ios 图片拉伸resizableImageWithCapInsets:详解

2024-06-22 13:08

本文主要是介绍ios 图片拉伸resizableImageWithCapInsets:详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在项目中,我们常常用到一些做背景的图片需要拉伸,今天就来详细讲讲我对图片拉伸函数:”resizableImageWithCapInsets:“的理解

为了演示我先准备好了图片,并做了标注


我们在sb上摆两个按钮,一个用来做测试改变背景图片用,命名为“测试按钮”。另一个用以正常显示背景用(即不拉伸图片),命名为“默认显示”。点击按钮设置按钮背景。可以看到图片均匀被拉伸,铺满整个按钮。很多时候这不是我们想要的效果。

如果我们想向下面这样拉伸图片,两条红线以外的不拉伸,保持原状,只拉伸两条红线以内的部分我们改怎么做呢?显然要用到- (UIImage *)resizableImageWithCapInsets:(UIEdgeInsets)capInsets这个函数。这个函数只有一个参数,类型是UIEdegInsets,这个参数由4个CGFloat构成,分别是top, left , bottom, right。top表示的是距离顶部多少像素不被拉伸,left表示左边多少像素不被拉伸以此类推。那么要达到我们刚才想要的效果就是设置top和buttom都为5个像素即可,效果如图,我们可以看到红线上下部分是没有被拉伸,至于中间部分为什么会呈现这样的状态。我们可以这样理解,我们的按钮宽高是大于图片的宽高的,我们沿着红线部分把img切开,这样有ABC 3部分,AB部分由于不做拉伸,直接放到按钮的上下边缘,但是这样左右仍然没有填满,那么它就复制一份AB向右边延伸。那么中间剩余的部分完全有B部分复制填满。这拉伸方式称为“瓦片式”。那么还有另一种填充方式。我们即将讲到。

- (IBAction)topBottomStay:(id)sender
{UIImage *resizeImg=[self.img resizableImageWithCapInsets:UIEdgeInsetsMake(5, 0, 5, 0)];[self.btn setBackgroundImage:resizeImg forState:UIControlStateNormal];
}

下面我们来讲讲另一种方式,那么这要用到另一个函数  - (UIImage *)resizableImageWithCapInsets:(UIEdgeInsets)capInsets resizingMode:(UIImageResizingMode);

这个函数有两个参数,第一个我们已经讲过,第二个则是拉伸模式,是一个枚举,包含两种模式(UIImageResizingModeTile,UIImageResizingModeStretch)第一中模式就是我们上面讲到的瓦片式,如果设置这个模式为UIImageResizingModeTile,那么这个函数和上面讲到的第一个包含一个参数的函数是没有区别的。那我们就来试试第二种模式看看效果是什么样的。

- (IBAction)topBottomStay:(id)sender
{//UIImage *resizeImg=[self.img resizableImageWithCapInsets:UIEdgeInsetsMake(5, 0, 5, 0)];UIImage *resizeImg1=[self.img resizableImageWithCapInsets:UIEdgeInsetsMake(5, 0, 5, 0) resizingMode:UIImageResizingModeStretch];[self.btn setBackgroundImage:resizeImg1 forState:UIControlStateNormal];
}


如图,我们可以看到AC部分仍然在上下边缘,高度没有被拉伸,但是为了铺满整个按钮,长度被拉伸到了和按钮一样。B部分仍然在中间,高度和宽度都被拉伸用来填满整个空白区域。这就是第二种模式(UIImageResizingModeStretch)。

那么想实现下面四边均不拉伸(只有中间部分拉伸)的效果我想大家也会做了,那就让我们来看看实际是怎么一种效果。


这里仍然有两种模式,我们先看第一种模式,左右我们已经知道是10个像素,你可以先猜猜是什么效果。

- (IBAction)borderStay:(id)sender {UIImage *resizeImg=[self.img resizableImageWithCapInsets:UIEdgeInsetsMake(5, 10, 5, 10)];[self.btn setBackgroundImage:resizeImg forState:UIControlStateNormal];
}


