基于HTML5的PACS--HTML5图像处理

在此之前,此系统是结合DICOM的WADO标准,在浏览器里通过javascript操作返回的JPG图片。这种服务器端解析,客户端展现的方式,对实现图像的移动、缩放、旋转、测量等图像操作能够实现实时的交互。但这种方式存在着几个弊端:

1.获取图像上的CT值(钙化值)信息的时候,要频繁的和服务器进行交互。

2.调整图像的窗宽窗位或者对图像进行反色,也要和服务器进行频繁的交互。

3.对图像进行测量(长方形测量,椭圆测量等)只能获取到面值和周长的简单的信息,这对于医生的诊断没多大的用处,实际运用中需要知道所测量的区域的最大值、最小值、方差值、均值等测量信息。

以上的缺点归结为一点:即本地没有处理像素信息的操作。但是HTML5对于像素级处理的能力已经支持得很好,完成可以实现客户端对像素信息的操作。所以为了解决以上问题最近对系统做了一次比较大的升级。即客户端端直接操作DICOM的像素数据进行JS端图像的生成以及JS端实现窗宽窗位的调整。

获取dicom中的像素数据,可考虑以下两种方式:

A:服务器端直接以字节流的方式返回DICOM文件,客户端用JS来接收字节流,并负责解析DICOM中的图像数据,这种方式不仅要根据DICOM 的传输语法(0002,0010)Transfer Syntax UID,还要根据  (0028,0002)Samples per pixel、(0028,0004)Photometric Interpretation,(0028,0010)Rows,(0028,0011)Columns,(0028,0100)Bits Allocated,(0028,0103)Pixel Representation等标签来确定像素数据的结构,复杂点的可能还会用到查找表来查找((0028,0004)Photometric Interpretation的值等于==PALETTE COLOR)。对于非压缩的显示VR或者是隐形VR, (0028,0004)Photometric Interpretation等于MONOCHROME1或者MONOCHROME2来说JS解析出像素数据确实很方便,但是DICOM文件各式各样,要 写出包罗给种传输语法以及各种像素结构的JS文件确实很费劲。还要考虑到多帧动态图像,如果多针图像很大整个文件下载下来解析估计浏览器会彻底奔溃。所以 觉得这种方式不太可行。(虽然这过程中实现了显示VR的DICOM文件的JS解析,但是中途考虑到复杂性和难度还是放弃了)。

B:从服务器端获取DICOM文件的像素数组,既然目前基于C/S模式的PACS已经相当成熟,各式各样的第三方开源的dicom解析工具如 DCMTK,DCM4CHE,MDCM,OPENDICOM等也相当的多,用开源的DICOM解析工具获取到像素数据也相当的方便。所以在服务器获取到像 素数据返回给JS端,让JS端直接操作像素数据来生成要显示的图像。对于多帧图像也可以按需按帧的从服务器下载像素数据。

言归正传,目前此系统是基于第二种方式来实现。需要特别注意的是:做窗宽窗位调整的时候要先做Hounsfield 值的转换。

HU[i] = pixel_val[i]*rescaleSlope+ rescaleIntercept。窗宽窗位的调整使用了线性的window-leveling 算法针对CT/MR等图像,或者是非线性的gamma算法针对DX图像(即当windowWidth比较大的时候要考虑非线性的gamma算法,因为线性 算法中每windowWidth/255个原始密度会压缩成一个显示灰度,windowWidth很大的时候损失可能会很大)

//线性的window-leveling算法
min = (2*windowCenter - windowWidth)/2.0 - 0.5; 
max = (2*windowCenter + windowWidth)/2.0 - 0.5;
for (var i = 0; i != nNumPixels; i++){
    showPixelValue = (pixelHuValue[i] - min)*255.0/(double)(max - min);
}
//非线性的gamma算法
min = (2*windowCenter - windowWidth)/2.0 - 0.5; 
max = (2*windowCenter + windowWidth)/2.0 - 0.5;
for (var i = 0; i != nNumPixels; i++){
    showPixelValue = 255.0 * Math.pow(pixelHuValue/(max-min), 1.0/gamma);
}

如下代码展示JS端如何用后台获取到的像素数据生成图像。其中用到了查找表的概念。

