第一篇,如何使用DCMTK库解析多帧dicom数据

默认大家的VS已经配置好DCMTK库,和OPenCv库了哈,我使用的是vs2017。DCMTK库和OPenCv库用新一点的,哪个版本无所谓
第一步,读dicom文件。

    string filepath = m_strFilePath;//文件地址
	char ch[20];
	strcpy(ch, filepath.c_str());
	DcmParse *dcmParse = new DcmParse(filepath);
	DcmFileFormat fileformat;
	OFCondition ofcfile = fileformat.loadFile(filepath.c_str());                    //读取Dicom图像  
	if (!ofcfile.good())     //判断Dicom文件是否读取成功  
	{
		std::cout << "file Load error" << std::endl;
	}
	DicomImage* dicomImg = new DicomImage((DcmObject*)dataset, xfer);

第二步,解析文件

std::vector<cv::Mat> APP::MultiframeImageFromDcmDataSet(DicomImage* m_dcmImage)
{
	std::vector<cv::Mat> output_img;
	int framecount=(m_dcmImage->getFrameCount());	//获取这个文件包含的图像的帧数
	for (int k = 0; k < framecount; k++)
	{
		unsigned char *pixelData = (unsigned char*)(m_dcmImage->getOutputData(8, k, 0)); //获得8位的图像数据指针  
		if (pixelData != NULL)
		{
			int m_height = m_dcmImage->getHeight();
			int m_width = m_dcmImage->getWidth();
			cv::Mat image(m_height, m_width, CV_8UC1, cv::Scalar::all(0));
			uchar* data = nullptr;
			for (int i = 0; i < m_height; i++)
			{
				data = image.ptr<uchar>(i);
				for (int j = 0; j < m_width; j++)
				{
					data[j] = *(pixelData + i * m_width + j);
				}
			}
			output_img.push_back(image);
		}
	}
	return output_img;

}
```cpp

第二部已经拆分出不同帧的dicom数据,这时候就使用OPencv对容器的数据进行显示就可以了。大家都知道OPencv显示的是弹窗形式的,做真正项目的话肯定不能使用弹窗去做。
下一篇会介绍如何使用这些数据源转成bitmap图像格式给按钮控件或者图像控件使用,这样就可以完美嵌入项目中了。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值