使用dcmtk读取dicom Tag信息

本文介绍了如何使用DCMTK工具dcmdump解析DICOM文件,展示如何通过C++代码获取患者姓名等信息,以及涉及的关键类如DcmFileFormat、DcmDataset和OFCondition.
摘要由CSDN通过智能技术生成

dicom文件由导言、前缀和多个数据元素构成,一个.dcm文件可以形象的看成一本字典,而每个字都由特定的Tag作为检索。

Tag的值中存放有该图对应患者的姓名、年龄、性别等,还包括拍摄医院的名称、操作技师的名字等,以及每一张图的像素信息。

文件结构可以参考 一滩海豹博主的文章:

dicom文件结构_dicom数据结构_一滩海豹的博客-CSDN博客

了解了基本情况,我们进行接下来的操作。

1. 任务目标

使用DCMTK读取一张dicom图像的信息,并将数据打印出来进行阅读。

2. 使用dcmdump

dcmtk本身就有一个工具APP可作为解析器,dcmdump位于dcmdata package,工具的介绍页面为:

DCMTK: dcmdump: Dump DICOM file and data set

在命令行输入

//dcmdump [options] dcmfile-in
dcmdump F:\test.dcm 

请添加图片描述

即可打印.dcm文件tag信息

3. 新建CPP项目读取tag

#include <iostream>
#include "dcmtk/dcmdata/dcfilefo.h"
#include "dcmtk/dcmdata/dcdeftag.h"
using namespace std;

int main()
{
	DcmFileFormat fileformat;
	OFCondition status = fileformat.loadFile("F:/test.dcm");
	DcmDataset* dataset = fileformat.getDataset();
	if (status.good())
	{
		OFString patientName;
		if (dataset->findAndGetOFString(DCM_PatientName, patientName).good())
		{
			cout << "Patient's Name: " << patientName << endl;
		}
		else
			cerr << "Error: cannot access Patient's Name!" << endl;
	}
	else
		cerr << "Error: cannot read DICOM file (" << status.text() << ")" << endl;	
	
	system("pause");
	return 0;
}

DcmFileFormat:

头文件:/dcfilefo.h

功能:用来操作dicom文件的类

DcmDataset:

头文件:/dcdatset.h

功能:是一个记录dicom tag的数据结构

OFCondition:

头文件:/ofcond.h

功能:用来记录状态

DCM_PatientName:

头文件:/dcdeftag.h

功能:记录了dicom的tag

如果无法编译成功,需要添加 include 文件夹和 dcmdata.lib,ofstd.lib

使用 DCMTK读取 DICOM 文件需要进行以下步骤: 1. 引入 DCMTK 库 在 QT 项目中引入 DCMTK 库,可以通过在项目文件中添加以下代码引入静态库: ``` LIBS += -L/path/to/dcmtk/lib -ldcmdata -loflog -lofstd -li2d -ldcmimage -lzlib -lpng -ltiff ``` 注意:需要将 /path/to/dcmtk/lib 替换为 DCMTK 库的安装路径。 2. 初始化 DCMTK 库 在 QT 代码中,需要先初始化 DCMTK 库,可以在 main 函数中添加以下代码: ``` #include <dcmtk/config/osconfig.h> #include <dcmtk/dcmdata/dctk.h> int main(int argc, char *argv[]) { // 初始化 DCMTK 库 DcmInitialize(argc, argv); ... } ``` 3. 读取 DICOM 文件 使用 DCMTK读取 DICOM 文件可以使用 DcmFileFormat 类,以下是一个示例代码: ``` #include <dcmtk/config/osconfig.h> #include <dcmtk/dcmdata/dctk.h> void readDICOM(const char* filename) { // 创建 DcmFileFormat 对象 DcmFileFormat fileformat; // 读取 DICOM 文件到 DcmFileFormat 对象中 OFCondition status = fileformat.loadFile(filename); if (!status.good()) { qDebug() << "Failed to read DICOM file"; return; } // 获取 DICOM 数据集 DcmDataset* dataset = fileformat.getDataset(); // 获取 DICOM 图像数据 Uint16 *pixelData; dataset->findAndGetUint16Array(DCM_PixelData, pixelData); // 获取 DICOM 图像大小 Uint16 rows, cols; dataset->findAndGetUint16(DCM_Rows, rows); dataset->findAndGetUint16(DCM_Columns, cols); } ``` 上述代码中,首先创建 DcmFileFormat 对象,然后使用 loadFile() 方法读取 DICOM 文件,如果读取成功,则可以使用 getDataset() 方法获取 DICOM 数据集,使用 findAndGetUint16Array() 方法获取图像数据,使用 findAndGetUint16() 方法获取图像大小。 注意:DCMTK使用 C++98 标准,因此需要在 QT 项目中添加 -std=c++98 编译选项。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值