Splitties

Splitties

Android和Kotlin多平台开发实用工具库集合

Splitties是一系列为Android和Kotlin多平台开发设计的小型实用库。它提供简洁API处理常见Android任务,如启动Activity、创建对话框和请求权限等。Splitties可减少样板代码,提升开发效率,让开发者更专注于核心逻辑。项目采用模块化设计,支持按需引入功能,有助于控制应用大小。

SplittiesKotlinAndroid多平台开源库Github开源项目

Splitties

Splitties 是一个小型 Kotlin 多平台库的集合(以 Android 为首要目标)。

这些库旨在减少你需要编写的代码量,节省代码阅读和编写时间,让你能更专注于为用户(即使只有你自己)构建想要的功能,或有更多时间来"玩乐"。

这个项目之所以命名为"Splitties",是因为它被拆分成小模块,作为独立的库分发,所以你可以只添加项目/模块中需要的部分,有助于减少用户设备需要下载和保存在有限存储空间中的最终二进制文件的大小(顺便说一下,一切资源都是有限的)。

一些面向 Android 的模块提供了类似 Anko 的功能。这里有 Splitties 与 Anko 的简短对比

每个模块都经过设计,具有小巧的体积和尽可能高的效率

一些示例

Splitties 的核心是简化你的代码。以下是一些示例:

Kotlin:

startActivity(Intent(this, DemoActivity::class.java))

使用 Splitties Activities 的 Kotlin:

start<DemoActivity>()

Kotlin:

Snackbar.make(root, R.string.refresh_successful, Snackbar.LENGTH_SHORT) .show()

使用 Splitties Snackbar 的 Kotlin:

root.snack(R.string.refresh_successful)

协程竞速:raceOf(…) 来自 协程模块

