编程开源技术交流,分享技术与知识

网站首页 > 开源技术 正文

使用Lottie做加载动画

wxchong 2024-06-13 22:29:00 开源技术 10 ℃ 0 评论

使用Lottie做加载动画

使用Lottie做加载动画

先给出Lottie的链接:Lottie-iOS

使用Lottie做动画的好处:

  1. 多平台统一,包括使用和动画效果
  2. 不用导入图片,只需要一个json文件(大小只有几kb到几十kb),有效减小应用安装包体积
  3. 程序员几乎不用写动画代码,也能达到炫酷的动画效果

最主要的两个类是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做动画的好处:

  1. 多平台统一,包括使用和动画效果
  2. 不用导入图片,只需要一个json文件(大小只有几kb到几十kb),有效减小应用安装包体积
  3. 程序员几乎不用写动画代码,也能达到炫酷的动画效果

最主要的两个类是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()
}
复制代码

效果图:

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表