加载中,加载中......使用SwiftUI设计2种Loading动画

简介: 加载中,加载中......使用SwiftUI设计2种Loading动画

加载中,加载中......使用SwiftUI设计2种Loading动画


项目背景

iOS客户端开发过程中,在页面加载时或者数据更新时,常常需要一个Loading动画进行过渡,避免交互之间的生硬感。

Loading动画有很多,这里提供两种Loading动画供大家参考。

项目搭建

首先,创建一个新的SwiftUI项目,命名为LoadingView。

image.png

圆点加载

第一种Loading是在页面初始加载时最常见的方式,基本的交互效果是4个圆点在不断缩放,体现出加载中的效果。

image.png

首先我们要声明一个变量控制圆点的缩放,示例:

@State var isAnimation: Bool = false

然后我们构建基础的圆点loading视图,示例:

// 4个圆点加载
func fourDotsLoading() -> some View {
    HStack {
        ForEach(0 ..< 4) { index in
            Circle()
                .fill(Color.green)
                .frame(width: 20, height: 20)
                .scaleEffect(isAnimation ? 1.0 : 0.5)
                .animation(Animation.easeInOut(duration: 0.5)
                    .repeatForever()
                    .delay(Double(index) * 0.2))
        }
    }
}

上述代码中,我们创建了一个新视图fourDotsLoading

我们使用HStack横向布局,使用ForEach循环遍历了4个圆点,使用scaleEffect修饰符跟随着isAnimation变量进行缩放。动画部分,我们让其间隔0.2秒不断循环。

最后,我们在ContentView中使用视图,并且在视图加载时切换isAnimation的状态,示例:

var body: some View {
    fourDotsLoading()
        .onAppear(){
            self.isAnimation.toggle()
        }
}

image.png

圆柱起伏

不错不错,下面我们再学习第二种loading动画,它有点像音乐起伏的效果,几个胶囊形状的圆角矩形不断缩放。

image.png

我们创建一个新的视图展示它,示例:

// 音乐起伏加载
func musicLoading() -> some View {
    HStack(alignment: .center, spacing: 5) {
        ForEach(0 ..< 5) { index in
            Capsule(style: .continuous)
                .fill(Color.green)
                .frame(width: 10, height: 50)
                .scaleEffect(isAnimation ? 0.5 : 1.0)
                .animation(Animation.easeInOut(duration: 0.5)
                    .repeatForever()
                    .delay(Double(index) * 0.1)
                )
        }
    }
}

上述代码中,我们创建了一个新视图musicLoading

我们使用HStack横向视图和ForEach循环遍历创建了5个Capsule胶囊视图,然后使用scaleEffect修饰符让它跟随isAnimation进行缩放。动画部分,同样是间隔0.1秒不断循环。

image.png

恭喜你,完成了本章的全部内容!

快来动手试试吧。


相关文章
egret微信小游戏自定义加载(loading)界面
egret微信小游戏自定义加载(loading)界面
egret微信小游戏自定义加载(loading)界面
PyQt5 图形界面 - Qt Designer创建qrc资源文件引用图片资源实例演示,QTextBrower组件引用图片资源方法展示
PyQt5 图形界面 - Qt Designer创建qrc资源文件引用图片资源实例演示,QTextBrower组件引用图片资源方法展示
385 0
PyQt5 图形界面 - Qt Designer创建qrc资源文件引用图片资源实例演示,QTextBrower组件引用图片资源方法展示
|
缓存 Swift iOS开发
iOS开发swift版异步加载网络图片(带缓存和缺省图片)
iOS开发swift版异步加载网络图片(带缓存和缺省图片)
436 0
|
计算机视觉 索引
NDK OpenGL ES 3.0 开发(二十一):3D 模型加载和渲染
3D 模型的设计一般是由许多小模型拼接组合成一个完整的大模型,一个小模型作为一个独立的渲染单元,我们称这些小模型为网格(Mesh)。
302 0
NDK OpenGL ES 3.0 开发(二十一):3D 模型加载和渲染
|
XML 程序员 C语言
Qt编写控件属性设计器1-加载插件
一、前言 加载插件是整个属性设计器的第一步要打通的功能,插件中的控件都加载不了,后面就别搞别玩下去了没法玩的,要从一个动态库中加载出来控件,肯定需要用到反射机制,以前做.NET开发的时候就觉得反射这个东西相当强大,居然可以读取DLL加载出来控件,现在用Qt,发现Qt也有反射机制,也许这东东可能各大.
1011 0
|
Web App开发 JavaScript 前端开发
混合开发(一)——WebView开发高级技巧之加载网页以及JavaScript,加载进度条
混合开发(一)——WebView开发高级技巧之加载网页以及JavaScript,加载进度条 现在关于混合开发也越来越多了,很多人喜欢跟随,比如HB,比如RN,其实这东西很早就有这么一个概念了,而且说实话,这方面的需求目前来讲,还是只针对一个别的应用的,不过日后会发展成...
1060 0