先给出Lottie的连接:Lottie-iOSios
最主要的两个类是AnimationView
和Animation
,AnimationView
是执行动画的View,Animation
即所执行的动画。例如加载动画:git
建立一个AnimationView
程序员
let animationView: AnimationView = {
let animationView = AnimationView()
animationView.size = CGSize(width: 170, height: 170)
return animationView
}()
复制代码
建立一个Animation
实例,并将它赋值给animationView
的animation属性github
let animation = Animation.named("animationName")
animationView.animation = animation
复制代码
其中animationName
是json
文件名,能够在这里下载,也能够本身制做。json
下面就能够在须要的地方执行动画了bash
animationView.play(fromProgress: 0, toProgress: 1, loopMode: .loop, completion: nil)
复制代码
动画能够终止或暂停async
animationView.stop()
animationView.pause()
复制代码
最后,这里是一个使用Lottie作的loadingView库。能够在LottieFiles官网下载动画的json文件导入项目。oop
使用pod安装动画
pod 'LottieLoadingView'
复制代码
导入ui
import LottieLoadingView
复制代码
// 设置动画
AQLoadingView.shared.animationName = "935-loading"
// 开始加载
AQLoadingView.startLoading()
// 处理任务
DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 5) {
// 结束加载
AQLoadingView.endLoading()
}
复制代码
先给出Lottie的连接:Lottie-iOS
最主要的两个类是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()
}
复制代码
效果图: