我正在尝试从Dicom文件打印图像。我将原始数据传递给convertToFormat_RGB888函数。据我所知,Qt无法处理单色16位图像。
这是原始图像(在此处转换为jpg):http://imageshack.us/photo/my-images/839/16bitc.jpg/
bool convertToFormat_RGB888(gdcm::Image const & gimage, char *buffer, QImage* &imageQt)
在这个函数中,我进入了这个...
...
else if (gimage.GetPixelFormat() == gdcm::PixelFormat::UINT16)
{
short *buffer16 = (short*)buffer;
unsigned char *ubuffer = new unsigned char[dimX*dimY*3];
unsigned char *pubuffer = ubuffer;
for (unsigned int i = 0; i < dimX*dimY; i++)
{
*pubuffer++ = *buffer16;
*pubuffer++ = *buffer16;
*pubuffer++ = *buffer16;
buffer16++;
}
imageQt = new QImage(ubuffer, dimX, dimY, QImage::Format_RGB888);
...
这段代码是从这里改编的:gdcm.sourceforge.net/2.0/html/ConvertToQImage_8cxx-example.html
但是原来的我得到了一个执行错误。使用我的至少我得到了一个图像,但它不一样。
这是新图像(在此处转换为jpg):http://imageshack.us/photo/my-images/204/8bitz.jpg/
我做错了什么?谢谢。
尝试手动从缓冲区获取像素值并将其传递给 QImage::setPixel。它可以更简单。
您在此处将 16 位整数分配给 8 位变量:
*pubuffer++ = *buffer16;
结果是未定义的,大多数编译器只是将较低的 8 位移动到目标。你想要上部 8 位
*pubuffer++ = (*buffer16) >> 8;
另一个问题是字节序。根据源数据的字节序,您可能需要调用其中一个 QtEndian 函数。
最后,您实际上不需要使用任何32位或24位Qt图像格式。使用 8 位QImage::Format_Indexed8
并将颜色表设置为灰色。