内容简介:最主要的两个类是创建一个创建一个
- 多平台统一,包括使用和动画效果
- 不用导入图片,只需要一个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()
}
复制代码
效果图:
以上所述就是小编给大家介绍的《使用Lottie做加载动画》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- iOS视频加载动画
- CSharpGL(50)使用Assimp加载骨骼动画
- 游戏制作之路(38)加载旧的动画
- 游戏制作之路(39)加载人形的动画4
- React 写一个 spinner 圆形加载动画
- 满月了!Layx v2.3.2 新增加载动画、窗口组预加载设置
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深入理解计算机系统(原书第2版)
(美)Randal E.Bryant、David O'Hallaron / 龚奕利、雷迎春 / 机械工业出版社 / 2011-1-1 / 99.00元
本书从程序员的视角详细阐述计算机系统的本质概念,并展示这些概念如何实实在在地影响应用程序的正确性、性能和实用性。全书共12章,主要内容包括信息的表示和处理、程序的机器级表示、处理器体系结构、优化程序性能、存储器层次结构、链接、异常控制流、虚拟存储器、系统级I/O、网络编程、并发编程等。书中提供大量的例子和练习,并给出部分答案,有助于读者加深对正文所述概念和知识的理解。 本书的最大优点是为程序......一起来看看 《深入理解计算机系统(原书第2版)》 这本书的介绍吧!