本篇文章主要介绍了iOS 图片裁剪的实现方法,主要介绍了两种图片剪裁的方法,具有一定的参考价值,有兴趣的可以了解一下。
iOS 图片裁剪方法,主要有两种,一起来看下。
通过 CGImage 或 CIImage 裁剪
UIImage有cgImage和ciImage属性,分别可以获得CGImage和CIImage对象。CGImage和CIImage对象都有cropping(to:)方法,传入CGRect的参数表示要裁剪的区域(采用UIImage的坐标)。
static func cropImage(_ image: UIImage, withRect rect: CGRect) -> UIImage? {
if let cgImage = image.cgImage,
let croppedCgImage = cgImage.cropping(to: rect) {
return UIImage(cgImage: croppedCgImage)
} else if let ciImage = image.ciImage {
let croppedCiImage = ciImage.cropping(to: rect)
return UIImage(ciImage: croppedCiImage)
}
return nil
}
对CGImage来说,传入的CGRect参数如果完全不在原图区域内,cropping(to:)方法返回空;如果有部分在原图区域内,cropping(to:)方法返回在原图区域部分的CGImage。
通过位图(Bitmap)裁剪
通过位图重新绘制图片,也可以获得裁剪之后的图片。
static func cropImage(_ image: UIImage, withRect rect: CGRect) -> UIImage? {
UIGraphicsBeginImageContext(rect.size)
guard let context = UIGraphicsGetCurrentContext() else { return nil }
context.translateBy(x: -rect.minX, y: -rect.minY)
image.draw(at: .zero)
let croppedImage = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
return croppedImage
}
位图大小为需要裁剪区域CGRect的大小size。用原图绘制,为了使裁剪区域正好在位图区域,需要进行坐标位移context.translateBy(x: -rect.minX, y: -rect.minY)。
如果传入的CGRect参数有部分或全部不在原图区域内,则超出原图区域的部分也会被绘制(绘制为透明),这与CGImage的裁剪方法不同。
简单试了几次,发现通过 CGImage 裁剪的 CPU 占用率比通过位图裁剪要低。仅从性能角度考虑,推荐使用前者。如果希望裁剪出来的图片不超出原图区域,也推荐使用前者。如果需要绘制其他的内容(比如其他形状、颜色,或绘制的内容超出原图区域),则要使用后者。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程学习网。
本文标题为:iOS 图片裁剪的实现方法
- Android studio实现动态背景页面 2023-05-23
- Android实现轮询的三种方式 2023-02-17
- 最好用的ios数据恢复软件:PhoneRescue for Mac 2023-09-14
- Flutter实现底部和顶部导航栏 2022-08-31
- 作为iOS开发,这道面试题你能答出来,说明你基础很OK! 2023-09-14
- iOS 对当前webView进行截屏的方法 2023-03-01
- SurfaceView播放视频发送弹幕并实现滚动歌词 2023-01-02
- 详解flutter engine 那些没被释放的东西 2022-12-04
- Android实现监听音量的变化 2023-03-30
- Android MaterialButton使用实例详解(告别shape、selector) 2023-06-16