suspend fun awaitUserChoice(ui: SomeUi, choices: List<Stuff>): Stuff? = raceOf({ ui.awaitSomeUserAction(choices) }, { ui.awaitDismissal() null }, { ui.showSomethingInRealtimeUntilCancelled() // 返回 Nothing,会运行但永远不会"获胜"。 })

Kotlin:

Snackbar.make(root, getString(R.string.deleted_x_items, deletedCount), Snackbar.LENGTH_LONG) .setAction(android.R.string.cancel) { deleteOperation.requestRollback() } .setActionTextColor(ContextCompat.getColor(this, R.color.fancy_color)) .show()

使用 Splitties Snackbar 的 Kotlin:

root.longSnack(str(R.string.deleted_x_items, deletedCount)) { action(android.R.string.cancel, textColor = color(R.color.fancy_color)) { deleteOperation.requestRollback() } }

概览

系统交互(仅 Android):

用户输入和用户界面相关的拆分:

小型消息(仅 Android)

对话框(仅 Android)

系统 UI(仅 Android)

View 扩展(仅 Android)

  • Views: View 的扩展函数和属性。
  • Views AppCompat: Views 的 AppCompat 扩展。包括 ImageView 着色、ActionBar 和工具提示的辅助函数。
  • Views CardView: Views 的 CardView 扩展。提供 contentPadding 属性。
  • Views Material: Views 的 Material Components 扩展。
  • Views Coroutines Material: Material Components 与 Kotlin 协程结合。
  • Views RecyclerView: Views 的 RecyclerView 扩展。
  • Views Coroutines: Android Views 与 Kotlin 协程结合。

使用 Kotlin 的强大功能创建基于 View 的 UI(仅限 Android)

  • Views DSL: 使用易读的 Kotlin 代码创建 UI(支持 IDE 预览)。
  • Views DSL AppCompat: Views DSL 的 AppCompat 扩展。
  • Views DSL ConstraintLayout: Views DSL 的 ConstraintLayout 扩展。
  • Views DSL CoordinatorLayout: Views DSL 的 CoordinatorLayout 扩展。
  • Views DSL Material: Views DSL 的 Material Components 扩展。
  • Views DSL RecyclerView: Views DSL 的 RecyclerView 扩展。

各种 UI 实用工具(仅限 Android)

  • Resources: 轻松获取字符串、颜色或可绘制资源的扩展,支持主题属性。
  • Dimensions: Android dpViewContext 的扩展。在使用 Views DSL 时特别方便。
  • 可选择的视图
    • Selectable Views: 在 API 23 之前具有 foreground 属性的可选择视图。
    • Selectable Views AppCompat: 适用于 AppCompatTextView 的可选择视图。
    • Selectable Views ConstraintLayout: 适用于 ConstraintLayout 的可选择视图。
  • Typesafe RecyclerView: 类型安全的 ViewHolderItemViewHolder,便于 RecyclerView 的基本使用。

Material Design 辅助工具(仅限 Android)

  • Material Colors: 2014 年 Material Design 调色板作为颜色资源。
  • Material Lists: 实现 Material Design 指南的列表项视图(非常适合在 RecyclerView 中使用)。

应用内和跨应用通信:Activities、Fragments、Intents 和 Bundles

  • Activities: 以最少的样板代码启动活动。
  • Intents:companion object 转换为强大的类型安全 intent 规范,并以简洁易用的方式创建 PendingIntent
  • Fragments: 以最少的样板代码从片段启动活动并执行事务。
  • Fragment Args: 通过委托属性实现无需繁琐操作的片段参数。
  • Bundle: 使用 BundleSpec 通过属性语法为 Intent 附加信息等操作 Bundle

并发(多平台)

  • 协程: kotlinx.coroutines的通用扩展。
  • 生命周期协程(仅限Android): 与AndroidX Lifecycle 的协程集成。
  • 主线程: 与主线程相关的属性和前提条件检查器。
  • 主处理程序(仅限Android): 顶级 mainHandler 属性,用于停止为主 Looper 分配多个 Handler
  • 检查延迟(仅限Android): mainThreadLazy 在主线程上检查属性访问。

数据持久化(多平台)

  • 首选项: Android的 SharedPreferences/DataStore 和macOS/iOS/watchOS的 NSUserDefaults 的属性语法。
  • Arch Room: 用Kotlin实例化数据库和执行事务的Room辅助工具。

实用工具(多平台)

  • 位标志: LongIntShortByte 及其无符号对应项的 hasFlagwithFlagminusFlag 扩展。
  • 集合: 无需 Iterator 分配的 ListforEach

调试(仅限Android)

  • Stetho初始化: 在调试版本中使用 [Stetho],无需编写任何代码!

遗留(仅限Android)

  • 异常: unexpectedValue(…)unsupportedAction(…) 和类似的返回 Nothing 的函数。
  • Arch生命周期: 获取 ViewModel、使用 LiveData 和观察 Lifecycle 的扩展。

下载

Gradle说明

确保在项目的(根) build.gradle 文件中定义的仓库中包含 mavenCentral() (新的Android Studio项目默认包含)。

为了更容易利用Splitties的内容来开发Android项目,有一些组合构件包含了大多数的splits。

Android基础

使用 [refreshVersions] 添加:Splitties.pack.androidBaseSplitties.pack.androidBaseWithViewsDsl

这两个包不包含AppCompat,适用于WearOS应用。

包含以下模块: [activities]、[appctx]、[bitflags]、[bundle]、[collections]、[coroutines]、[dimensions]、[fragments]、[fragmentargs]、[intents]、[lifecycle-coroutines]、[mainhandler]、[mainthread]、[material-colors]、[permissions]、[preferences]、[resources]、[systemservices]、[toast]、[views]、[views-coroutines]、[views-recyclerview]、[views-selectable]、[views-selectable-constraintlayout]

Gradle依赖:

implementation("com.louiscad.splitties:splitties-fun-pack-android-base:3.0.0")

还有一个包含Views DSL的版本。它额外包含以下模块:

[views-dsl]、[views-dsl-constraintlayout]、[views-dsl-recyclerview]

Gradle依赖:

implementation("com.louiscad.splitties:splitties-fun-pack-android-base-with-views-dsl:3.0.0")

Android AppCompat

使用 refreshVersions 添加:Splitties.pack.appCompatSplitties.pack.appCompatWithViewsDsl

这两个包包含了 Android 基础 包和以下模块:

Gradle 依赖:

implementation("com.louiscad.splitties:splitties-fun-pack-android-appcompat:3.0.0")

还有一个带 Views DSL 的版本。它额外包含了 Android 基础包 的 Views DSL 版本和以下模块:

Gradle 依赖:

implementation("com.louiscad.splitties:splitties-fun-pack-android-appcompat-with-views-dsl:3.0.0")

Android Material Components

使用 refreshVersions 添加:Splitties.pack.androidMdcSplitties.pack.androidMdcWithViewsDsl

这两个包包含了 Android AppCompat 包和以下模块:

Gradle 依赖:

implementation("com.louiscad.splitties:splitties-fun-pack-android-material-components:3.0.0")

还有一个带 Views DSL 的版本。它额外包含了 Android AppCompat 包 的 Views DSL 版本和以下模块:

Gradle 依赖:

implementation("com.louiscad.splitties:splitties-fun-pack-android-material-components-with-views-dsl:3.0.0")

所有构件(47个)

由于您可能会使用多个构件,为了避免重复,我们建议您将版本放在一个集中的位置,这样升级到新版本时就不需要太多工作。

最好的方法是使用 refreshVersions,它为 Splitties 内置了依赖符号,还包括许多其他流行和高质量的库,如 kotlinx、AndroidX、Square/CashApp 的库和 Google 的库。

最重要的是,使用它运行 refreshVersions 任务可以在几秒钟内显示所有依赖项的可用更新,直接显示在 versions.properties 中,使升级变得轻而易举,甚至只需使用键盘即可完成。

供您参考,Splitties 的当前最新版本是 3.0.0

<details> <summary> <b>以下是此库所有构件的 Maven 坐标,供参考。(点击展开)</b> </summary> ``` com.louiscad.splitties:splitties-activities com.louiscad.splitties:splitties-alertdialog com.louiscad.splitties:splitties-alertdialog-appcompat com.louiscad.splitties:splitties-alertdialog-appcompat-coroutines com.louiscad.splitties:splitties-appctx com.louiscad.splitties:splitties-arch-lifecycle com.louiscad.splitties:splitties-arch-room com.louiscad.splitties:splitties-bitflags com.louiscad.splitties:splitties-bundle com.louiscad.splitties:splitties-checkedlazy com.louiscad.splitties:splitties-collections com.louiscad.splitties:splitties-coroutines com.louiscad.splitties:splitties-dimensions com.louiscad.splitties:splitties-exceptions com.louiscad.splitties:splitties-fragments com.louiscad.splitties:splitties-fragmentargs com.louiscad.splitties:splitties-intents com.louiscad.splitties:splitties-lifecycle-coroutines com.louiscad.splitties:splitties-mainhandler com.louiscad.splitties:splitties-mainthread com.louiscad.splitties:splitties-material-colors com.louiscad.splitties:splitties-material-lists com.louiscad.splitties:splitties-permissions com.louiscad.splitties:splitties-preferences com.louiscad.splitties:splitties-resources com.louiscad.splitties:splitties-snackbar com.louiscad.splitties:splitties-stetho-init com.louiscad.splitties:splitties-systemservices com.louiscad.splitties:splitties-toast com.louiscad.splitties:splitties-typesaferecyclerview com.louiscad.splitties:splitties-views com.louiscad.splitties:splitties-views-appcompat com.louiscad.splitties:splitties-views-cardview com.louiscad.splitties:splitties-views-coroutines com.louiscad.splitties:splitties-views-coroutines-material com.louiscad.splitties:splitties-views-dsl com.louiscad.splitties:splitties-views-dsl-appcompat com.louiscad.splitties:splitties-views-dsl-constraintlayout com.louiscad.splitties:splitties-views-dsl-coordinatorlayout com.louiscad.splitties:splitties-views-dsl-ide-preview com.louiscad.splitties:splitties-views-dsl-material com.louiscad.splitties:splitties-views-dsl-recyclerview com.louiscad.splitties:splitties-views-material com.louiscad.splitties:splitties-views-recyclerview com.louiscad.splitties:splitties-views-selectable com.louiscad.splitties:splitties-views-selectable-appcompat com.louiscad.splitties:splitties-views-selectable-constraintlayout ```

快照版本

假设你需要尝试一个尚未正式发布的新功能或修复:

你可以通过添加相应的仓库来获取快照版本,如下所示,并将库版本更改为最新的快照版本 3.0.0-SNAPSHOT:

allProjects { repositories { mavenCentral() google() // 在下面添加 sonatype 快照仓库 maven(url = "https://oss.sonatype.org/content/repositories/snapshots") } }

新版本通知

发布会在 GitHub 上公布,你可以通过点击"Watch",然后选择"Releases only"来订阅。

然而,如果你使用 refreshVersions,当你运行 refreshVersions 任务时,你也会在 versions.properties 文件中了解到更新信息。

改进这个库

如果你希望这个库在新模块或现有模块中有新功能或改进,请先开一个 issue 或对类似的 issue 进行投票/评论,以便讨论。

文档贡献也受欢迎。对于拼写错误或其他小改进,可以直接提交 PR(拉取请求)。对于更重要的文档贡献,请先开一个 issue 进行讨论。

如果你发现了 bug,请开一个 issue 并提供所有重要细节。如果你知道一个简单的修复方法,不会破坏 API 且不需要考虑副作用,你也可以直接提交 PR。

你还可以加入 Kotlin Slack 的 #splitties 频道参与讨论(你可以在这里获得邀请)。

什么是 split

"split"是 Splitties 库的一个模块,你可以将其添加为依赖项。它只包含所需的传递依赖。这允许你只在你的应用或库模块中添加所需的内容,使最终的 apk/ipa/app 尽可能小,不包含应用未使用的内容。

假设你正在使用 Views DSL 构建一个 Wear OS 应用。Wear OS 应用不需要 AppCompat。包含它会浪费带宽和存储空间。Views DSL 核心模块依赖于 Android SDK,但不依赖于 AppCompat,所以使用 Views DSL 不会使你的手表应用膨胀。然而,如果你正在构建手机、平板电脑或计算机 Android 应用,有一个 Views DSL AppCompat split 提供了一些扩展供你使用。

致谢 特别感谢 Jovche Mitrejchevski 在本项目决策过程中提供的帮助。

感谢 JetBrains 和贡献者们开发了 Anko,它是一个很好的灵感来源,特别是对于 Views DSL 而言。当然也要感谢优秀的 Kotlin 编程语言,使得这个项目成为可能。

感谢 Doug Stevenson 撰写的文章"Kotlin 和 Android:一次实际的实验"。可以说,Views DSL 的根源就在这个实验中。

许可证

本库在 Apache License 2.0 版本下发布,你可以在这里查看。

编辑推荐精选

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成AI工具AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机AI图像热门
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

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

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

下拉加载更多