ITK、VTK 读取 DiCOM 文件信息,并实现交互预览

DICOM 文件介绍

DICOM 全名叫 Digital Imaging and Communications in Medicine(医学数字图像与通信),是医学图像和相关信息的过节标准,也定义了临床所需数据医学图像格式;

DICOM 数据格式包含大量属性,例如病人名字、ID、年龄等基本信息,这些信息从储存在 “头文件” 中,这种储存方式避免了病人与图像误配;

一个病人样本 包含多个 DICOM 子文件,单个 DICOM 对象只包含具有一帧像素数据,帧与帧之间以序列形式存在,可以来回切换形成类似于电影放映的情景,类似于把一个3D 图像扫描成像,沿着垂直方向等厚度分割得到

Snipaste_2020-07-11_11-25-24.png

ITK 对 DICOM 数据进行读取

ITK 根据 DICOM 文件读取方式有两种类型,单张 DICOM 读取或 序列 DICOM 读取

ITK 读取单张 DICOM 文件

  • itkImageSeriesReader;
  • itkGDCMImageIO;

读取后可以通过 itkGCOMImageIO 中 Get*** 函数获取病人相关信息,并打印输出,这里需要注意一点,DICOM 对应的数据类型为 signed short;核心代码:

	string DirectoryPath = "D:/Data_Training/Dicom_data/215020265/AT000002.152046493.dcm";
	

	typedef signed short InternalPixelType;
	const unsigned int  Dimension = 2;
	using InternalImageType = itk::Image<InternalPixelType, Dimension>;

	typedef itk::Image<InternalPixelType, Dimension> ImageType;
	typedef itk::ImageSeriesReader<ImageType> ReaderType;
	
	typedef itk::GDCMImageIO ImageIOType;
	
	ImageIOType::Pointer gdcmIO = ImageIOType::New();
	
	ReaderType::Pointer reader = ReaderType::New();
	reader->SetImageIO(gdcmIO);
	reader->SetFileNames(DirectoryPath);

	// Reading Data;
	try
	{
		reader->Update();
		reader->GetMetaDataDictionary();
		gdcmIO->GetMetaDataDictionary();// 读取头文件信息;

		//信息赋值
		char* name = new char[50];
		char* patientID = new char[50];
		char* time = new char[50];
		char* manufacture = new char[50];
		char* modility = new char[50];
		char* hospital = new char[50];
		char* sex = new char[50];
		char* age = new char[50];
		char* description = new char[100];
		

		
		
		int pixelType = gdcmIO->GetPixelType();
		int componentType = gdcmIO->GetComponentType();
		int fileType = gdcmIO->GetFileType();
		ImageIOType::ByteOrder byteOrder;
		byteOrder = gdcmIO->GetByteOrder();
		
		unsigned int dim = 0;
		gdcmIO->GetDimensions(dim);
		ImageIOType::SizeType imgsize;
		imgsize = gdcmIO->GetImageSizeInPixels();
		int componetSize = gdcmIO->GetComponentSize();
		int dimension = gdcmIO->GetNumberOfDimensions();
		int ori = 0;
	
		gdcmIO->GetOrigin(ori);
		int spa = 0;

		gdcmIO->GetPatientSex(sex);
		gdcmIO->GetPatientAge(age);
		gdcmIO->GetStudyDescription(description);
		gdcmIO->GetSpacing(spa);
		gdcmIO->GetPatientName(name);
		gdcmIO->GetModality(modility);
		gdcmIO->GetPatientID(patientID);
		gdcmIO->GetManufacturer(manufacture);
		gdcmIO->GetStudyDate(time);
		ImageIOType::TCompressionType compressType;
		compressType = gdcmIO->GetCompressionType();
		gdcmIO->GetInstitution(hospital);
		ImageType::SpacingType spacetype;
		spacetype = reader->GetOutput()->GetSpacing();
		ImageType::PointType origin;
		origin = reader->GetOutput()->GetOrigin();
		
		
		
		cout << "name:" << name << endl;
		cout << "age:" << age << endl;
		cout << "sex:" << sex << endl;
		cout << "description:" << description << endl;
		cout << "hospital:" << hospital << endl;
		cout << "modility:" << modility << endl;
		cout << "manfacture:" << manufacture << endl;
		cout << "dim:" << dim << endl;
		cout << "origin:" << origin << endl;
		cout << "Time:" << time << endl;
		cout << "patientID:" << patientID << endl;
		
	}
	catch (const itk::ExceptionObject& excp)
	{
		cout << " Reading Exceptaion Caught" << endl;
		cout << excp.what() << endl;
		
		return EXIT_FAILURE;
	}
	

