使用Lottie做加载动画
先给出Lottie的链接:Lottie-iOS
使用Lottie做动画的好处:
- 多平台统一,包括使用和动画效果
- 不用导入图片,只需要一个json文件(大小只有几kb到几十kb),有效减小应用安装包体积
- 程序员几乎不用写动画代码,也能达到炫酷的动画效果
最主要的两个类是AnimationView
和Animation
,AnimationView
是执行动画的View,Animation
即所执行的动画。例如加载动画:
创建一个AnimationView
- let animationView: AnimationView = {
- let animationView = AnimationView()
- animationView.size = CGSize(width: 170, height: 170)
- return animationView
- }()
- 复制代码
创建一个Animation
实例,并将它赋值给animationView
的animation属性
- let animation = Animation.named("animationName")
-
- animationView.animation = animation
- 复制代码
其中animationName
是json
文件名,可以在这里下载,也可以自己制作。
下面就可以在需要的地方执行动画了
- animationView.play(fromProgress: 0, toProgress: 1, loopMode: .loop, completion: nil)
- 复制代码
动画可以终止或暂停
- animationView.stop()
-
-
- animationView.pause()
-
- 复制代码
最后,这里是一个使用Lottie做的loadingView库。可以在LottieFiles官网下载动画的json文件导入项目。
使用pod安装
- pod 'LottieLoadingView'
- 复制代码
导入
- import LottieLoadingView
- 复制代码
- // 设置动画
- AQLoadingView.shared.animationName = "935-loading"
- // 开始加载
- AQLoadingView.startLoading()
- // 处理任务
- DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 5) {
- // 结束加载
- AQLoadingView.endLoading()
- }
-
- 复制代码
使用Lottie做加载动画
先给出Lottie的链接:Lottie-iOS
使用Lottie做动画的好处:
- 多平台统一,包括使用和动画效果
- 不用导入图片,只需要一个json文件(大小只有几kb到几十kb),有效减小应用安装包体积
- 程序员几乎不用写动画代码,也能达到炫酷的动画效果
最主要的两个类是AnimationView
和Animation
,AnimationView
是执行动画的View,Animation
即所执行的动画。例如加载动画:
创建一个AnimationView
- let animationView: AnimationView = {
- let animationView = AnimationView()
- animationView.size = CGSize(width: 170, height: 170)
- return animationView
- }()
- 复制代码
创建一个Animation
实例,并将它赋值给animationView
的animation属性
- let animation = Animation.named("animationName")
-
- animationView.animation = animation
- 复制代码
其中animationName
是json
文件名,可以在这里下载,也可以自己制作。
下面就可以在需要的地方执行动画了
- animationView.play(fromProgress: 0, toProgress: 1, loopMode: .loop, completion: nil)
- 复制代码
动画可以终止或暂停
- animationView.stop()
-
-
- animationView.pause()
-
- 复制代码
最后,这里是一个使用Lottie做的loadingView库。可以在LottieFiles官网下载动画的json文件导入项目。
使用pod安装
- pod 'LottieLoadingView'
- 复制代码
导入
- import LottieLoadingView
- 复制代码
- // 设置动画
- AQLoadingView.shared.animationName = "935-loading"
- // 开始加载
- AQLoadingView.startLoading()
- // 处理任务
- DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 5) {
- // 结束加载
- AQLoadingView.endLoading()
- }
-
- 复制代码
效果图: