美文网首页加载动画
使用Lottie做加载动画

使用Lottie做加载动画

作者: X勒个F | 来源:发表于2019-05-04 01:59 被阅读0次

    使用Lottie做加载动画

    先给出Lottie的链接:Lottie-iOS

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

    最主要的两个类是AnimationViewAnimationAnimationView是执行动画的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
    

    其中animationNamejson文件名,可以在这里下载,也可以自己制作。

    下面就可以在需要的地方执行动画了

    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. 程序员几乎不用写动画代码,也能达到炫酷的动画效果

    最主要的两个类是AnimationViewAnimationAnimationView是执行动画的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
    

    其中animationNamejson文件名,可以在这里下载,也可以自己制作。

    下面就可以在需要的地方执行动画了

    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()
    }
    
    

    效果图:

    loading

    相关文章

      网友评论

        本文标题:使用Lottie做加载动画

        本文链接:https://www.haomeiwen.com/subject/jqmtoqtx.html