cornerstone.js 中PT图像自己计算窗宽窗位

背景:做petct过程中,前端的PT图像可以正常显示窗框窗位,后端要做截图时不能正确显示窗宽窗位。

解决思路:前端可以正常显示是因为 cornerstone.js 的源码里有算法做过处理,可以参考源码算法。

computeAutoVoi.js 中的源码贴出来记录一下:

javascript 复制代码
/**
 * Computes the VOI to display all the pixels if no VOI LUT data (Window Width/Window Center or voiLUT) exists on the viewport object.
 *
 * @param {Viewport} viewport - Object containing the viewport properties
 * @param {Object} image An Image loaded by a Cornerstone Image Loader
 * @returns {void}
 * @memberof Internal
 */
export default function computeAutoVoi (viewport, image) {
  if (hasVoi(viewport)) {
    return;
  }

  const maxVoi = image.maxPixelValue * image.slope + image.intercept;
  const minVoi = image.minPixelValue * image.slope + image.intercept;
  const ww = maxVoi - minVoi;
  const wc = (maxVoi + minVoi) / 2;

  if (viewport.voi === undefined) {
    viewport.voi = {
      windowWidth: ww,
      windowCenter: wc
    };
  } else {
    viewport.voi.windowWidth = ww;
    viewport.voi.windowCenter = wc;
  }
}

核心代码就是:

javascript 复制代码
  // 从图像的dicom标签中可以拿到图像最大像素值/最小像素值*图像斜率+图像的截距
  const maxVoi = image.maxPixelValue * image.slope + image.intercept;
  const minVoi = image.minPixelValue * image.slope + image.intercept;

  // 窗宽
  const ww = maxVoi - minVoi;
  // 窗位
  const wc = (maxVoi + minVoi) / 2;
相关推荐
小兵张健5 小时前
开源 playwright-pool 会话池来了
前端·javascript·github
codingWhat9 小时前
介绍一个手势识别库——AlloyFinger
前端·javascript·vue.js
Lee川9 小时前
深度拆解:基于面向对象思维的“就地编辑”组件全模块解析
javascript·架构
进击的尘埃9 小时前
Web Worker 与 OffscreenCanvas:把主线程从重活里解放出来
javascript
codingWhat9 小时前
手撸一个「能打」的 React Table 组件
前端·javascript·react.js
进击的尘埃9 小时前
用 TypeScript 的 infer 搓一个类型安全的深层路径访问工具
javascript
yuki_uix9 小时前
Object.entries:优雅处理 Object 的瑞士军刀
前端·javascript
Lee川9 小时前
JavaScript 面向对象编程全景指南:从原始字面量到原型链的终极进化
javascript·面试
Neptune113 小时前
JavaScript回归基本功之---类型判断--typeof篇
前端·javascript·面试
进击的尘埃14 小时前
微前端沙箱隔离:qiankun 和 wujie 到底在争什么
javascript