0

我正在使用 DCMTK 读取并希望修改 DICOM 图像。我有以下代码:

#include <iostream>
#include <opencv\cv.h>
#include <dcmtk\dcmimgle\dcmimage.h>

int main() {
    try {
        DicomImage* dicomImage = new DicomImage("C:/Users/Kriselle/Documents/000004.dcm");
        if ((dicomImage != NULL) && (dicomImage->isMonochrome())) {
            dicomImage->writeBMP("C:/Users/Kriselle/Documents/z.bmp", 8);
            std::cout << "z.bmp is created" << std::endl;
        }
        else {
            std::cout << "dicomImage is null or not monochrome" << std::endl;
        }
    }
    catch (cv::Exception e) {
        std::cerr << e.what() << std::endl;
    }
    return 0;
}

我所做的只是创建一个 DicomImage 并将其像素数据写入具有我指定的文件名的 BMP 文件,但该图像仅返回一个灰色图像,原始图像的轮廓几乎无法识别。

这就是它的样子:https ://www.dropbox.com/s/6dw8nlae8hfvqf6/000004.jpg?dl=0 这是代码产生的结果:https ://www.dropbox.com/s/fff2kch124bzjqy/ z.bmp?dl=0

我是否遗漏了代码中的某些内容,或者我不明白该函数的作用?任何人都可以请赐教吗?非常感谢你!

4

1 回答 1

1

正如您可以在DicomImage类的 API 文档中阅读的那样,默认设置是在渲染单色 DICOM 图像时不启用 VOI 转换。在您的情况下,这似乎不合适,因此您应该指定更合适的 VOI 设置(例如min-max window)或使用存储在 DICOM 数据集中的 VOI 窗口之一(如果有)。

顺便说一句,在构造函数中加载图像后,您还应该使用 getStatus() 方法检查此过程的状态。

于 2015-07-23T12:54:12.857 回答