image打开rgb16 qt_QT中显示图像数据
一般圖像數(shù)據(jù)都是以RGBRGBRGB……字節(jié)流的方式(解碼完成后的原始圖像流),我說成字節(jié)流,那就表明R,G,B的值各占一個字節(jié),在編程時表示的就是unsigned char * data。
我們先來看一下QT中的QImage對象。在加載data數(shù)據(jù)前,我們要確定QImage加載圖像的空間分配足夠大,先假設data是由640*480像素的壓縮數(shù)據(jù)解碼得來的,RGB(3字節(jié))是一個像素,故data的應該是640*480*3個字節(jié);比較一下下面兩種方式:
QImage?img(640,480,QImage::Format_RGB888);//24位
unsigned?char?*?p_bits=img.bits();
24位(3字節(jié))一個像素,那么p_bits所得到的空間應該是640*480*3個字節(jié),所以剛剛好一個字節(jié)對一個字節(jié)。所以我們這樣賦值即可:
for(int?i=0;i<640*480*3;i+=3)
{
puiBits[i]=data[i];
puiBits[i+1]=data[i+1];
puiBits[i+2]=data[i+2];
}
//接著就是將img轉化成QPixmap填充到QWidget
QPixmap?pixmap=QPixmap::fromImage(img);
pixmap=pixmap.scaled(widget->size());
widget->setAutoFillBackground(true);
QPalette?palette;
palette.setBrush(widget->backgroundRole(),?QBrush(pixmap));
widget->setPalette(palette);
widget->repaint();
另一種方式:
unsigned?int?*?p_bits;
QImage?img(640,480,QImage::Format_RGB32);
p_bits=(uint*)img.bits();
32位(4字節(jié))一個像素,那么p_bits所得到的空間應該是640*480*4個字節(jié),所以不能以上面的方式賦值。有沒有注意到,這里用了unsigned int而不用unsigned char;unsigned int是4個字節(jié)的,unsigned char 是1個字節(jié)的,所以我們這里做的事情是將每一個RGB單元放到p_bits的每個unsigned int(4字節(jié))中。因為p_bits是unsigned int指針,所以p_bits[i]就是4個字節(jié)。所以應該這樣寫:
for(int?i=0;i<640*480*3;i+=3)
{
p_bits[i/3]=qRgb(data[i],data[i+1],data[i+2]);
}
//接著就是將img轉化成QPixmap填充到QWidget
QPixmap?pixmap=QPixmap::fromImage(img);
pixmap=pixmap.scaled(widget->size());
widget->setAutoFillBackground(true);
QPalette?palette;
palette.setBrush(widget->backgroundRole(),?QBrush(pixmap));
widget->setPalette(palette);
widget->repaint();
總結
以上是生活随笔為你收集整理的image打开rgb16 qt_QT中显示图像数据的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 百度云加速器
- 下一篇: leetcode 203 移除链表元素