时间:2021-05-20
通过 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}如果旋转的角度能被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以上所述是小编给大家介绍的iOS 图片旋转方法实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了js根据鼠标移动速度背景图片自动旋转的方法。分享给大家供大家参考。具体实现方法如下:复制代码代码如下:js实现图片快速旋转围绕的鼠标希望本文所述对
之前分别介绍了图片裁剪和图片旋转方法《iOS图片裁剪方法》地址:http://www.zzvips.com/article/145411.html《iOS图片旋
本文实例为大家分享了Java实现图片旋转,供大家参考,具体内容如下方法一:普通方法实现图片旋转/***图像旋转*@paramsrc*@paramangel*@r
本文实例为大家分享了iOS实现音乐播放器图片旋转的具体代码,供大家参考,具体内容如下通过给继承与UIImageView的类CXGImageView添加CABas
本文实例为大家展示了图片旋转、鼠标滚轮缩放、镜像、切换图片多重效果,提供了详细的代码,分享给大家供大家参考,具体内容如下具体代码:图片旋转,鼠标滚轮缩放,镜像,