Circuit 0.26.0 版本发布:Compose 共享元素动画与状态管理革新
项目简介
Circuit 是一个由 Slack 团队开发的现代化 Android 应用框架,它结合了 Jetpack Compose 的声明式 UI 和 Redux 风格的状态管理,为构建复杂、可维护的 Android 应用提供了优雅的解决方案。该框架特别强调单向数据流和清晰的架构分层,使得状态管理变得可预测且易于测试。
核心更新亮点
1. 共享元素动画支持(实验性)
0.26.0 版本最引人注目的特性是新增了对 Compose 共享元素动画 API 的支持。这项功能允许开发者在屏幕过渡时创建流畅的共享元素动画效果,显著提升用户体验。
实现方式:
开发者现在可以通过简单的 SharedElementTransitionLayout 包装器来启用共享元素过渡效果:
CircuitCompositionLocals(circuit) {
SharedElementTransitionLayout {
NavigableCircuitContent(
navigator = navigator,
backStack = backStack,
)
}
}
这个布局组件会创建并提供 SharedElementTransitionScope,内部使用标准的 Compose 共享元素/边界动画。该功能同时支持 NavigableCircuitContent 和覆盖层(overlays)。
注意事项:
- 该 API 目前标记为实验性,未来可能随 Compose 底层 API 的变化而调整
- 提供了
PreviewSharedElementTransitionLayout用于 Compose 预览支持
2. 状态管理行为变更与增强
2.1 rememberRetained 行为调整
rememberRetained 的行为在 0.26.0 版本中进行了重要调整,使其更加符合直觉:
- 旧行为:有时会在组件重新添加时恢复值,取决于父级
RetainedStateRegistry是否被保存 - 新行为:与
remember和rememberSaveable保持一致,除非明确通过注册表保存和恢复,否则移除后重新添加的组件不会恢复其值
2.2 RetainedStateRegistry 改进
saveAll现在会返回保存的值RetainedStateRegistry.Entry.unregister现在返回布尔值表示是否实际移除了未保存的 valueProvidersaveAll和saveValue现在会在CanRetainChecker返回false时跳过存储子值
2.3 新增 RetainedStateHolder
类似于 SaveableStateHolder,新增的 RetainedStateHolder 为特定键维护单独的 RetainedStateRegistry 条目。这使得子树可以在被释放前保存其状态,后续重新组合时能够恢复状态。
典型使用场景(如标签页切换):
val retainedStateHolder = rememberRetainedStateHolder()
var currentTab by remember { mutableStateOf(TabA) }
retainedStateHolder.RetainedStateProvider(key = currentTab.name) {
when (currentTab) {
TabA -> TabAContent()
TabB -> TabBContent()
TabC -> TabCContent()
}
}
3. NavigableCircuitContent 实现改进
- 从为每条记录管理单独的
RetainedStateRegistry改为使用新的RetainedStateHolder - 修改
SaveableStateHolder释放已移除记录的保存状态
其他重要更新
-
依赖项升级:
- 编译目标提升至 Android SDK 35
- Compose Android BOM 更新至 2025.01.01
- androidx.annotation 升级至 1.9.1
- androidx.activity 升级至 1.10.0
- Compose Android 更新至 1.7.7
- Compose Multiplatform 更新至 1.7.3
- Kotlin 升级至 1.9.10
-
代码生成改进:
- 修复了类级别
@Inject注解导致代码生成失败的问题 - KSP 更新至 1.9.10-1.0.29
- Dagger 更新至 2.55
- KotlinPoet 更新至 2.0.0
- 修复了类级别
-
示例与文档:
- 更新了 Mosaic 示例并现代化了计数器示例以全面使用效果
- 修复了导航文档示例中的变量大小写问题
技术深度解析
共享元素动画的实现原理
Circuit 的共享元素动画实现建立在 Compose 的基础动画 API 之上,通过 SharedTransitionScope 和 SharedTransitionLayout 提供了更高层次的抽象。这种设计允许:
- 跨屏幕状态共享:在不同屏幕间共享元素的状态(如位置、大小)
- 协调动画:确保源屏幕和目标屏幕的动画同步进行
- 灵活配置:支持自定义动画曲线、持续时间和各种过渡效果
状态管理架构演进
0.26.0 版本的状态管理改进反映了 Circuit 团队对应用架构的深入思考:
- 明确的生命周期:
rememberRetained的行为变更使得状态恢复更加明确和可控 - 分层状态管理:
RetainedStateHolder的引入提供了更细粒度的状态控制能力 - 内存效率:自动释放不再需要的状态有助于减少内存占用
升级建议
对于现有项目升级到 0.26.0 版本,开发者应特别注意:
- 共享元素动画:虽然是实验性功能,但可以开始评估和测试,为未来稳定版做准备
rememberRetained行为变更:检查现有代码是否依赖旧行为,必要时进行调整- 依赖兼容性:确保项目其他依赖与新版本的编译目标兼容
结语
Circuit 0.26.0 版本通过引入共享元素动画支持和改进状态管理机制,进一步巩固了其作为现代化 Android 开发框架的地位。这些改进不仅提升了用户体验,也使开发者能够构建更加健壮和可维护的应用。特别是状态管理方面的增强,展示了 Circuit 团队对应用架构深刻理解的持续演进。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00