推荐使用:Compose LazyList/Grid 重新排序库
在构建用户界面时,尤其是针对移动和桌面平台的 Android 应用程序,让用户体验流畅、直观的交互至关重要。Jetpack Compose 提供了一种声明式 UI 编程方式,使得实现此类功能变得更加轻松。今天,我们向您推荐一个开源项目——ComposeReorderable,它为您的 Jetpack Compose 应用带来了拖放重排的功能。
1、项目介绍
ComposeReorderable 是一个专为 Jetpack Compose 设计的库,它允许您在 LazyList 和 LazyGrid 中通过简单的拖放操作来重新排列元素。这个库提供了优雅的动画效果,并且支持 Android 和桌面平台,可以方便地集成到您的应用中,为用户提供更加自然的列表和网格管理体验。

2、项目技术分析
该项目的核心在于两个关键组件:rememberReorderableLazyListState 和 rememberReorderableLazyGridState,它们分别用于创建可重新排列的懒加载列表和网格状态。然后,通过添加 reorderable() 修改器到您的 LazyList 或 LazyGrid 上,启用拖放功能。ReorderableItem 用于包裹每个要重排的项,提供拖动状态以便进行视觉反馈,如阴影和缩放。
此外,detectReorderAfterLongPress 和 detectReorder 修饰符则用于触发重新排列行为,可以设置为长按或直接拖动启动。默认拖放行为也可通过 dragCancelledAnimation 和 defaultDraggingModifier 进行自定义。
3、项目及技术应用场景
- 购物清单:用户可以通过拖放修改物品顺序。
- 任务列表:调整任务优先级,高优先级任务放置在顶部。
- 相册应用:图片按照用户的意愿重新组织。
- 文件管理器:文件和文件夹的布局可以根据用户需求自由调整。
4、项目特点
- 跨平台:兼容 Android 和桌面环境。
- 易用性:简单集成,只需几个步骤即可启用拖放功能。
- 定制化:提供动画控制选项,可自定义拖放取消动画以及默认拖动修饰符。
- 性能优化:基于 Jetpack Compose 的懒加载特性,高效处理大量数据。
- 动态反馈:拖动过程中实时更新视觉效果,增强交互体验。
如何开始?
要在您的项目中使用 ComposeReorderable,请将以下依赖添加到你的构建文件:
dependencies {
implementation("org.burnoutcrew.composereorderable:reorderable:<latest_version>")
}
然后参照项目提供的示例代码,根据您的需求进行集成。
为了看到更多的使用场景和示例,您可以探索项目中的样本应用程序。
最后,值得注意的是,该库当前存在已知问题:第一项的动画显示可能不正常,但总体上,ComposeReorderable 已经成为一个非常实用的工具,能够显著提升您的应用的交互体验。
现在就加入 ComposeReorderable 的世界,让您的用户享受到更流畅、更具个性化的界面操作吧!
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0218
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0139
uni-appA cross-platform framework using Vue.jsJavaScript09
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03