加载中,加载中......使用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

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

快来动手试试吧。


相关文章
|
Swift iOS开发 Perl
如何解决Swift混编的module编译错误
前言很多iOS工程都是基于Object-C开发,再逐步向Swift演进,演进过程中不可避免要进行Swift混编。Swift模块需要支持LLVM Module规范,混编工程会遇到各种Module编译错误。这对于不熟悉的同学来说简直是灾难,严重影响开发效率。本文会介绍常见的Module编译错误,希望对大家有所帮助。常见错误1:Could not build module xxx当一个OC模块引用了Sw
8182 1
如何解决Swift混编的module编译错误
|
3月前
|
存储 人工智能 弹性计算
2026年阿里云新用户专享活动规则及v新功能汇总参考
阿里云新用户专享活动核心围绕“低价套餐+叠加优惠”展开,规则聚焦身份定义、限购续费、叠加限制三大核心;2026年新功能则重点发力AI融合、存储优化、数据库智能运维等领域,覆盖多模态处理、高效检索、智能决策等场景。以下是详细解读,均基于2026年官方最新政策与发布信息。
612 15
|
程序员 索引
SwiftUI极简教程18:SwipeCard卡片滑动效果的使用(上)
SwiftUI极简教程18:SwipeCard卡片滑动效果的使用(上)
1568 0
SwiftUI极简教程18:SwipeCard卡片滑动效果的使用(上)
|
11月前
|
XML 搜索推荐 Android开发
Android改变进度条控件progressbar的样式(根据源码修改)
本文介绍了如何基于Android源码自定义ProgressBar样式。首先分析了系统源码中ProgressBar样式的定义,发现其依赖一张旋转图片实现动画效果。接着分两步指导开发者实现自定义:1) 模仿源码创建一个旋转动画XML文件(放置在drawable文件夹),修改图片为自定义样式;2) 在UI控件中通过`indeterminateDrawable`属性应用该动画。最终实现简单且个性化的ProgressBar效果,附带效果图展示。
657 2
|
安全 iOS开发
iOS页面布局:UIScrollView的布局问题
iOS页面布局:UIScrollView的布局问题
739 63
|
iOS开发
iOS 启动图设置及icon图标设置
OS 启动图设置及icon图标设置
1221 0
iOS 启动图设置及icon图标设置
|
移动开发 Android开发 iOS开发
ios标准页面调用HTML5页面和HTML5调用ios的函数
ios标准页面调用HTML5页面和HTML5调用ios的函数
436 0
|
Swift 容器
swift水平组合(HStack)
swift水平组合(HStack)
517 1
|
Web App开发 编解码 API
WebRTC简介及使用
WebRTC简介及使用
1149 0
|
存储 大数据 API
swift 中 Realm 使用详解
当涉及到在 Swift 项目中进行本地数据库存储时,Realm 是一个强大且易用的解决方案。它提供了高性能、跨平台的数据库引擎,能够轻松地处理数据持久化和查询操作。本篇博客将介绍 Realm 的基本使用方法,以及一些需要注意的事项,从而能更好地利用 Realm 来管理本地数据。
1410 0

热门文章

最新文章

下一篇
开通oss服务