Project Icon

SkeletonUI

简洁高效的SwiftUI骨架屏动画库

SkeletonUI是一款专为SwiftUI设计的骨架屏动画库,支持iOS、tvOS、watchOS和macOS多平台。通过简洁的声明式语法,开发者可轻松创建自定义骨架加载动画,有效替代传统加载页面或旋转器。这个轻量级库具备高度可定制性和易用性,有助于快速实现流畅的加载效果,从而提升应用的用户体验。

SkeletonUI 旨在为骨架加载动画带来优雅的声明式语法。摆脱加载屏幕或旋转器,开始使用骨架来表示最终内容形状。

要求 :gear:

  • macOS 10.15
  • Xcode 11.0
  • Swift 5.0

支持的平台 :iphone:

  • iOS 13.0
  • tvOS 13.0
  • watchOS 6.0
  • macOS 10.15

安装 :computer:

Swift Package Manager

Swift Package Manager 是一个用于自动化分发 Swift 代码的工具,集成在 swift 编译器中。一旦设置好 Swift 包,将 SkeletonUI 添加为依赖项就像在 Package.swiftdependencies 值中添加它一样简单。

  dependencies: [
  .package(url: "https://github.com/CSolanaM/SkeletonUI.git", .branch("master"))
  ]

CocoaPods

CocoaPods 是 Cocoa 项目的集中依赖管理器。有关使用和安装说明,请访问他们的网站。要使用 CocoaPods 将 SkeletonUI 集成到你的 Xcode 项目中,请在 Podfile 中指定它:

pod 'SkeletonUI'

特性 :sparkles:

  • SwiftUI 简单、声明式语法
  • 极其简单易用
  • 所有视图都可以使用骨架
  • 完全可定制
  • 通用(iPhone、iPad、iPod、Apple TV、Apple Watch、Mac)
  • SwiftUI ViewModifier 的强大功能
  • 轻量级代码库

用法 :rocket:

基本一行代码:

import SkeletonUI
import SwiftUI

struct UsersView: View {
    @State var users = [String]()

    var body: some View {
        Text("已完成请求 \(users.count) 个用户!")
            .skeleton(with: users.isEmpty)
            .onAppear {
                DispatchQueue.main.asyncAfter(deadline: .now() + 5) {
                    self.users = ["John Doe", "Jane Doe", "James Doe", "Judy Doe"]
                }
        }
    }
}

高级自定义:

import SkeletonUI
import SwiftUI

struct User: Identifiable {
    let id = UUID()
    let name: String
}

struct UsersView: View {
    @State var users = [User]()

    var body: some View {
        SkeletonList(with: users, quantity: 6) { loading, user in
            Text(user?.name)
                .skeleton(with: loading,
                          animation: .pulse(),
                          appearance: .solid(color: .red, background: .blue),
                          shape: .rectangle,
                          lines: 3,
                          scales: [1: 0.5])
        }
        .onAppear {
            DispatchQueue.main.asyncAfter(deadline: .now() + 5) {
                self.users = [User(name: "John Doe"),
                              User(name: "Jane Doe"),
                              User(name: "James Doe"),
                              User(name: "Judy Doe")]
            }
        }
    }
}

更新日志 :calendar:

详情请查看 CHANGELOG.md

贡献 :tada:

  • 将你的想法作为功能请求提出。
  • 创建错误报告以帮助我们改进。
  • 提出你自己的修复、建议并提交带有更改的拉取请求。

详情请查看 CONTRIBUTING.md

行为准则 :speech_balloon:

详情请查看 CODE_OF_CONDUCT.md

致谢 :speak_no_evil:

SkeletonUI 由 CSolanaM 拥有和维护。你可以在 Twitter 上关注我 @CSolanaM,或通过电子邮件联系我,了解项目更新和发布。

许可证 :mortar_board:

SkeletonUI 基于 MIT 许可证发布。详情请查看 LICENSE

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号