美文网首页我依然爱iOSiOS点点滴滴
iOS设置图片拉伸不变形区域

iOS设置图片拉伸不变形区域

作者: Cloudox_ | 来源:发表于2017-11-27 11:00 被阅读696次

在开发中,我们可能会遇到这种情况:设计做了一张图,比如是按钮或文本条的背景,但由于文字长度不一,因此按钮或者文本条大小也会变化,如果直接设为背景,那么势必导致图片被拉伸,如果是整体图片还没什么,但如果是一些特殊的图片,比如这种:

image.png

由于右下角有一个箭头,正常来说不管按钮怎么变化大小,右下角的区域都应该是固定大小的,这就要求限制该区域不论图片怎么拉伸都不拉伸这个区域。

实现方法

iOS提供了简单的方法来设置不被拉伸的区域,是以图片原本大小上对应区域来设置的,方法为:

- (UIImage *)resizableImageWithCapInsets:(UIEdgeInsets)capInsets resizingMode:(UIImageResizingMode)resizingMode

这个方法第一个参数接受一个UIEdgeInsets对象,用来说明你要限制不被拉伸的区域,其包含四个参数,分别为图片中距离上、左、下、右边界的不拉伸部分的范围宽度:

UIEdgeInsets insets = UIEdgeInsetsMake(top, left, bottom, right);

也就是说,在我们引言的例子中,我们就需要设置距离右边界和下边界一定距离,确保包含打钩部分,使其不被拉伸。

如果还有其他角落有范围不想被拉伸,name灵活设置四个参数对应的距离就好了。

上面的方法中第二个参数表示拉伸的模式:

  • UIImageResizingModeStretch:拉伸模式,通过拉伸UIEdgeInsets指定的矩形区域来填充图片
  • UIImageResizingModeTile:平铺模式,通过重复显示UIEdgeInsets指定的矩形区域来填充图片

我们通过设置后,可以得到确保右下角不被拉伸的效果:

image.png

图中上面的是没做设置的,下面是做了设置的,可以看出效果很明显。

代码如下:

    // 不处理的图片
    UIImageView *unHandleImg = [[UIImageView alloc] initWithFrame:CGRectMake((SCREENWIDTH-200)/2, 100, 200, 30)];
    unHandleImg.image = [UIImage imageNamed:@"theImage"];
    [self.view addSubview:unHandleImg];
    
    // 处理区域拉伸的图片
    UIImageView *handleImg = [[UIImageView alloc] initWithFrame:CGRectMake((SCREENWIDTH-200)/2, 200, 200, 30)];
    UIImage *img = [UIImage imageNamed:@"theImage"];
    // 四个数值对应图片中距离上、左、下、右边界的不拉伸部分的范围宽度
    img = [img resizableImageWithCapInsets:UIEdgeInsetsMake(35, 35, 35, 35) resizingMode:UIImageResizingModeStretch];
    handleImg.image = img;
    [self.view addSubview:handleImg];

需要注意的是,需要把图片添加到Assets中,创建对应的图片集合才能够生效,否则效果是不尽如人意的。

这算是一个比较常用到的小技巧了,记录下来,也希望能够帮助还不知道的人。


示例工程:https://github.com/Cloudox/ImageAreaStretchDemo


查看作者首页

相关文章

  • iOS设置图片拉伸不变形区域

    引 在开发中,我们可能会遇到这种情况:设计做了一张图,比如是按钮或文本条的背景,但由于文字长度不一,因此按钮或者文...

  • iOS 设置图片不拉伸区域

    开发中,如果视图的大小不确定,而我们设置背景图片时如果拉伸过大,展示效果就会大打折扣。 iOS提供了简单的方法来设...

  • 关于IOS图片拉伸处理

    如果想要拉伸一个图片,直接拉伸的话,图片有透明的区域会拉伸变形,需要设置保护的区域方法可以分为两种通过代码 在As...

  • iOS 图片加载的一些问题

    图片渲染 解决图片渲染的方法: 图片变形 变形方式有: 图片拉伸 代码设置 图片设置设置Assets图片的Slic...

  • iOS 拉伸图片

    代码拉伸 图片加代码 1.设置图片拉伸区域 2.代码设置图片大小

  • UIImage

    图片的拉伸 效果图: 图片拉伸变形的方法、属性:  withCapInsets:通过设置 UIEdgeInset...

  • Xcode设置图片拉伸区域

    没有设置拉伸区域之前图片是介个样子的~ 开始设置拉伸区域:1.在Assets.xcassets中找到你要设置的图片...

  • iOS 图片不变形拉伸

    开发中我们经常会用到图片,当imageview的frame比图片的的尺寸要大如果直接将image 给 imagev...

  • 图片处理方法(截取、马赛克、拉伸)

    图片拉伸处理 实现类似Android中点9图的效果,拉伸图片不造成变形且不降低图片清晰度. 截取图片 截取图片的一...

  • UIImage 图片拉伸

    iOS 图片拉伸技 1、直接拉伸法 简单暴力,却是最最常用的方法,直接将图片设置为ImageView的image属...

网友评论

    本文标题:iOS设置图片拉伸不变形区域

    本文链接:https://www.haomeiwen.com/subject/fomrbxtx.html