Swift 启动页动画CAKeyframeAnimation)

前言

项目开发中有个需求,需要给启动页一个正在加载的动画,先上一个效果图。

上图最底层浅色圆圈,我们定义为浅A,转动的为深B,可以看到,深B是围绕着浅A圆圈的边缘旋转的。 下面对实现思想进行分析。

剖析

核心的难点是如何让深B紧凑沿着浅A的圆边做轨迹运动,为此,我们需要确定一个轨迹C,然后让深B轨迹C上做圆周运动

红色圆圈是轨迹C,它的圆点就是浅A的圆点,然后就是确定半径,为了让深B沿着浅A的边缘运动,所以轨迹C的半径应该是(浅A直径 - 深B直径 )/ 2。

代码

确定轨迹C的圆点和半径

let centerX = launchBottomView.center.x
let centerY = launchBottomView.center.y
let radius = (launchBottomView.bounds.size.width - launchTopView.bounds.size.width) / 2

创建椭圆轨迹C

let boundingRect = CGRect(x: centerX - radius,y: centerY - radius,width: radius * 2,height: radius * 2)
let path = CGPath(ellipseIn: boundingRect,transform: nil)

深B做动画

let animation = CAKeyframeAnimation(keyPath:"position")
animation.duration = 3
animation.path = path
animation.calculationMode = kCAAnimationPaced
animation.repeatCount = HUGE
launchTopView.layer.add(animation,forKey:"Move")
调用确定圆点、半径、动画的位置要写在 viewDidAppear方法中,否则会导致获取的控件大小不准确。

源码

https://github.com/LSnumber1/...

相关文章

软件简介:蓝湖辅助工具,减少移动端开发中控件属性的复制和粘...
现实生活中,我们听到的声音都是时间连续的,我们称为这种信...
前言最近在B站上看到一个漂亮的仙女姐姐跳舞视频,循环看了亿...
【Android App】实战项目之仿抖音的短视频分享App(附源码和...
前言这一篇博客应该是我花时间最多的一次了,从2022年1月底至...
因为我既对接过session、cookie,也对接过JWT,今年因为工作...