问题 - 目录名 gifs/ 与类名 AnimatedGif 长期描述 GIF, 但实际格式是 WebP 动画 (依赖 sketch-animated-webp, 文件后缀也是 .webp) - 名实不符持续误导阅读者, 也让 GIF 相关搜索返回错误结果 改动(仅重命名, 不改运行时行为) - core/src/main/assets/gifs/ → animations/ (git mv, 152 个 webp + AGENTS.md) - core/.../ui/AnimatedGif.kt → AnimatedWebp.kt, 函数 AnimatedGif() → AnimatedWebp() - Platform.kt:13 getWebpUri 路径 gifs/ → animations/ - BottomCard.kt:175 调用点 AnimatedGif( → AnimatedWebp( - CalendarMonthView.kt:583 注释同步 - scripts/profile.sh:228,1103 两处场景描述/trace 文档同步 - baseline-prof.txt: 19 处 AnimatedGifKt → AnimatedWebpKt (R8 类名) 注: lambda hash 可能需下次 updateBaselineProfile 重新生成校准, 当前不影响构建 验证 - grep 全仓库 (排除 build/AGENTS.md/baseline-prof) 无 AnimatedGif/ 残留 - ./gradlew :app:assembleDebug → BUILD SUCCESSFUL 备注 - WEBP_FILES = (1..152) 硬编码暂保留, 下一个提交替换为构建期 BuildConfig - AGENTS.md 文档校正留待 Task 6 统一处理
YaYa
纯 Android + Jetpack Compose 日历应用,支持农历/节气/节日、个人班次排期,提供月/周/年三种视图。
特性
- 流畅的视图切换 —— 月视图、周视图、年视图三种模式,拖拽手势驱动月↔周折叠,弹簧动画自动吸附
- 无限滑动分页 —— 基于
Int.MAX_VALUE的虚拟分页,前后无边界翻页 - 完整中式日历 —— 公历 + 农历 + 二十四节气 + 传统节日,ISO 8601 周起始(周一)
- 个人排班周期 —— 自定义工作/休息循环,与公共节假日独立
- Material 3 设计 —— 动态配色,深色模式
技术栈
- Kotlin 2.3 · Jetpack Compose · Material 3
kotlinx-datetime处理所有日期逻辑tyme4kt提供农历、节气与传统节日sketch渲染 GIF 动画- 双模块:
:core(UI + 逻辑) ·:app(薄壳)
构建
# Debug
./gradlew :app:assembleDebug # 构建 debug APK
./gradlew :app:installDebug # 安装 debug APK 到设备
# Release
./gradlew :app:assembleRelease # 构建 release APK
./gradlew :app:installBenchmark # 安装 benchmark(release + 可调试)APK
# 测试
./gradlew :core:testDebugUnitTest # 运行全部测试
./gradlew :core:testDebugUnitTest --tests "plus.rua.project.ui.CalendarUtilsTest" # 运行单个测试
# Baseline Profile(需要连接设备)
./gradlew :macrobenchmark:updateBaselineProfile # 一键生成 + 自动复制到 :core
./gradlew :macrobenchmark:connectedBenchmarkAndroidTest # 仅运行基准测试
# 性能 Profiling(需要连接设备)
./scripts/profile.sh # 默认 8 秒
./scripts/profile.sh 15 # 自定义时长
构建产物位于 app/build/outputs/apk/<variant>/ 目录。
线条小狗表情包来自 https://www.douban.com/group/topic/264788645/?_i=9181692phrDzjR,9241256phrDzjR
Description
Languages
Kotlin
77.3%
Shell
18.7%
PowerShell
4%