/**
 * @author http://www.cnblogs.com/poxiao
 * pixelBuffer代表是从后台获取到的像素信息数组,代码只列出了单色灰度图像的情况,
 * 如果是三色的RGB图像自己稍微改动下代码即可。篇幅有限不在叙述。
 **/
var pixelBuffer;
//width 代表图像的宽度,即DICOM中的标签(0028,0011)Columns
var width;
//height 代表图像的高度,即DICOM中的标签(0028,0010)Rows
var height;
/**
 * @windowCenter 代表当前要显示的窗位
 * @windowWidth 代表当前要显示的窗宽
 * @bitsStored (0028,0101) 根据每个像素的存储位数生成查找表大小
 * @rescaleSlope (0028,1053)用于计算HU值
 * @rescaleIntercept  (0028,1052)用于计算HU值
 * **/
function createImageCanvas(windowCenter,windowWidth,bitsStored,rescaleSlope,rescaleIntercept){
    var lookupObject=new LookupTable();
    lookupObject.setData(windowCenter,windowWidth,bitsStored,rescaleSlope,rescaleIntercept);
    lookupObject.calculateHULookup();
    lookupObject.calculateLookup();
   
    var imageCanvas=document.createElement("canvas");
    imageCanvas.width = width;
    imageCanvas.height =height;
    imageCanvas.style.width = width;
    imageCanvas.style.height = height;
    var tmpCxt = imageCanvas.getContext("2d");
    var imageData = tmpCxt.getImageData(0,0,width,height);
    var n=0;
    for(var yPix=0; yPix<height; yPix++)
    {
        for(var xPix=0; xPix<width;xPix++)
        {
            var offset = (yPix * width + xPix) * 4;
            var pixelValue=lookupObject.lookup[pixelBuffer[n]];
            imageData.data[offset]=    pixelValue;
            imageData.data[offset+1]=pixelValue;
            imageData.data[offset+2]=pixelValue;
            imageData.data[offset+3]=255;
            n++;
        }
    }
    tmpCxt.putImageData(imageData, 0,0);
   
    return imageCanvas;
};
/**
 * 像素查找表,主要要先根据rescaleSlope和rescaleIntercept进行Hounsfield值的转换
 * HU[i] = pixel_val[i]*rescaleSlope+ rescaleIntercept
 */
function LookupTable()
{
    this.bitsStored;
    this.rescaleSlope;
    this.rescaleIntercept;
    this.windowCenter;
    this.windowWidth;
   
    this.huLookup;
    this.lookup;
}

LookupTable.prototype.setData=function(wc,ww,bs,rs,ri)
{   
    this.windowCenter=wc;
    this.windowWidth=ww;
    this.bitsStored=bs;
    this.rescaleSlope=rs;
    this.rescaleIntercept=ri;
};

LookupTable.prototype.setWindowingdata=function(wc,ww)
{
    this.windowCenter=wc;
    this.windowWidth=ww;
};

LookupTable.prototype.calculateHULookup=function()
{
    var size=1<<this.bitsStored;
    this.huLookup = new Array(size);
    for(var inputValue=0;inputValue<size;inputValue++)
    {
        if(this.rescaleSlope == undefined && this.rescaleIntercept == undefined) {
            this.huLookup[inputValue] = inputValue;
        } else {      
            this.huLookup[inputValue] = inputValue * this.rescaleSlope + this.rescaleIntercept;
        }
    }
};
/**
 * 窗宽窗位的调整线性的Window-leveling算法
 * 非线性的gamma算法,稍微修改下:
 *  var y=255.0 * Math.pow(this.huLookup[inputValue]/this.windowWidth, 1.0/gamma);
 * **/
LookupTable.prototype.calculateLookup=function()
{   
    var size=1<<this.bitsStored;
    var min=this.windowCenter-0.5-(this.windowWidth-1)/2;
    var max=this.windowCenter-0.5+(this.windowWidth-1)/2;
    this.lookup=new Array(size);
    for(var inputValue=0;inputValue<size;inputValue++)
    {
        if(this.huLookup[inputValue]<=min){
            this.lookup[inputValue]=0 ;
        }else if (this.huLookup[inputValue]>max){
            this.lookup[inputValue]=255;
        }else{               
            var y=((this.huLookup[inputValue]-(this.windowCenter-0.5))/(this.windowWidth-1)+0.5)*255;
            this.lookup[inputValue]= parseInt(y);
        }
    }
};

