UIImageView的图片拉伸(下)

2017-08-01  本文已影响251人  SuAdrenine

上一篇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];
上一篇 下一篇

猜你喜欢

热点阅读