手机适配

This commit is contained in:
pengxiaolong
2026-02-10 18:26:31 +08:00
parent 63415e1fde
commit d10524c597
262 changed files with 107341 additions and 32222 deletions

128
CLAUDE.md Normal file
View File

@@ -0,0 +1,128 @@
# CLAUDE.md
This file provides guidance to Claude Code (claude.ai/code) when working with code in this repository.
## 项目概述
Android 输入法应用IME包含自定义键盘和社交圈Circle功能模块。Kotlin 开发Jetpack Compose + XML 混合 UI。
- **包名**: `com.boshan.key.of.love`
- **命名空间**: `com.example.myapplication`
- **编译配置**: compileSdk 34, minSdk 21, targetSdk 34
## 构建命令
```bash
gradlew assembleDebug # 构建 Debug APK
gradlew assembleRelease # 构建 Release APK
gradlew installDebug # 安装到设备
gradlew clean # 清理
gradlew lint # Lint 检查
```
## 核心架构
### 应用入口流程
```
SplashActivity → GuideActivity/ImeGuideActivity → OnboardingActivity → MainActivity
```
### 键盘模块 (keyboard/)
**继承体系**
```
BaseKeyboard (抽象基类,提供震动、主题应用、递归设置文字颜色)
├── MainKeyboard (主键盘,拼音/英文输入)
├── AiKeyboard (AI 辅助键盘)
├── EmojiKeyboard (表情/颜文字键盘)
├── NumberKeyboard (数字键盘)
└── SymbolKeyboard (符号键盘)
```
**核心服务 `MyInputMethodService.kt`**
- 键盘懒加载 + 缓存机制(`ensureMainKeyboard()` 等)
- 智能联想流程:`commitKey()``updateCompletionsAndRender()` → 后台计算候选词 → `showCompletionSuggestions()`
- 特殊交互Emoji 按 Unicode 代码点删除、长按连删 + 上滑清空、回填功能
### 语言模型 (data/)
**N-gram 模型架构**`LanguageModel.kt` + `LanguageModelLoader.kt`
- 词表:`assets/vocab.txt`(每行一词,行号=词ID按频率降序
- Unigram`assets/uni_logp.bin`u16 分数数组0-1000越高越常用
- Bigram`assets/bi_rowptr.bin`[u32 offset, u16 length] + `bi_data.bin`[u32 next_id, u16 score]
- Trigram`assets/tri_ctx.bin`[u32 ctx1, u32 ctx2] + `tri_rowptr.bin` + `tri_data.bin`
**预测算法**3-gram → 2-gram → 1-gram 回退机制,结合用户点击学习排序
**Trie 优化**`Trie.kt`
- 每个节点记录 `maxFreq`(子树最高词频)
- 优先级队列遍历快速获取 top-K
- 用户点击权重 1000远超静态词频
### 网络层 (network/)
**双客户端架构**
- `RetrofitClient.kt`:常规 HTTP30s 超时)
- `NetworkClient.kt`SSE 流式响应(无超时,用于 AI 聊天)
**请求签名机制**`HttpInterceptors.kt`
1. 生成 timestamp + nonceUUID 前 16 位)
2. 合并参数appId + timestamp + nonce + query + body 扁平化)
3. 按 key 字典序拼接HMAC-SHA256 签名
4. 添加 HeaderX-App-Id, X-Timestamp, X-Nonce, X-Sign
**SSE 解析**`NetworkClient.kt`):支持 JSON 和纯文本 chunk自动识别 `[done]` 结束标记
**Token 过期处理**:响应拦截器检测 code=40102/40103 → 清除本地 token → `AuthEventBus.emit(TokenExpired)`
### 社交圈 Repository (ui/circle/)
**缓存策略**`CircleChatRepository.kt`
- 自适应 LRU 缓存大小(根据设备内存 32-120 页)
- 预加载当前页前后 N 页
- 防重加载机制(`inFlight``pageInFlight` HashSet
### 主题系统 (theme/)
- `ThemeManager.kt`:观察者模式通知主题变更
- 各键盘实现 `applyKeyBackgroundsForTheme()` 应用主题
- `ThemeDownloadWorker.kt`WorkManager 后台下载
### UI 模块 (ui/)
| 模块 | 说明 |
|------|------|
| `circle/` | 社交圈AI 角色聊天、评论系统 |
| `shop/` | 主题商店 |
| `mine/` | 个人中心 |
| `login/` | 登录注册 |
| `recharge/` | 充值 |
| `home/` | 首页 |
导航图:`res/navigation/circle_graph.xml`
## 关键配置
**build.gradle.kts**
```kotlin
androidResources {
noCompress += listOf("bin") // 禁止压缩 .bin允许 FileChannel 内存映射
}
```
**输入法配置**`res/xml/method.xml`
**网络安全**`res/xml/network_security_config.xml`
## 辅助脚本
```bash
python scripts/clean_vocab.py <输入文件> <输出文件> # 词表清洗(过滤无效词)
```
## 开发注意事项
- 输入法服务需用户在系统设置中手动启用
- 语言模型使用 `FileChannel.map()` 内存映射加载,修改 .bin 文件需重新生成
- 网络请求签名使用 Body 扁平化(支持嵌套 JSON 和数组)
- `NetworkClient.init(context)` 必须在使用 SSE 前调用(通常在 Application.onCreate
- 项目当前无单元测试配置