iOS图片拉伸的方法

假如下面的一张图片,是用来做按钮的背景图片的,原始尺寸是76 × 40

我们通过代码将这张图片设置为按钮的背景图片,假如我们将创建好的按钮的宽高设置为:(W=200, H=50)代码如下:

 // 初始化按钮
 UIButton *button = [[UIButton alloc] init];
 // 设置尺寸
 button.frame = CGRectMake(100, 200, 200, 50);
 
 // 加载图片
 UIImage *image = [UIImage imageNamed:@"ppm_new_shuliang.png"];
 
 // 设置背景图片
 [button setBackgroundImage:image forState:UIControlStateNormal];
 
 // 添加按钮 
 [self.view addSubview:button];

 结果如下:图片被拉伸了。

原因分析:是将原是尺寸为76 × 40 的图片拉伸成了W=200, H=50;

解决方案:

1.找美工重做一张较大的图片,这样的话就会出现软件包将来会变大,占用空间更大;如果我们要经常修改按钮的frame,美工设计比较繁琐;
2.苹果为我们提供了关于图片拉伸的API,我们可以直接利用代码实现;

修改后:

 // 初始化按钮
 UIButton *button = [[UIButton alloc] init];
 // 设置尺寸
 button.frame = CGRectMake(100, 200, 200, 50);
 
 CGFloat top = 0; // 顶端盖高度
 CGFloat bottom = 0 ; // 底端盖高度
 CGFloat left = 22; // 左端盖宽度
 CGFloat right = 22; // 右端盖宽度
 UIEdgeInsets insets = UIEdgeInsetsMake(top, left, bottom, right);
 
 
 // 加载图片
 UIImage *image = [UIImage imageNamed:@"ppm_new_shuliang.png"];
 
 image = [image resizableImageWithCapInsets:insets resizingMode:UIImageResizingModeStretch];
 
 // 设置背景图片
 [button setBackgroundImage:image forState:UIControlStateNormal];
 
 // 添加按钮 
 [self.view addSubview:button];


还有一种设置方法:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。