UIImageView的图片拉伸(下)

上一篇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];
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 返回一张受保护且被拉伸的图片 应用场景:聊天窗口的气泡 方法一(弃用): iOS 5.0以前使用(弃用)这个方法会...
    林安530阅读 15,913评论 1 36
  • 许多UIView的子类,如一个UIButton或一个UILabel,它们知道怎么绘制自己。迟早,你也将想要做一些自...
    shenzhenboy阅读 1,686评论 2 8
  • 苹果为了节省打包文件(ipa)的存储空间,在iOS5就推出了图片拉伸,但是初衷是好的,如果程序猿不会用,那一切都是...
    coderYJ阅读 3,939评论 1 11
  • 台北101(Taipei 101),又称台北101大楼,在规划阶段初期原名台北国际金融中心(Taipei Fina...
    道形图阅读 715评论 0 7
  • 冬日恋歌下的暖阳 腊梅花心怒放 万物凋零的时候 傲梅独占花魁 也许闻香识女人 就要去赏梅 梅妻鹤子 多么美好的追求...
    罗嗦小窝_tpw_698阅读 237评论 0 0