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

相关文章

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

Python Faker库基本用法详解

《PythonFaker库基本用法详解》Faker是一个非常强大的库,适用于生成各种类型的伪随机数据,可以帮助开发者在测试、数据生成、或其他需要随机数据的场景中提高效率,本文给大家介绍PythonF... 目录安装基本用法主要功能示例代码语言和地区生成多条假数据自定义字段小结Faker 是一个 python

Python实现AVIF图片与其他图片格式间的批量转换

《Python实现AVIF图片与其他图片格式间的批量转换》这篇文章主要为大家详细介绍了如何使用Pillow库实现AVIF与其他格式的相互转换,即将AVIF转换为常见的格式,比如JPG或PNG,需要的小... 目录环境配置1.将单个 AVIF 图片转换为 JPG 和 PNG2.批量转换目录下所有 AVIF 图

Java Predicate接口定义详解

《JavaPredicate接口定义详解》Predicate是Java中的一个函数式接口,它代表一个判断逻辑,接收一个输入参数,返回一个布尔值,:本文主要介绍JavaPredicate接口的定义... 目录Java Predicate接口Java lamda表达式 Predicate<T>、BiFuncti

详解如何通过Python批量转换图片为PDF

《详解如何通过Python批量转换图片为PDF》:本文主要介绍如何基于Python+Tkinter开发的图片批量转PDF工具,可以支持批量添加图片,拖拽等操作,感兴趣的小伙伴可以参考一下... 目录1. 概述2. 功能亮点2.1 主要功能2.2 界面设计3. 使用指南3.1 运行环境3.2 使用步骤4. 核

一文详解JavaScript中的fetch方法

《一文详解JavaScript中的fetch方法》fetch函数是一个用于在JavaScript中执行HTTP请求的现代API,它提供了一种更简洁、更强大的方式来处理网络请求,:本文主要介绍Jav... 目录前言什么是 fetch 方法基本语法简单的 GET 请求示例代码解释发送 POST 请求示例代码解释

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

详解nginx 中location和 proxy_pass的匹配规则

《详解nginx中location和proxy_pass的匹配规则》location是Nginx中用来匹配客户端请求URI的指令,决定如何处理特定路径的请求,它定义了请求的路由规则,后续的配置(如... 目录location 的作用语法示例:location /www.chinasem.cntestproxy

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经