鼠标调整窗宽窗位的时候JS端生成图像+绘制图形的速度。

1.512 X 512大小的CT图像调整窗宽窗位速度

2.512 X 512大小的彩色CT图像调整窗宽窗位速度

3.512 x 512大小的MR图像调整窗宽窗位速度

4.2057 X 1347大小的CR图像调整窗宽窗位速度

5.有了像素信息后就可以在客户端实时的获取到CT值了。

6:有了像素信息后测量也可以获取到测量区域的最大值、最小值、方差值、均值等测量信息了

进测试,调整窗宽窗位时HTML5上绘制图形的时间还是很快的,总的绘制时间在10毫秒的数量级,而且发现绘制时间还可以变少,这绘制时间包括了图 像边角上的文字信息,但是HTML5绘制文字的信息效率明显比绘制图像的效率要底,所以不必每次刷新都绘制文本信息,可以加以参数控制在图像切换或者调窗 宽窗位的时候也就是文本信息变化的时候才绘制文字信息。关于图像的生成时间,发现图像的生成时间和图像的宽X高成正比,图像越大所需时间越长,对于 CT/MR等图像时间大概在几十个毫秒级。对于2057X1347的CR图像时间大概在400毫秒级,对于2000X3000多的DX图像生成图像的时间 就有点卡顿了,要1秒-2秒左右。。。这速度还得想办法优化有木有。。。。。还有对于DX图像调整窗宽窗位虽然使用了gamma算法,但是出来的图像,我 总感觉得没有用第三方工具比如RadiAnt上看见的光滑,噪声有点大。所以在没得到更好的解决方案前,目前DX的图像只能特殊化即保留原来的方式在服务 器端直接生成JPG让客户端直接绘制,希望会DICOM图像算法的大神们看到此文章后能给小弟我一点关于DX调窗宽窗位的意见,是不是还要用到别的算法啥的?。先谢谢了

时间: 2024-10-30 20:31:00

基于HTML5的PACS--HTML5图像处理的相关文章

应对非HTML5的IE浏览器准备着手基于FLEX的PACS

基于HTML5的PACS系统暂先告一段落,基本的图像浏览.图像操作.图像测量.JS本地调整窗宽窗位等功能已经实现.详情请参考博文: http://www.cnblogs.com/poxiao/p/3540688.html 基于HTML5的PACS不仅能很好的运行于google chrmoe浏览器.Mozilla Firefox浏览器,对android系统的手机.平板及iphone.ipad等苹果IOS系统也能够完美的支持.但是IE浏览器对HTML5的支持并不能够让人满意,只有IE10及以上版本对

HTML5学习总结——HTML5入门与新增标签

一.HTML5概要 1.1.为什么需要HTML5 概念: HTML5 是继 HTML4.01, XHTML 1.0 和 DOM 2 HTML 后的又一个重要版本, 旨在消除富 Internet 程序(RIA)对 Flash, Silverlight, JavaFX 一类浏览器插件的依赖. 1991年HTML1.0标准出现1997年HTML4.0发布,4.0标准下的浏览器局限性Flash (安全与稳定堪忧.耗电.触摸.不开放)SilverlightJavaApplet2008年HTML5出现, W

玩转html5(一)-----盘点html5新增的那些酷酷的input类型和属性

今天正式开始学习html5了,相比html以前的版本,html5新增了好多功能,属性,使我们做出来的界面更加的绚丽,而且使用起来超级简单,这篇文章先来说说html增加的那些input类型和属性. html5新增的input类型有:email,url,number,range,date pickers,datalist,telephone,search,color email:提交时会自动验证输入的内容是否满足格式 邮箱 :<input type="email" name=&quo

jqm视频播放器,html5视频播放器,html5音乐播放器,html5播放器,video开发demo,html5视频播放示例,html5手机视频播放器

最近在论坛中看到了很多实用html5开发视频播放,音乐播放的功能,大部分都在寻找答案.因此我就在这里做一个demo,供大家相互学习.html5开发越来越流行了,而对于视频这一块也是必不可少的一部分.如何让你的网站占据优势,就要看你的功能和用户体验了.html5对video还是做了很多优惠的东西,我们使用起来很得心应手. 在过去 flash 是网页上最好的解决视频的方法,截至到目前还算是主流,像那些优酷之类的视频网站.虾米那样的在线音乐网站,仍然使用 flash 来提供播放服务.但是这种状况将会随

