如何使用GDCM读取多帧DICOM文件?

How to read multi frame DICOM files using GDCM?

本文关键字:DICOM 文件 何使用 GDCM 读取      更新时间:2023-10-16

我正在尝试使用 gdcm 库读取多帧 DICOM 文件。

但是我只能使用以下代码读取单帧dicom文件数据:

gdcm::ImageReader reader;
reader.SetFileName(path); 
if(!reader.Read()) return false;
const gdcm::Pixmap &image = reader.GetPixmap();
int length = image.GetBufferLength();
char *buffer = new char[length];
image.GetBuffer(buffer);

如何访问另一个框架?

使用 GDCM 3.0.8,您可以使用以下代码读取帧,

gdcm.ImageRegionReader imageReader = new gdcm.ImageRegionReader();
imageReader.SetFileName(@"multiframe.dcm");
imageReader.ReadInformation();
gdcm.Image gimage = imageReader.GetImage();
uint numDims = gimage.GetNumberOfDimensions();
if (numDims < 2 || numDims > 3)
return false;
uint width = gimage.GetDimension(0);
uint height = gimage.GetDimension(1);
uint numFrames = 1;
if (numDims == 3)
numFrames = gimage.GetDimension(2);
gdcm.PixelFormat pixelFormat = gimage.GetPixelFormat();
var bytesPerPixel = pixelFormat.GetPixelSize();
for (uint frame = 0; frame < numFrames; frame++)
{
gdcm.BoxRegion boxRegion = new gdcm.BoxRegion();
boxRegion.SetDomain(0, width - 1, 0, height - 1, frame, frame);
boxRegion.ComputeBoundingBox();
imageReader.SetRegion(boxRegion);
byte[] pixelBytes = new byte[width * height * bytesPerPixel];
imageReader.ReadIntoBuffer(pixelBytes, (uint)pixelBytes.Length);
}

虽然这是 C# 代码,但C++几乎相同。 我希望有人可以从中得到帮助。