结果和你想象的一样么?很明显这是沿红线把img切开,共分为9块,1、2、3、4部分宽高均不变,直接铺到按钮的四个角上,5、6、7、8分别铺到按钮的对应边上,长度(宽度)不够的复制补齐,剩余部分第9块复制补齐。

我们再来看看第二中模式

- (IBAction)borderStay:(id)sender {//UIImage *resizeImg=[self.img resizableImageWithCapInsets:UIEdgeInsetsMake(5, 10, 5, 10)];UIImage *resizeImg=[self.img resizableImageWithCapInsets:UIEdgeInsetsMake(5, 10, 5, 10) resizingMode:UIImageResizingModeStretch];[self.btn setBackgroundImage:resizeImg forState:UIControlStateNormal];
}

这种模式和第一种模式的区别在于分成9块的摆放位置没有变,1、2、3、4宽高依然没有边之外,其他部分不是复制铺满,而是直接拉伸铺满。讲到这里我想大家已经很了解怎么拉伸图片了。



这篇关于ios 图片拉伸resizableImageWithCapInsets:详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1084372

相关文章

Spring @RequestMapping 注解及使用技巧详解

《Spring@RequestMapping注解及使用技巧详解》@RequestMapping是SpringMVC中定义请求映射规则的核心注解,用于将HTTP请求映射到Controller处理方法... 目录一、核心作用二、关键参数说明三、快捷组合注解四、动态路径参数(@PathVariable)五、匹配请

git stash命令基本用法详解

《gitstash命令基本用法详解》gitstash是Git中一个非常有用的命令,它可以临时保存当前工作区的修改,让你可以切换到其他分支或者处理其他任务,而不需要提交这些还未完成的修改,这篇文章主要... 目录一、基本用法1. 保存当前修改(包括暂存区和工作区的内容)2. 查看保存了哪些 stash3. 恢

java String.join()方法实例详解

《javaString.join()方法实例详解》String.join()是Java提供的一个实用方法,用于将多个字符串按照指定的分隔符连接成一个字符串,这一方法是Java8中引入的,极大地简化了... 目录bVARxMJava String.join() 方法详解1. 方法定义2. 基本用法2.1 拼接

Java中的record使用详解

《Java中的record使用详解》record是Java14引入的一种新语法(在Java16中成为正式功能),用于定义不可变的数据类,这篇文章给大家介绍Java中的record相关知识,感兴趣的朋友... 目录1. 什么是 record?2. 基本语法3. record 的核心特性4. 使用场景5. 自定

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

Python struct.unpack() 用法及常见错误详解

《Pythonstruct.unpack()用法及常见错误详解》struct.unpack()是Python中用于将二进制数据(字节序列)解析为Python数据类型的函数,通常与struct.pa... 目录一、函数语法二、格式字符串详解三、使用示例示例 1:解析整数和浮点数示例 2:解析字符串示例 3:解

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

MySQL 表的内外连接案例详解

《MySQL表的内外连接案例详解》本文给大家介绍MySQL表的内外连接,结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录表的内外连接(重点)内连接外连接表的内外连接(重点)内连接内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我

Windows 系统下 Nginx 的配置步骤详解

《Windows系统下Nginx的配置步骤详解》Nginx是一款功能强大的软件,在互联网领域有广泛应用,简单来说,它就像一个聪明的交通指挥员,能让网站运行得更高效、更稳定,:本文主要介绍W... 目录一、为什么要用 Nginx二、Windows 系统下 Nginx 的配置步骤1. 下载 Nginx2. 解压

RabbitMQ工作模式中的RPC通信模式详解

《RabbitMQ工作模式中的RPC通信模式详解》在RabbitMQ中,RPC模式通过消息队列实现远程调用功能,这篇文章给大家介绍RabbitMQ工作模式之RPC通信模式,感兴趣的朋友一起看看吧... 目录RPC通信模式概述工作流程代码案例引入依赖常量类编写客户端代码编写服务端代码RPC通信模式概述在R