ITK 读取序列 DICOM 文件

  • itkImageSeriesReader;
  • itkGDCMImageIO;
  • itkGDCMSeriesFileNames;

与单张读取不同的是,多了一个 itkGDCMSeriesFileNames 类,用于打包 DICOM 序列文件,再传入 GDCMImageIO 进行读取

	string DirectoryPath = "D:/Data_Training/Dicom_data/215020265";

	typedef signed short InternalPixelType;
	const unsigned int  Dimension = 3;
	using InternalImageType = itk::Image<InternalPixelType, Dimension>;

	typedef itk::Image<InternalPixelType, Dimension> ImageType;
	typedef itk::ImageSeriesReader<ImageType> ReaderType;
	
	typedef itk::GDCMImageIO ImageIOType;
	typedef itk::GDCMSeriesFileNames NamesGeneratorType;
	
	ImageIOType::Pointer gdcmIO = ImageIOType::New();
	NamesGeneratorType::Pointer namesGenerator = NamesGeneratorType::New();
	
	namesGenerator->SetInputDirectory(DirectoryPath);
	
	const ReaderType::FileNamesContainer & filenames =
		namesGenerator->GetInputFileNames();

	std::size_t numberOfFileNames = filenames.size();
	std::cout << numberOfFileNames << std::endl;
	
	
	ReaderType::Pointer reader = ReaderType::New();
	reader->SetImageIO(gdcmIO);
	reader->SetFileNames(filenames);
	

	// Reading Data;
	try
	{
		reader->Update();
		reader->GetMetaDataDictionary();
		gdcmIO->GetMetaDataDictionary();// 读取头文件信息;

		//信息赋值
		char* name = new char[50];
		char* patientID = new char[50];
		char* time = new char[50];
		char* manufacture = new char[50];
		char* modility = new char[50];
		char* hospital = new char[50];
		char* sex = new char[50];
		char* age = new char[50];
		char* description = new char[100];
		

		
		
		int pixelType = gdcmIO->GetPixelType();
		int componentType = gdcmIO->GetComponentType();
		int fileType = gdcmIO->GetFileType();
		ImageIOType::ByteOrder byteOrder;
		byteOrder = gdcmIO->GetByteOrder();
		
		unsigned int dim = 0;
		gdcmIO->GetDimensions(dim);
		ImageIOType::SizeType imgsize;
		imgsize = gdcmIO->GetImageSizeInPixels();
		int componetSize = gdcmIO->GetComponentSize();
		int dimension = gdcmIO->GetNumberOfDimensions();
		int ori = 0;
	
		gdcmIO->GetOrigin(ori);
		int spa = 0;

		gdcmIO->GetPatientSex(sex);
		gdcmIO->GetPatientAge(age);
		gdcmIO->GetStudyDescription(description);
		gdcmIO->GetSpacing(spa);
		gdcmIO->GetPatientName(name);
		gdcmIO->GetModality(modility);
		gdcmIO->GetPatientID(patientID);
		gdcmIO->GetManufacturer(manufacture);
		gdcmIO->GetStudyDate(time);
		ImageIOType::TCompressionType compressType;
		compressType = gdcmIO->GetCompressionType();
		gdcmIO->GetInstitution(hospital);
		ImageType::SpacingType spacetype;
		spacetype = reader->GetOutput()->GetSpacing();
		ImageType::PointType origin;
		origin = reader->GetOutput()->GetOrigin();
		
		
		
		cout << "name:" << name << endl;
		cout << "age:" << age << endl;
		cout << "sex:" << sex << endl;
		cout << "description:" << description << endl;
		cout << "hospital:" << hospital << endl;
		cout << "modility:" << modility << endl;
		cout << "manfacture:" << manufacture << endl;
		cout << "dim:" << dim << endl;
		cout << "origin:" << origin << endl;
		cout << "Time:" << time << endl;
		cout << "patientID:" << patientID << endl;
		
	}
	catch (const itk::ExceptionObject& excp)
	{
		cout <
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小张Python1

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

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

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

打赏作者

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

抵扣说明:

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

余额充值