HTML5 简介、HTML5 浏览器支持

HTML5是HTML最新的修订版本,2014年10月由万维网联盟(W3C)完成标准制定. HTML5的设计目的是为了在移动设备上支持多媒体. HTML5 简单易学. 什么是 HTML5? HTML5 是下一代 HTML 标准. HTML , HTML 4.01的上一个版本诞生于 1999 年.自从那以后,Web 世界已经经历了巨变. HTML5 仍处于完善之中.然而,大部分现代浏览器已经具备了某些 HTML5 支持. HTML5 是如何起步的? HTML5 是 W3C 与 WHATWG 合作的结

【html5】使用 html5 的十大原因

你难道还没有考虑使用 html5? 当然我猜想你可能有自己的原因:它现在还没有被广泛的支持,在 ie 中不好使,或者你就是喜欢写比较严格的 xhtml 代码.html5 是 web 开发世界的一次重大的改变,事实上不管你是否喜欢,它都是代表着未来趋势.其实 html5 并不难理解和使用.我们这里能列出许多原因为什么现在要开始使用 html5. 目前有很多的文章介绍使用 html5 并且介绍了使用它的优势和好处,没错,这篇文章也类似.随着更多这样的文章,以及 apple 的支持,adobe 围绕

windows平台下基于QT和OpenCV搭建图像处理平台

在之前的博客中,已经分别比较详细地阐述了"windows平台下基于VS和OpenCV"以及"Linux平台下基于QT和OpenCV"搭建图像处理框架,并且生成了相应的免费视频.这篇博客的主要内容,就是基于最新版本的相应工具,在windows平台下,"基于QT和OpenCV搭建图像处理平台",并且进一步研究如何基于QT所见即所得的便利,进行图像处理操作,最终还要和vs做一个比较,进行初步小结. 主要分为3个部分,一个是当前模式下,windows+Q

HTML5视频教程,HTML5项目实战,HTML5中文指南,HTML5使用手册

HTML5视频教程,HTML5项目实战,HTML5中文指南,HTML5使用手册. 超过2G 的 HTML5 视频教程免费分享,免费下载! 尚硅谷前端HTML5视频_HTML & CSS 核心基础教程(103集实战教学,从入门到精通) 本套视频适合零基础并且对前端知识感兴趣的同学.内容涵盖HTML基础.标签.CSS 选择器.盒子模型.浮动.定位.图片整合.PS 切图等页面相关常用技术. 视频最后包含一个实战项目:将一个 PSD 设计图转换为一个商业网站的首页.让同学们体验前端页面开发的全过程. 通

HTML5开发学习教程,学习HTML5还是学习HTML5的制作工具?

一名优秀的HTML5前端开发工程师在知识体系上既要有广度,又要有深度,所以很多大公司往往出高薪也很难招到理想的前端开发工程师.现在说的重点不在于讲解技术,而是更侧重于对技巧的讲解.技术非黑即白,只有对和错,而技巧则见仁见智. 以前会Photoshop和Dreamweaver就可以制作网页,现在只掌握这些已经远远不够了.无论是开发难度上,还是开发方式上,现在的网页制作都更接近传统的网站后台开发,所以现在不再叫网页制作,而是叫WEB前端开发. HTML5前端开发在产品开发环节中的作用变得越来越重要,

什么是HTML5,做HTML5页面需要学习什么

什么是HTML5,做HTML5页面需要学习什么?很多人问过我这个问题,而问这个问题的人基本上都是刚听说过HTML5,处在懵懂的阶段,他们往往会被一些网上炫酷页面所吸引,开始的目的也很简单,能通过自己的努力做出这些页面,而这些页面效果一般只要通过简单的html和css就能实现,但这仅仅是表面现象,做出来与做好是两码事.而要做好它,必须要深入地去了解什么是HTML5. 在这里小编建了一个前端学习交流扣扣群:132667127,我自己整理的最新的前端资料和高级开发教程,如果有想需要的,可以加群一起学习