4.1 KiB
4.1 KiB
实现方案 - 2026-05-08-01-53-07
修改目标
- 固定融合视角的 DICOM 物理尺寸基准,使切片范围变化不改变模型原始位置。
- DICOM 切片范围默认显示到最高切片,并支持
M-N双向范围选择。 - 优化逆向工作区布局,浏览器放大后可滚动访问 DICOM 切片范围。
- 项目库项目加载/导入后后台预加载 DICOM 与模型预览。
- 模型切分开启后,在 DICOM 切割帧上叠加 Mask 轮廓/填充,直观看到切割位置。
涉及路径
WebSite/src/components/ProjectLibrary.tsxWebSite/src/components/ReverseWorkspace.tsxWebSite/server.ts工程分析/经验记录.md
技术路线
固定 DICOM 体基准
- 后端
dicom-fusion-volume的physicalSize.depth改为完整 DICOM 序列深度,而不是当前start/end范围深度。 - 前端 FusionThreeView 使用完整物理尺寸计算 DICOM box 和模型缩放,范围变化只改变参与显示的帧,不改变空间基准。
- 模型 pivot 保持 DICOM 中心,不根据切片范围重新定位。
双向范围滑条
- 恢复
sliceStart与sliceEnd两个状态,但 UI 使用同一范围卡片表达。 - 初始值设为
sliceStart=maxSlice、sliceEnd=maxSlice,即默认最高切片。 - 请求接口前将
min(sliceStart,sliceEnd)和max(sliceStart,sliceEnd)作为真实M-N。 - UI 显示
M-N / total,并提供两个滑条在同一区域控制左右端点。
放大布局
- 逆向工作区根容器允许纵向滚动。
- 主三列区域保留内部滚动,左侧融合区域不因高度压缩导致 DICOM 范围卡片不可达。
后台预加载
- 项目库加载项目列表后,对默认/选中项目发起低成本预加载:
- DICOM 预览中间帧。
- 前几个 STL preview。
- 融合体最高切片。
- 使用
void异步调用,不阻塞 UI。
切割 Mask 叠加
- FusionThreeView 中当
cutEnabled时,根据当前切割帧创建 DICOM texture overlay。 - 在切割帧平面上叠加半透明橙色 Mask 区域和边界线,表示模型切割位置。
- 该 Mask 是可视化辅助层,不改变模型、不写出 NIfTI。
数据流或交互流程
- 进入逆向工作区读取项目,计算
maxSlice=dicomCount-1。 - 初始范围设为
maxSlice-maxSlice。 - 用户拖动双向范围控制,前端排序后请求
dicom-fusion-volume?start=M&end=N。 - 后端返回当前范围帧,但 physical depth 始终以完整 DICOM 序列计算。
- FusionThreeView 使用固定 DICOM box 渲染 DICOM 与模型,模型位姿不受范围变化影响。
- 启用模型切分后,在切割帧平面叠加 Mask 预览。
兼容性与回滚方案
- 对任意 DICOM 总数使用
dicomCount和接口返回total,不硬编码 300。 - 若项目没有 DICOM 或 STL,预加载自动跳过。
- 回滚本次 commit 可恢复旧的单端点切片范围与切割显示。
预计文件变更
server.ts:修正融合体 physical depth 基准。ProjectLibrary.tsx:新增项目后台预加载。ReverseWorkspace.tsx:双向范围、布局滚动、固定模型空间、切割 Mask 叠加。
人工审核状态
用户已声明本次不需要二次人工确认,按默认执行确认规则直接执行。
执行记录
- 已将后端
dicom-fusion-volume的physicalSize.depth改为完整 DICOM 序列深度,避免切片范围变化导致 DICOM 体和模型空间重新缩放。 - 已将融合视图中每张 DICOM 帧的 Z 位置改为按真实
volume.indices映射到完整 DICOM 深度,范围变化只增减显示帧,不重新铺满空间。 - 已将逆向工作区 DICOM 切片范围改为双端点控制,支持
M-N显示范围。 - 已将默认切片范围初始化为最高切片
maxSlice-maxSlice,不硬编码 300。 - 已让逆向工作区根容器支持纵向滚动,浏览器放大时仍可滚动访问 DICOM 切片范围。
- 已在项目库中加入项目后台预加载:最高 DICOM 预览、最高融合体、前三个 STL 预览。
- 已在模型切分开启时,在切割 DICOM 帧上叠加橙色 Mask 预览和边界标记,使用户能直接在 DICOM 上看到切割位置。