博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
DCMTK开源库的学习笔记1:将DCM文件保存成BMP文件或数据流(即数组)
阅读量:6872 次
发布时间:2019-06-26

本文共 2468 字,大约阅读时间需要 8 分钟。

hot3.png

DCMTK开源库介绍:

        DCMTK是目前最全面实现DICOM3.0标准的开源库,通过结合DCMTK开源库和CxImage图像开源库,能够很方便的开发属于自己的DCM文件编辑浏览软件。

DCMTK与CxImage的结合:

        下面记录”DCM文件到BMP文件格式的转换“的学习和探索的过程。

         1)BMP文件的格式这里不细讲(可自行参阅MSDN相关资料)。BMP属于设备无关图(DIB),内存中只要依次包含BMP文件头(BITMAPFILEHEADER)、BMP信息头(BITMAPINFOHEADER)、调色板(Palette),以及真实像素信息,就可以在所有显示设备中进行显示。因此将DCM文件转换到BMP格式的主要工作是:从DCM众多数据元中挑选出BMP文件头、信息头所必须的信息(如图像宽度、图像高度、每个像素所占的空间、像素数据等)。

         2)此次采用了dcmtk中的dcmimgle开发包,利用DicomImage类提供的createWindowsDIB接口以及writeBMP来进行格式转化。具体代码如下:

DcmFileFormat *mImage=new DcmFileFormat();	DJDecoderRegistration::registerCodecs(); // register JPEG codecs	DcmDataset *dataset = mImage->getDataset();	E_TransferSyntax xfer=dataset->getOriginalXfer();	dataset->chooseRepresentation(EXS_LittleEndianExplicit,NULL);	DicomImage *pdcmImage=new DicomImage((DcmFileFormat*)mImage,EXS_LittleEndianExplicit,CIF_AcrNemaCompatibility,0,1);	if(pdcmImage->getStatus()!=EIS_Normal)		exit(0);	void* pDIB=NULL;	int size=0;	pdcmImage->createWindowsDIB(pDIB,size,0,8,1,1);

        至此,pDIB内存中就获得了”c:\test.dcm“文件像素数据多对应的BMP格式的数据。如果想将pDIB保存成BMP文件,还需要补充BMP文件头(BITMAPFILEHEADER)、BMP信息头(BITMAPINFOHEADER)、调色板(Palette)。参照MSDN中BITMAPFILEHEADER和BITMAPINFOHEADER的结构,逐个成员赋值即可。假设我们生成的文件头变量为mBmpFileHeader,信息头变量为mBmpInfoHeader。由于createWindowsDIB函数中的BMP像素位数设定的是8,所以BMP图像属于索引图像,其文件中需要调色板,调色板的生成如下所示(最简单的生成方法):

RGBQUAD* mPalette=new RGBQUAD[256];	memset(mPalette,0,sizeof(RGBQUAD)*256);	for(int i=0;i<256;++i)	{		mPalette[i].rgbBlue=i;		mPalette[i].rgbGreen=i;		mPalette[i].rgbRed=i;	}

        随后将mBmpFileHeader、mBmpInfoHeader、mPalette添加到pDIB的前面,就构成了一幅BMP图像,直接将此数据保存成bmp文件即可。具体的链接步骤如下:

	int imgsize=width*height;	int headsize=sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER)+sizeof(RGBQUAD)*256;	int size=headsize+imgsize;	BYTE* mDibImage=new BYTE[size];	memset(mDibImage,0,size);	memcpy(mDibImage,mBmpFileHeader,sizeof(BITMAPFILEHEADER));	memcpy(&mDibImage[sizeof(BITMAPFILEHEADER)],mBmpInfoHeader,sizeof(BITMAPINFOHEADER));	memcpy(&mDibImage[sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER)],mPalette,sizeof(RGBQUAD)*256);	memcpy(&mDibImage[headsize],pDIB,imgsize);
 

       至此mDibImage内存存储的数据就是一幅完整的BMP文件。将其保存后的结果如下图(左)所示:

       相比dcm浏览软件中看到的结果(上图右),自己生成的图像模糊很多。思考原因,可能是窗宽窗位的关系。DicomImage中也提供了调整窗宽窗位的接口setWindow。在调用createWindowsDIB函数之前,调用setW函数,随后生成的BMP图像结果如下:

与常用的dcm浏览软件中的结果一致。

源代码下载:

         鉴于有些网友向我询问完整源码的问题,以前都是直接邮箱发送的,最近嫌麻烦,就将完整的.h和.cpp文件上传到了CSDN中,资源链接是:,需要2个积分奥。哈哈,如果不是CSDN的朋友,或者没有积分的朋友也不要着急,也可以到我的Github主页进行免费下载,地址是:,有问题及时反馈,多多交流,共同进步。

作者:zssure@163.com

时间:2014-09-03(最后更新时间)

转载于:https://my.oschina.net/zssure/blog/354823

你可能感兴趣的文章
业务发展如何利用创新驱动力量?
查看>>
云数据加密公司LOCKet获千万级Pre-A融资
查看>>
爱尔兰WElink Energy宣布在葡萄牙建立220MW太阳能光伏项目
查看>>
如何从敏捷到精益地修复bug与解决问题
查看>>
开启智慧新生活 新余市智慧城市建设全省率先
查看>>
智慧东湖让城市慢游更幸福
查看>>
陕西联通推进高速公路WiFi覆盖
查看>>
PHP开发者常犯的10个MySQL错误
查看>>
物联网在交通领域示范应用的三大趋势
查看>>
浅谈如何用Java操作MongoDB?
查看>>
Java ConcurrentModificationException异常原因和解决方法
查看>>
2015 年对 GitLab 来说是非常棒的一年
查看>>
《编写高质量代码:改善c程序代码的125个建议》——建议17-1:先处理正常情况,再处理异常情况...
查看>>
《Docker技术入门与实战》——3.2 查看镜像信息
查看>>
Linux有问必答:如何在CentOS或RHEL 7上修改主机名
查看>>
JVM的持久代——何去何从?
查看>>
Kafka Producer接口
查看>>
《jQuery、jQuery UI及jQuery Mobile技巧与示例》——9.8 技巧:指定自定义的过渡动画...
查看>>
《NLTK基础教程——用NLTK和Python库构建机器学习应用》——第2章 文本的歧义及其清理...
查看>>
《Hack与HHVM权威指南》——1.3.3 属性
查看>>