【发布时间】:2014-03-12 21:52:06
【问题描述】:
我正在尝试从二进制文件中保存为 16 位整数的数据构造 QImages。我可以很好地加载数据,但是当我使用 QImage::loadFromData(QBytearray ba) 函数(返回 false)时我的程序失败,如下所示:
QBytearray frame;
QImage pic = QImage(256, 256, QImage::Format_RGB888);
for(int i = 0; i < height; i++) {
for(int j = 0; j < width; j++) {
// Access value of pixel at each location
datum = store[i][j];
for(int c = 0; c < 3; c++) {
// Calculate colour at given pixel
col = (255.0f * ((float)datum - (float)min) / ((float)(max - min)));
// Assign colour value to the pixel
frame[c+3*j+3*i*width] = ((unsigned char)col);
}
}
}
pic.loadFromData(frame);
我从之前编写的 Java 代码中重新调整了它的用途,该代码完全按预期工作(来自完全相同的数据):
BufferedImage image = = new BufferedImage(256, 256, BufferedImage.TYPE_3BYTE_BGR);
byte[] data = image.getRaster().getDataBuffer();
for (j=0; j<height; j++) {
for (i=0; i<width; i++) {
//Find value of the pixels at the location
datum=data[j][i];
for (c=0; c<3; c++) {
//Calculate the colour at the given pixel
col=(255.0f*((float)datum-(float)min)/((float)(max-min)));
//Assign the colour value to the pixel
data[c+3*i+3*j*width] = (byte)col;
}
}
}
谁能帮我看看我哪里出错了?我已经被难住了好几天,完全没有想法。
【问题讨论】:
-
您是否尝试过将
store设置为一组硬编码的预定值?如果有,结果如何?如果没有,你能做到这一点并给我们结果吗?完成构建后frame是什么? -
@MirroredFate 考虑到图像是 256x256,我无法真正做到这一点,因此硬编码该图像的值有点费时。当我完成构建时,
frame到底是什么意思?尺寸? -
虽然让我感到困惑的一件事是,从直接从文件加载的单独图像中转储 Bytearray(效果很好)给了我一个 QByteArray 2562 个元素长 - 而我正在构建的是196609 个元素长。我觉得这种(巨大的)大小差异至少是问题的一部分,但我不知道两者之间的数据格式差异可能是什么。我的意思是,196609 字节数组在 Java 实现中工作得很好,所以我真的不知道为什么相同大小的图像的 C++ 字节数组会小得多。
-
此外,在
QImage::loadFromData(QByteArray ba)函数中使用转储的 QByteArray 的工作方式与宣传的完全一样。似乎大小差异是主要问题,但即使我放弃颜色设置(cfor循环)我仍然有一个 65536 个元素长的数组。 -
这主要是猜测你有一个二维数组
store和一个QByteArray框架。您正在将无符号字符(1 个字节)从store移动到frame,但您的 RGB 值总共需要 3 个字节。这意味着frame本质上是一个等于 256*256*3 或 196609 字节的字节数组。我看不到你在哪里输入标题信息来告诉它是哪种图像,或者任何类型的元字符来给出大小......
标签: java c++ qt bufferedimage qimage