繁体   English   中英

UIButton backgroundImage stretchableImageWithLeftCapWidth:topCapHeight问题

[英]UIButton backgroundImage stretchableImageWithLeftCapWidth:topCapHeight issue

我有一个指定宽度为200的UIButton 。它的autoresizingMask属性设置为UIViewAutoresizingFlexibleWidth UIImage应用于此按钮的backgroundImage属性。 UIimage定义如下:

[[UIImage imageNamed:@"buttonimage.png"] stretchableImageWithLeftCapWidth:10 topCapHeight:0]

buttonimage.png的宽度为400px(由于视网膜分辨率,按钮宽度为2 buttonimage.png )并且表示圆角矩形。 在纵向模式下,一切都很好。 一旦用户旋转设备并且iPhone进入横向模式, UIButton就会被拉伸。 由于此行为,图像的左圆角边界保持不变( stretchableImageWithLeftCapWidth:但右角也被拉伸。 是否有任何我忘记设置的属性,确保只有一个指定的像素(例如第十个像素)被拉伸而其他任何东西都保留了它的尺寸?

提前致谢!

编辑:如果我使用较小的图像,已经在纵向模式下拉伸,两个边框似乎都会被展开。

解决了! 如果您的图像被称为“myImage.png”并且它是视网膜版本,请将其命名为“myImage@2x.png”

是否有任何我忘记设置的属性,确保只有一个指定的像素(例如第十个像素)被拉伸而其他任何东西都保留了它的尺寸?

不是真的,但考虑到图像的大小,您应该重新读取leftCapWidth属性。

可伸展图像的工作方式是:提供左上角,下一个像素被拉伸,图像右侧width = (total width - left cap + 1)保持不变。 鉴于您将左上角设置为10,原始图像为400,您告诉iOS图像右侧不可伸展的右侧是400-10-1=389px 同样的事情垂直适用。 检查您是否在普通设备上使用@ 2x图像,其名称上没有@ 2x,或者2x版本的像素不是两倍,或者是大写/小写差异。 您可以通过nslogging找到加载的图像大小。

我不知道为什么图像的右侧会被拉伸。 假设你有height=0 ,如果按钮高度改变,整个图像可以垂直拉伸,但这不太可能导致只有右侧的扭曲。

据我所知,你的代码没有任何问题,应该导致图像的右侧被裁剪。 下面是我使用的确切代码,我知道它可以产生与你正在寻找相同的效果。

UIButton *button=[[UIButton alloc] initWithFrame:CGRectMake(0, 0, 245, 51)];
button.autoresizingMask=UIViewAutoresizingFlexibleWidth;
[button setBackgroundImage:[[UIImage imageNamed:@"userbubble.png"] stretchableImageWithLeftCapWidth:40 topCapHeight:0] forState:UIControlStateNormal];
[self.view addSubview:button];

我的猜测是问题来自您正在使用的png,或者可能来自项目中的Compress PNG Files设置。 此外,由于您使用的图像太大,请尝试进一步放置左边的边框,例如40或50像素。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM