Files
ISISeg/工程分析/经验记录.md

6.0 KiB
Raw Blame History

经验记录

本文件用于记录每次执行中出现的关键问题和解决方案。

2026-05-18-17-40-02 Web 导丝分割系统第一版

1. pytest 无法导入本地 backend 包

A. 具体问题:执行 pytest -q 时,tests/test_api.pytests/test_segmentation.pyModuleNotFoundError: No module named 'backend'

B. 产生问题原因:项目是从空目录新建,尚未安装为 Python 包pytest 启动时没有稳定地把项目根目录放入 pythonpath

C. 解决问题方案:新增 pytest.ini,配置 pythonpath = .testpaths = tests

D. 后续如何避免问题:从零构建 Python 项目时同步添加 pytest 配置,或使用标准包管理配置声明测试路径。

2. scikit-image 0.26 参数变更警告

A. 具体问题:remove_small_objects 使用 min_size 时测试出现 FutureWarning。

B. 产生问题原因:当前环境的 scikit-image 版本将 min_size 标记为废弃参数,并引入 max_size 表达“移除小于等于该面积的对象”。

C. 解决问题方案:将 remove_small_objects(binary, min_size=...) 改为 remove_small_objects(binary, max_size=...)

D. 后续如何避免问题:固定依赖版本后仍要关注测试警告;图像处理库升级时优先查看函数签名和文档。

3. 融合模式首帧过分割

A. 具体问题:视频第 0 帧没有前帧,融合模式覆盖率一度达到约 22%,明显偏宽。

B. 产生问题原因:时序差分在无前帧时退化为 Hessian融合投票逻辑对无前帧使用了一票通过导致边缘形态学噪声被并入。

C. 解决问题方案:融合模式统一使用两票通过,低响应时才回退到一票;同时将边缘形态学改成暗线候选约束下的边缘检测。

D. 后续如何避免问题:视频算法要单独检查首帧、丢帧和单图退化路径;融合策略必须记录每个子方法的置信约束。

2026-05-18-17-55-29 运行确认与演示视频录制

1. Playwright 安装下载卡住

A. 具体问题:尝试安装 playwright==1.55.0 用于浏览器录屏时pip 长时间停留在大型 wheel 下载阶段,没有继续输出。

B. 产生问题原因Playwright 包体积较大,当前网络下载速度或连接稳定性不足;继续等待会影响本次“确保可运行”的收口。

C. 解决问题方案:终止该安装进程,改用系统已有 google-chrome --headless 截取首页,并使用当前已安装的 OpenCV 将真实页面截图和真实 API 分割结果合成为演示 mp4。

D. 后续如何避免问题:演示录制优先复用本机已有工具;只有确实需要完整浏览器交互录屏时,再单独安装 Playwright 并预留下载时间。

2026-05-18-19-06-50 网页端工作台增强

1. CSS 覆盖 hidden 导致初始预览控件显示

A. 具体问题Chrome headless 截图发现初始页面里本应隐藏的视频控件和图像预览同时显示,破坏首屏布局。

B. 产生问题原因CSS 中对 #videoPreview#imagePreview 设置了 display: block,其选择器优先级覆盖了浏览器对 hidden 属性的默认 display: none

C. 解决问题方案:在全局 CSS 中增加 [hidden] { display: none !important; },确保所有使用 hidden 的状态元素都能可靠隐藏。

D. 后续如何避免问题:前端页面涉及显隐状态时,必须用 headless 截图检查初始状态;如果自定义了 display 样式,需要显式保护 [hidden]

2026-05-18-19-19-36 加载样例控制台提示处理

1. favicon.ico 404 干扰问题判断

A. 具体问题:点击“加载样例”后,浏览器控制台出现 /favicon.ico 404同时还有 Unchecked runtime.lastError

B. 产生问题原因:项目没有提供 /favicon.ico,浏览器会默认请求该资源并记录 404runtime.lastError 更常见于浏览器扩展消息通道关闭,通常不是普通网页代码产生。

C. 解决问题方案:后端增加 /favicon.ico 响应,前端为“加载样例”增加明确的成功/失败状态提示和异常捕获。

D. 后续如何避免问题:网页端交付时补齐 favicon、状态提示和错误处理遇到 runtime.lastError 时优先用无痕模式或禁用扩展排查来源。

2026-05-18-19-31-18 原始媒体查看入口增强

1. 文件加载后的原始内容查看入口不够明确

A. 具体问题:用户加载样例或上传视频/图像后,希望在“预览与结果”区域明确查看原始视频,否则不容易确认当前已加载内容。

B. 产生问题原因:页面虽然已有内嵌预览区域,但缺少显式的“查看原始视频/图像”操作入口,大尺寸查看也不方便。

C. 解决问题方案:在“预览与结果”标题区新增按文件类型切换文案的按钮;加载视频时显示“查看原始视频”,加载图像时显示“查看原始图像”;点击后打开原始媒体弹窗。

D. 后续如何避免问题:输入数据、处理中结果、最终结果应分别提供清晰入口,尤其是医学影像类工具需要让用户随时核对原始输入。

2026-05-18-19-37-10 原始视频与结果同级分栏

1. 原始媒体入口层级不符合用户预期

A. 具体问题:用户希望“查看原始视频”和“预览与结果”是同一级,而不是把原始视频查看作为“预览与结果”标题区里的按钮。

B. 产生问题原因:上一版将原始媒体查看入口作为辅助操作放在结果区标题右侧,信息架构上仍然偏向“结果主导”,不符合用户希望的左右对照工作流。

C. 解决问题方案:将右侧工作区拆成左右两个 workspace-pane:左侧固定展示原始视频/图像,右侧展示分割进度、摘要和结果帧;保留“放大查看”作为左侧面板内的辅助操作。

D. 后续如何避免问题:医学影像交互页面应优先考虑“原始输入”和“算法输出”并列对照,而不是把原始输入藏在结果区域的附属操作中。