更多图片处理方法见图片组件 BBWebImage
iOS 图片旋转方法
通过 CGImage 或 CIImage 旋转特定角度
UIImage
可通过CGImage
或CIImage
初始化,初始化方法分别为init(cgImage: CGImage, scale: CGFloat, orientation: UIImageOrientation)
和init(ciImage: CIImage, scale: CGFloat, orientation: UIImageOrientation)
。通过UIImageOrientation
的不同取值,可以使图片旋转90、180、270度。
用原图绘制
通过原图绘制实现旋转图片任意角度。可以先绘制红色背景,效果如下
static func rotateImage(_ image: UIImage, withAngle angle: Double) -> UIImage? {
if angle.truncatingRemainder(dividingBy: 360) == 0 { return image }
let imageRect = CGRect(origin: .zero, size: image.size)
let radian = CGFloat(angle / 180 * M_PI)
let rotatedTransform = CGAffineTransform.identity.rotated(by: radian)
var rotatedRect = imageRect.applying(rotatedTransform)
rotatedRect.origin.x = 0
rotatedRect.origin.y = 0
UIGraphicsBeginImageContext(rotatedRect.size)
guard let context = UIGraphicsGetCurrentContext() else { return nil }
context.translateBy(x: rotatedRect.width / 2, y: rotatedRect.height / 2)
context.rotate(by: radian)
context.translateBy(x: -image.size.width / 2, y: -image.size.height / 2)
image.draw(at: .zero)
let rotatedImage = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
return rotatedImage
}
angle
表示需要旋转的角度,单位是度,正值表示图片顺时针方向旋转。如果旋转的角度能被360整除,则不需要旋转,直接返回原图。如果是其他角度,需要进行绘制。
绘制首先要获取原点为零、大小为原图大小的CGRect
,用imageRect
表示。CGAffineTransform.identity
获得单位矩阵。CGAffineTransform
的rotated(by angle: CGFloat) -> CGAffineTransform
方法将矩阵旋转一定角度,返回旋转后的矩阵。角度采用弧度制,正值为逆时针方向,负值为顺时针方向。CGRect
的applying(_ t: CGAffineTransform) -> CGRect
方法将旋转后的矩阵用于imageRect
,返回包含imageRect
旋转后的最小CGRect
,用rotatedRect
表示,作为位图大小。rotatedRect
的原点可能不为零,需要置为零。
位图的CGContext
以原点为轴旋转。为了使图片以中心为轴旋转,先把CGContext
的原点移至中心context.translateBy(x: rotatedRect.width / 2, y: rotatedRect.height / 2)
,然后再旋转context.rotate(by: radian)
。CGContext
的rotate(by angle: CGFloat)
方法也是采用弧度制,正值表示context
逆时针方向旋转,绘制出来的效果为图片顺时针方向旋转。此时,context
的原点在位图的中心,需要按照原图大小的一半进行位移,context.translateBy(x: -image.size.width / 2, y: -image.size.height / 2)
,使整张图从原点绘制后图的中心在位图区域的中心。
如果要得到红色背景,则在取得context
后立即填充红色,即在guard let context = UIGraphicsGetCurrentContext() else { return nil }
后加上
UIColor.red.setFill()
context.fill(rotatedRect)
通过 CALayer 绘制
可以将图片放在UIView
上,用CALayer
绘制旋转后的图片。
static func rotateImage(_ image: UIImage, withAngle angle: Double) -> UIImage? {
if angle.truncatingRemainder(dividingBy: 360) == 0 { return image }
let imageView = UIImageView(image: image)
imageView.transform = CGAffineTransform.identity.rotated(by: CGFloat(angle / 180 * M_PI))
let rotatedRect = imageView.bounds.applying(imageView.transform)
let containerView = UIView(frame: CGRect(origin: .zero, size: rotatedRect.size))
imageView.center = containerView.center
containerView.addSubview(imageView)
UIGraphicsBeginImageContext(containerView.bounds.size)
guard let context = UIGraphicsGetCurrentContext() else { return nil }
containerView.layer.render(in: context)
let rotatedImage = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
return rotatedImage
}
将原图放入UIImageView
,用imageView
表示,然后进行矩阵旋转。获取旋转后的CGRect
,创建一个相同大小的UIView
,用containerView
表示,作为imageView
的父视图(superview
)。将imageView
居中放置。用containerView
的layer
进行绘制。
如果要得到红色背景,则在创建containerView
后设置背景色,即在let containerView = UIView(frame: CGRect(origin: .zero, size: rotatedRect.size))
后加上
containerView.backgroundColor = .red
转载请注明出处:http://www.cnblogs.com/silence-cnblogs/p/6496564.html