4

更好的方法(没有QImage)?:

QImage image(width, height, QImage::Format_RGB888);
memcpy(image.bits(), m_frameRGB->data[0], height * width * 3);
QPixmap pixmap = QPixmap::fromImage(image);

我看不出有任何理由QImage用作中间缓冲区,但QPixmap::loadFromData不要使用此上下文加载数据:

pixmap.loadFromData(m_frameRGB->data[0], height * width * 3); // Need pixmap resize?
4

2 回答 2

2

文档说:“如果未指定格式(这是默认格式),加载程序会探测文件的标题以猜测文件格式”。您只提供指向原始图像字节的指针,但您必须在缓冲区的开头提供一个标头,例如对于未压缩的 PPM 格式。

编辑: 您还可以测试 Roku 的建议,以使用将图像数据作为参数的 QImage 构造函数,但请参阅文档中的注释:“缓冲区必须在 QImage 的整个生命周期内保持有效。”

于 2012-06-26T16:22:32.510 回答
1

遵循hmuelner的提示,并且......它真的比QPixmap pixmap = QPixmap::fromImage(image);

QPixmap pixmap(height, width);
QByteArray pixData;
pixData.append(QString("P6 %1 %2 255 ").arg(width).arg(height));
pixData.append((char *)m_frameRGB->data[0], width * height * 3);
pixmap.loadFromData((uchar *)pixData.data(), pixData.size());
于 2019-11-07T12:11:58.007 回答