上一篇UIImageView的图片拉伸(上)我们介绍了使用UIImageView的contentModel来对图片进行拉伸,但是当我们遇到聊天气泡那种根据文字大小来变化拉伸的背景图时,使用contentModel来对图片进行拉伸已经不能满足需求了,强行拉伸会使聊天气泡的尖角发生形变,所以我们需要别的方式来对图片进行拉伸。
实现方法
iOS提供了简单的方法来设置不被拉伸的区域,是以图片原本大小上对应区域来设置的,方法为:
- (UIImage *)resizableImageWithCapInsets:(UIEdgeInsets)capInsets resizingMode:(UIImageResizingMode)resizingMode
这个方法第一个参数接受一个UIEdgeInsets对象,用来说明你要限制不被拉伸的区域,其包含四个参数,分别为图片中距离上、左、下、右边界的不拉伸部分的范围宽度:
UIEdgeInsets insets = UIEdgeInsetsMake(top, left, bottom, right);
也就是说,在我们引言的例子中,我们就需要设置距离右边界和下边界一定距离,确保包含四周我们不想拉伸的部分,使其不被拉伸。
如果还有其他角落有范围不想被拉伸,name灵活设置四个参数对应的距离就好了。
上面的方法中第二个参数表示拉伸的模式:
UIImageResizingModeStretch:
拉伸模式,通过拉伸UIEdgeInsets指定的矩形区域来填充图片
UIImageResizingModeTile:
平铺模式,通过重复显示UIEdgeInsets指定的矩形区域来填充图片
示例代码:
// 不处理的图片
UIImageView *unHandleImg = [[UIImageView alloc] initWithFrame:CGRectMake(100, 100, 200, 100)];
unHandleImg.image = [UIImage imageNamed:@"theImage"];
[self.view addSubview:unHandleImg];
// 处理区域拉伸的图片
UIImageView *handleImg = [[UIImageView alloc] initWithFrame:CGRectMake(100, 200, 200, 100)];
UIImage *image = [UIImage imageNamed:@"green_arrow"];
// 四个数值对应图片中距离上、左、下、右边界的不拉伸部分的范围宽度 ,也就是对中间部分进行拉伸
CGPoint center = CGPointMake(image.size.width / 2.0f, image.size.height / 2.0f);
UIEdgeInsets edgeInsets = UIEdgeInsetsMake(center.y, center.x, center.y, center.x);
image = [image resizableImageWithCapInsets:edgeInsets resizingMode:UIImageResizingModeStretch];
handleImg.image = image;
[self.view addSubview:handleImg];
需要注意的是,需要把图片添加到Assets中,创建对应的图片集合才能够生效,否则效果是不尽如人意的。
附:
另一种不是很规范的实现
UIImage *img=[UIImage imageNamed:@"imageName"];
//设置不拉伸区域,左边15个单位,上边12个单位不拉伸,其余位置拉伸
img=[img stretchableImageWithLeftCapWidth:15 topCapHeight:12];
UIImageView *imgView=[[UIImageView alloc] initWithImage:img];
[imgView setFrame:CGRectMake(10, 10, 200, 200)];
[self. view addSubview:imgView];