2026-05-07-18-42-53 优化可视化工具栏和构件ID联动

This commit is contained in:
2026-05-07 18:55:14 +08:00
parent 796619632b
commit 97edf35bd0
9 changed files with 393 additions and 155 deletions

View File

@@ -0,0 +1,79 @@
# 实现方案 - 2026-05-07-18-42-53
## 修改目标
1. 移除逆向工作区可视化工具栏底部 Metadata 信息块。
2. 将 DICOM 融合切片范围控制改为融合视角下方单滑条,滑条值表示展示到第几张切片。
3. 将整体位姿控制区统一命名为“模型位姿”,并保留现有位姿保存、选择、重置和调节能力。
4. 将构件 ID 从纯组件状态提升为后端项目状态字段,使项目库 3D 模型与逆向工作区可视化工具栏联动。
## 涉及路径
- `WebSite/src/components/ReverseWorkspace.tsx`
- `WebSite/src/components/ProjectLibrary.tsx`
- `WebSite/src/server.ts`
- `WebSite/src/types.ts`
- `工程分析/经验记录.md`
## 技术路线
### 构件 ID 联动
- 在后端项目数据中增加 `moduleStyles` 字段,存储每个 STL 文件的:
- `visible`
- `color`
- `opacity`
- `partId`
- 项目库与逆向工作区读取项目时都使用同一个 `project.moduleStyles` 初始化。
- 任一页面修改 ID、颜色、透明度、显示状态时通过 `PATCH /api/projects/:projectId/module-styles` 写回后端。
- 前端本地状态更新后同步调用 API保证跨页面和跨浏览器一致。
### 融合切片范围
- 保留后端接口需要的 `start/end` 参数。
- 前端只展示一个滑条 `sliceEnd`,内部固定 `start = 0``end = sliceEnd`
- 滑条放在影像与模型融合视角下方,便于操作与结果对应。
### 位姿模块整合
- 将工具栏内的“整体位姿”标题改为“模型位姿”。
- 保留模型显示、位姿保存/选择、旋转、平移、缩放与重置功能,但减少重复命名。
### UI 清理
- 删除可视化工具栏底部 Metadata 代码块。
## 数据流
1. 后端读取或重置项目时生成默认 `moduleStyles``partId` 默认从 1 到 N。
2. 项目库修改构件 ID 后调用 API 保存。
3. 逆向工作区加载项目时读取最新 `moduleStyles`
4. 逆向工作区修改构件 ID 后同样调用 API 保存。
5. 融合视角滑条变化后触发 `dicom-fusion-volume?start=0&end=<sliceEnd>` 重新加载体数据。
## 兼容性与回滚方案
- 对旧 `state.json` 做兼容:项目没有 `moduleStyles` 时由后端按 STL 列表自动补齐。
- 若新增 API 出现问题,前端仍可回退为本地状态,但 ID 联动会退化。
- 所有修改集中在项目状态、项目库与逆向工作区,回滚本次 commit 即可恢复。
## 预计文件变更
- `server.ts`:补齐项目 moduleStyles、增加更新 API。
- `types.ts`:补充项目 moduleStyles 类型。
- `ProjectLibrary.tsx`:读取/保存共享 moduleStyles。
- `ReverseWorkspace.tsx`:读取/保存共享 moduleStyles调整切片范围 UI删除 Metadata重命名位姿模块。
## 人工审核状态
用户已声明本次不需要二次人工确认,按默认执行确认规则直接执行。
## 执行记录
- 已新增共享构件样式数据 `moduleStyles`,包含 `visible/color/opacity/partId`
- 已新增 `PATCH /api/projects/:projectId/module-styles`,用于项目库与逆向工作区同步构件 ID、颜色、透明度、显示隐藏状态。
- 已将项目库和逆向工作区的构件 ID 读写改为同一后端项目状态。
- 已删除逆向工作区可视化工具栏下方 `Metadata` 信息块。
- 已将融合视角下方 DICOM 切片范围改为单一进度条,内部固定从第 1 张开始显示。
- 已将可视化工具栏中的“整体位姿”改为“模型位姿”,并合并位姿保存、选择和各项旋转/平移/缩放控制。
- 已同步将项目库 3D 模型中的“整体位姿”标题改为“模型位姿”。

View File

