dcmtk读取dcm文件中Tag值

读取病人信息等,可根据宏定义自由设置读取其他信息,代码如下:

{  
	DcmFileFormat fileformat;
	OFCondition dcmFile = fileformat.loadFile("G:/DXL/DXL_CCTA/1.2.392.200036.9116.2.1220972159.1406529370.671878.1.1_anon.dcm"); //读取Dicom图像

	if (!dcmFile.good()) //判断Dicom文件是否读取成功
	{
		std::cout << "file Load error" << std::endl;
		return;
	}
	DcmDataset *dataset = fileformat.getDataset(); //得到Dicom的数据集

	OFString patientname;
	dataset->findAndGetOFString(DCM_PatientName, patientname); //获取病人姓名

	qDebug() << "patientname:" << QString::fromStdString(patientname) << endl;

	OFString isRGB;
	dataset->findAndGetOFString(DCM_PhotometricInterpretation, isRGB); // DCM图片的图像模式

	unsigned short bit_count(0);
	dataset->findAndGetUint16(DCM_BitsStored, bit_count); //获取像素的位数 bit
} 
使用 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[]) { // 初始化 DCMTKDcmInitialize(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
发出的红包

打赏作者

星火撩猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值