当前位置: 移动技术网 > IT编程>移动开发>IOS > iOS 图片旋转方法实例代码

iOS 图片旋转方法实例代码

2019年07月24日  | 移动技术网IT编程  | 我要评论

上海三要员将被调离,失婚女人翻身记,yutise

通过 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 图片旋转方法实例代码,希望对大家有所帮助

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

  • ios uicollectionview实现横向滚动

    现在使用卡片效果的app很多,之前公司让实现一种卡片效果,就写了一篇关于实现卡片的文章。文章最后附有demo实现上我选择了使用uicollectionview ... [阅读全文]
  • iOS UICollectionView实现横向滑动

    本文实例为大家分享了ios uicollectionview实现横向滑动的具体代码,供大家参考,具体内容如下uicollectionview的横向滚动,目前我使... [阅读全文]
  • iOS13适配深色模式(Dark Mode)的实现

    iOS13适配深色模式(Dark Mode)的实现

    好像大概也许是一年前, mac os系统发布了深色模式外观, 看着挺刺激, 时至今日用着也还挺爽的终于, 随着iphone11等新手机的发售, ios 13系统... [阅读全文]
  • ios 使用xcode11 新建项目工程的步骤详解

    ios 使用xcode11 新建项目工程的步骤详解

    xcode11新建项目工程,新增了scenedelegate这个类,转而将原appdelegate负责的对ui生命周期的处理担子接了过来。故此可以理解为:ios... [阅读全文]
  • iOS实现转盘效果

    本文实例为大家分享了ios实现转盘效果的具体代码,供大家参考,具体内容如下demo下载地址: ios转盘效果功能:实现了常用的ios转盘效果,轮盘抽奖效果的实现... [阅读全文]
  • iOS开发实现转盘功能

    本文实例为大家分享了ios实现转盘功能的具体代码,供大家参考,具体内容如下今天给同学们讲解一下一个转盘选号的功能,直接上代码直接看viewcontroller#... [阅读全文]
  • iOS实现轮盘动态效果

    本文实例为大家分享了ios实现轮盘动态效果的具体代码,供大家参考,具体内容如下一个常用的绘图,主要用来打分之类的动画,效果如下。主要是ios的绘图和动画,本来想... [阅读全文]
  • iOS实现九宫格连线手势解锁

    本文实例为大家分享了ios实现九宫格连线手势解锁的具体代码,供大家参考,具体内容如下demo下载地址:效果图:核心代码://// clockview.m// 手... [阅读全文]
  • iOS实现卡片堆叠效果

    本文实例为大家分享了ios实现卡片堆叠效果的具体代码,供大家参考,具体内容如下如图,这就是最终效果。去年安卓5.0发布的时候,当我看到安卓全新的material... [阅读全文]
  • iOS利用余弦函数实现卡片浏览工具

    iOS利用余弦函数实现卡片浏览工具

    本文实例为大家分享了ios利用余弦函数实现卡片浏览工具的具体代码,供大家参考,具体内容如下一、实现效果通过拖拽屏幕实现卡片移动,左右两侧的卡片随着拖动变小,中间... [阅读全文]
验证码:
移动技术网