@@ -0,0 +1,46 @@
# 测试方案 - 2026-05-07-18-42-53
## 静态检查
- 执行 `npm run lint`,确认 TypeScript 类型检查通过。
- 执行 `npm run build`,确认生产构建通过。
## 单元或集成测试
- 使用现有 API 和页面构建流程做集成验证:
- `GET /api/projects` 返回项目数据且包含共享 `moduleStyles`
- `PATCH /api/projects/:projectId/module-styles` 可保存构件 ID。
- 重新读取项目后构件 ID 保持一致。
## 关键业务场景验证
1. 项目库 3D 模型构件层级修改 ID 后,进入逆向工作区可视化工具栏显示同一 ID。
2. 逆向工作区修改 ID 后,返回项目库 3D 模型显示同一 ID。
3. 可视化工具栏不再显示 Metadata。
4. 融合视角下方只有一个 DICOM 切片范围滑条,不再暴露起点/终点输入。
5. 位姿控制区域标题显示“模型位姿”。
## 医学影像数据相关边界验证
- 切片范围滑条最小值不小于 1最大值不超过 DICOM 总切片数。
- API 请求仍使用合理 `start/end`,避免空体数据。
- 构件 ID 限定为 `1~255`,防止与背景 `0` 冲突。
## 回归风险
- 共享 moduleStyles 可能影响已有颜色、透明度、显示隐藏控制。
- 融合体请求频繁变化可能导致加载状态更新较频繁。
## 人工审核状态
用户已声明本次不需要二次人工确认,按默认执行确认规则直接执行。
## 执行结果
- `npm run lint`:通过。
- `npm run build`:通过,仅保留 Vite 大 chunk 体积提醒。
- 重新部署:已通过 `tmux` 重启 `revoxelseg-dicom` 服务,运行在 `http://0.0.0.0:4000/`
- `curl -I http://127.0.0.1:4000/`:返回 `HTTP/1.1 200 OK`
- `GET /api/projects/head-ct-demo`:返回默认项目,包含 9 个 STL 构件的 `moduleStyles`
- `PATCH /api/projects/head-ct-demo/module-styles`:可修改构件 ID 和可见性。
- 构件 ID 边界:提交 `partId=0` 后服务端返回 `partId=1`,符合不可修改为 0 的约束。

View File

@@ -667,3 +667,21 @@ C. 解决问题方案
D. 后续如何避免问题
构件层级状态应作为统一结构在不同页面复用;任何新增构件字段都要检查初始化、单项更新、全局更新和默认 fallback 四条路径;逆向工作区的可视化控制应与项目库模型页保持一致,避免用户在两个页面学两套交互。
## 2026-05-07-18-42-53 构件 ID 跨页面联动
A. 具体问题
项目库 3D 模型和逆向工作区可视化工具栏都能修改构件 ID但两边原先分别维护本地状态无法保证 ID、显示隐藏、颜色和透明度一致。
B. 产生问题原因
构件样式属于项目级配置,但旧实现只保存在 React 组件 state 中,页面切换或不同浏览器访问时不会自动共享。
C. 解决问题方案
在项目数据中新增 `moduleStyles` 字段,并新增 `PATCH /api/projects/:projectId/module-styles` 接口。项目库和逆向工作区都读写同一后端状态,服务端统一补齐默认值并将 `partId` 限制在 `1~255`
D. 后续如何避免问题
凡是需要跨页面、跨浏览器一致的配置项,优先放入后端项目状态;前端可以保留本地 state 提升响应速度,但必须通过 API 持久化并从项目数据恢复。

View File

@@ -0,0 +1,43 @@
# 需求分析 - 2026-05-07-18-42-53
## 原始需求摘要
本次需要优化逆向工作区与项目库之间的可视化控制体验:
1. 删除可视化工具栏下方的 `Metadata` 信息块。
2. DICOM 切片范围不再使用起点/终点输入,改为影像与模型融合视角下方的一条进度条控制切片范围。
3. 将模型位姿模块与整体位姿整合,统一命名为“模型位姿”。
4. 项目库 3D 模型中的构件 ID 与可视化工具栏中的构件 ID 保持联动。
## 业务目标
- 让影像与模型融合视角更聚焦实际操作,减少无效信息。
- 降低 DICOM 切片范围操作复杂度,使用单进度条表达当前展示范围。
- 统一模型位姿概念,避免“模型位姿”和“整体位姿”并存造成理解负担。
- 保证同一项目的构件 ID 在项目库和逆向工作区中一致。
## 输入与输出
- 输入:用户在项目库或逆向工作区中修改构件 ID、切换切片范围、调整模型位姿。
- 输出:
- 可视化工具栏不再展示 Metadata。
- 融合视角下方展示 DICOM 切片范围滑条。
- 位姿控制区域统一显示为“模型位姿”。
- 项目库和可视化工具栏中的构件 ID 双向同步。
## 影响范围
- `WebSite/src/components/ReverseWorkspace.tsx`
- `WebSite/src/components/ProjectLibrary.tsx`
- 可能涉及后端项目状态 API 与类型定义,用于持久化或共享构件 ID。
- `工程分析/经验记录.md`
## 风险点
- 如果构件 ID 只保存在组件本地状态,项目库和逆向工作区可能仍不同步。
- 切片范围由两个输入改为一个滑条后,需要保持后端融合体数据请求仍有合理 `start/end`
- 位姿模块重命名和合并时需要避免破坏现有旋转、平移、缩放、保存位姿功能。
## 待确认问题
用户已明确本次需求分析、实现方案、测试方案、执行修改均不需要二次人工确认,因此按默认执行确认规则直接实施。