我正在使用 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
我是否遗漏了代码中的某些内容,或者我不明白该函数的作用?任何人都可以请赐教吗?非常感谢你!