feat: 优化图标分页选择器与中文返回信息

This commit is contained in:
Hermes Bot
2026-04-20 13:34:28 +08:00
parent 2022c2d1c1
commit 96275e8028
3 changed files with 336 additions and 223 deletions

231
README.md
View File

@@ -1,6 +1,6 @@
# ShortX ToolHub
一个模块化的 ShortX JS 浮窗工具框架,支持广播关闭、子线程模型、日志记录、自动下载与热更新
一个模块化的 ShortX JS 浮窗工具框架,支持子模块自动下载、按 `Last-Modified` 热更新、启动日志记录,以及面向大图标库的分页式 ShortX 图标选择器
---
@@ -10,31 +10,32 @@
```
shortx.getShortXDir()/
├── ToolHub/
── code/
├── th_01_base.js
├── th_02_core.js
├── th_03_icon.js
├── th_04_theme.js
├── th_05_persistence.js
├── th_06_icon_parser.js
├── th_07_shortcut.js
├── th_08_content.js
├── th_09_animation.js
├── th_10_shell.js
├── th_11_action.js
├── th_12_rebuild.js
├── th_13_panel_ui.js
├── th_14_panels.js
├── th_15_extra.js
└── th_16_entry.js
└── ToolHub/logs/
└── init.log
── code/
├── th_01_base.js
├── th_02_core.js
├── th_03_icon.js
├── th_04_theme.js
├── th_05_persistence.js
├── th_06_icon_parser.js
├── th_07_shortcut.js
├── th_08_content.js
├── th_09_animation.js
├── th_10_shell.js
├── th_11_action.js
├── th_12_rebuild.js
├── th_13_panel_ui.js
├── th_14_panels.js
├── th_15_extra.js
└── th_16_entry.js
└── logs/
└── init.log
```
### 服务器(项目维护目录)
```
ToolHub/
├── ToolHub.js # 入口文件(粘贴到 ShortX 任务)
├── ToolHub.js
├── README.md
└── code/
├── th_01_base.js
├── th_02_core.js
@@ -58,135 +59,131 @@ ToolHub/
## 部署步骤
### 1. 创建目录(可省略)
### 1. 放置入口文件
`ToolHub.js` 内容粘贴到 ShortX 任务中。
入口文件会自动检测并创建 `ToolHub/code/` 目录,无需手动操作。
### 2. 直接运行
入口文件会自动:
1. 检查并创建 `ToolHub/code/`
2. 修复目录权限(`chmod 700` + `chown 1000:1000`
3. 对 16 个子模块做 HEAD 检测
4. 缺失或有更新时自动下载覆盖
5. 记录启动日志到 `ToolHub/logs/init.log`
若需手动创建,在 ShortX 数据根目录下执行:
```bash
mkdir -p ToolHub/code
chmod 700 ToolHub/code
chown 1000:1000 ToolHub/code
```
---
### 2. 放置入口文件
## 返回信息格式
`ToolHub.js` 的内容粘贴到 ShortX 任务中。
子模块会自动从 git 仓库下载到 `ToolHub/code/`,无需手动复制。
### 3. 运行
执行 ShortX 任务,正常返回示例:
成功启动示例:
```json
{
"ok": true,
"started": true,
"msg": "已按 WM 专属 HandlerThread 模型启动",
"msg": "ToolHub 启动成功:已按 WM 专属 HandlerThread 模型启动",
"syncMsg": "本次已覆盖更新 2 个子模块(新增 0 / 覆盖 2th_14_panels.js、th_16_entry.js",
"updatedCount": 2,
"updatedModules": ["th_14_panels.js", "th_16_entry.js"],
"closeAction": "shortx.wm.floatball.CLOSE",
"layout": {"cols": 2, "rows": 2}
}
```
---
## 自动下载与权限管理
入口文件启动时会自动完成以下操作:
1. **缺失自检**:检查 `ToolHub/code/` 下的 16 个模块文件,缺失则从 git raw URL 自动下载
2. **权限保障**:目录不存在时自动创建并设置 `chmod 700` + `chown 1000:1000`
3. **权限判断**:通过 `stat` 命令精确检查 uid/gid/mode不正确才修复
4. **单次检查**:一次启动中只检查一次目录权限,避免重复 shell 开销
---
## 版本管理与热更新
每个模块文件第一行必须包含版本注释:
```javascript
// @version 1.0.0
无子模块更新时:
```json
{
"ok": true,
"started": true,
"msg": "ToolHub 启动成功:已按 WM 专属 HandlerThread 模型启动",
"syncMsg": "子模块已是最新,本次未覆盖更新。",
"updatedCount": 0,
"updatedModules": [],
"closeAction": "shortx.wm.floatball.CLOSE",
"layout": {"cols": 2, "rows": 2}
}
```
入口文件中的 `MODULE_MANIFEST` 定义各模块的期望版本。启动时若本地版本与期望版本不匹配,自动重新下载。
如果有非关键模块加载失败,会额外返回:
- `loadMsg`
- `loadErrors`
升级模块时只需
1. 更新模块文件中的 `@version` 版本号
2. 同步更新 `ToolHub.js``MODULE_MANIFEST` 的对应版本号
3. 推送到 git 仓库
4. 实机下次启动时自动检测并更新
如果启动失败,会额外返回
- `err`
---
## 下载校验
## 子模块热更新机制
- **大小校验**:对比 HTTP `Content-Length` 与实际写入字节数,不匹配则抛异常
- **内容校验**:读取下载文件前 200 字节,检测 `<!DOCTYPE``<html`,防止下到 404/502 错误页面
当前机制不是版本号比对,而是:
- 对每个子模块发送 HTTP HEAD 请求
- 读取远端 `Last-Modified`
- 与本地 `.lm_模块名` 缓存比较
- 不一致则重新下载覆盖
- 网络检查失败时优先回退到本地已有文件
因此:
- **入口文件无需维护 `MODULE_MANIFEST`**
- 模块里的 `@version` 仅可作为人工注释,不参与程序判断
---
## ShortX 图标选择器优化
按钮编辑页里的 ShortX 图标选择器现已改为:
- **分页模式**,不再一次性塞入大批图标
- **一页显示多少个图标,就按当前 UI 实际可见容量自动计算 pageSize**
- 保留 **搜索 / 分类 / 上一页 / 下一页**
- 选中图标后自动回填并收起
- 收起后再次点击 **展开图标库** 可正常重新打开
当前交互要点:
1. 切到 `ShortX图标` 时自动展开图标库
2. 页容量按当前可见行数 × 4 列实时计算
3. 搜索、切分类、翻页时都会回到顶部,减少卡顿感和误触
---
## 日志系统
### 启动日志
路径:`shortx.getShortXDir() + "/ToolHub/logs/init.log"`
记录内容:
- 目录创建/权限修复
- 模块下载开始/结束/异常
- 版本不匹配
- 模块加载失败
- 模块体积超阈警告(>200KB
### 运行日志
路径:`shortx.getShortXDir() + "/ToolHub/logs/"`
日志文件按天分割,默认保留 3 天。
---
## 关闭浮窗
通过 adb 或 ShortX Shell 执行:
```bash
am broadcast -a shortx.wm.floatball.CLOSE
启动日志路径:
```text
shortx.getShortXDir() + "/ToolHub/logs/init.log"
```
---
## 模块说明
| 文件 | 职责 | 线数参考 |
|------|------|---------|
| `th_01_base.js` | 基础工具函数、Logger、崩溃处理、进程信息获取 | ~1300 |
| `th_02_core.js` | FloatBallAppWM 构造函数、基础工具方法dp/now/clamp | ~124 |
| `th_03_icon.js` | 图标缓存/LRU、悬浮球图标加载PNG 文件) | ~170 |
| `th_04_theme.js` | 屏幕/旋转、UI 样式辅助、莫奈动态取色、主题检测 | ~800 |
| `th_05_persistence.js` | 面板/位置/配置持久化、设置面板 schema 与编辑缓存 | ~298 |
| `th_06_icon_parser.js` | 快捷方式图标解析、resolveIconDrawable、图标文件路径 | ~485 |
| `th_07_shortcut.js` | 内置快捷方式选择器(合并 shortcuts.js、分组过滤 | ~1175 |
| `th_08_content.js` | ContentProvider URI 解析、通用 query、统一入口 | ~209 |
| `th_09_animation.js` | 动画/视图管理、吸边停靠、屏幕监控、重建悬浮球 | ~662 |
| `th_10_shell.js` | Shell 智能执行Action 优先 + 广播桥兜底) | ~33 |
| `th_11_action.js` | 按钮动作执行(点击/长按/双击) | ~320 |
| `th_12_rebuild.js` | 改大小后安全重建悬浮球 | ~76 |
| `th_13_panel_ui.js` | 设置面板 UI 组件SectionHeader、SettingItemView 等) | ~375 |
| `th_14_panels.js` | 面板配置工厂、按钮构建器、对话框、文本查看器 | ~2957 |
| `th_15_extra.js` | 额外面板:设备信息、网络状态、快捷操作 | ~1598 |
| `th_16_entry.js` | 入口面板定义、广播接收器注册、启动流程 | ~324 |
记录内容包括:
- 目录创建 / 权限修复
- 更新检测
- 下载开始 / 结束 / 异常
- 模块加载失败
- 模块体积告警(>200KB
---
## 模块加载容错
## 模块职责
- `for` 循环加载 16 个模块,单模块失败记录日志但不阻断后续加载
- `th_16_entry.js` 失败时直接抛异常(启动必备)
- 错误信息落盘到 `ToolHub/logs/init.log`,便于实机排查
| 文件 | 职责 |
|------|------|
| `th_01_base.js` | 基础工具、日志、配置校验、通用辅助 |
| `th_02_core.js` | `FloatBallAppWM` 构造、基础状态与核心工具 |
| `th_03_icon.js` | 图标缓存、Bitmap 管理、悬浮球图标加载 |
| `th_04_theme.js` | 主题、颜色、样式工具 |
| `th_05_persistence.js` | 持久化与设置数据层 |
| `th_06_icon_parser.js` | 图标解析、ShortX 内置图标扫描与回退 |
| `th_07_shortcut.js` | 快捷方式选择器 |
| `th_08_content.js` | ContentProvider 读取与通用 query |
| `th_09_animation.js` | 面板动画、吸边、显示/隐藏管理 |
| `th_10_shell.js` | Shell 执行层 |
| `th_11_action.js` | 按钮动作分发与执行 |
| `th_12_rebuild.js` | 悬浮球重建逻辑 |
| `th_13_panel_ui.js` | 设置面板通用 UI 组件 |
| `th_14_panels.js` | 设置面板、按钮编辑器、ShortX 图标分页选择器 |
| `th_15_extra.js` | 主面板与附加展示层 |
| `th_16_entry.js` | 生命周期、广播注册、启动与销毁 |
---
## 注意事项
- 入口文件通过 `loadScript()` 动态加载子模块,`var` 声明通过间接 `eval` 挂到全局作用域
- 子模块加载顺序不可更改base → core → icon → theme → persistence → icon_parser → shortcut → content → animation → shell → action → rebuild → panel_ui → panels → extra → entry
- 调试请查看日志文件,不通过返回 JSON 暴露内部细节
- 单个模块建议不超过 200KB超过时启动日志会记录 WARN 提示拆分
- 入口文件只负责加载与汇总返回信息,不承载业务 UI
- `th_16_entry.js` 属于关键模块,加载失败会直接中止启动
- 不建议把调试细节直接塞进返回 JSON优先写日志返回信息只保留用户判断启动/更新所需的关键信息
- 若修改了模块结构、返回字段、图标选择器交互,记得同步更新 README 与相关技能说明