1. 程式人生 > >【轉載】Qt中圖像的顯示與基本操作

【轉載】Qt中圖像的顯示與基本操作

繪制 nta pen 位置 產生 縮放 eas urn mod

Qt可顯示基本的圖像類型,利用QImage、QPxmap類可以實現圖像的顯示,並且利用類中的方法可以實現圖像的基本操作(縮放、旋轉)。

參考:Qt中圖像的顯示與基本操作 - ykm0722的專欄 - 博客頻道 - CSDN.NET http://blog.csdn.net/ykm0722/article/details/7447632


1. Qt可顯示的圖像類型

參考Qt的幫助文檔,可支持的類型,即可以直接讀取並顯示的格式有BMP、GIF、JPG、JPEG、PNG、TIFF、PBM、PGM、PPM、XBM、XPM。

2. Qt用如何顯示圖像

通常用QLabel顯示圖像,QLabel類有setPixmap()函數,可以用來顯示圖像。也可以直接用QPainter畫出圖像。

如果圖像過大,直接用QLabel顯示,將會出現有部分圖像顯示不出來,這時可以用Scroll Area部件。方法:將QLabel部件放到Scroll Area部件裏面,將兩個采用柵格布局,當圖像超出了QLabel部件大小時,就會產生滑動桿,這樣圖像就可以都看到了。

3. 顯示的方法

步驟:先打開一個圖像;將圖像文件加載進QImage對象中;再用QPixmap對象獲得圖像;最後用QLabel選擇一個QPixmap圖像對象顯示。

代碼如下:

QString filename;

filename=QFileDialog::getOpenFileName(this,

tr("選擇圖像"),

"",

tr("Images (*.png *.bmp *.jpg *.tif *.GIF )"));

if(filename.isEmpty())

{

return;

}

else

{

QImage* img=new QImage;

if(! ( img->load(filename) ) ) //加載圖像

{

QMessageBox::information(this,

tr("打開圖像失敗"),

tr("打開圖像失敗!"));

delete img;

return;

}

ui->label->setPixmap(QPixmap::fromImage(*img));

}

註:也可以直接用QPixmap類的對象采用Load函數加載圖像。這裏說下QImage和QPixmap類的用處:QImage為圖像的像素級訪問做了優化,QPixmap使用底層平臺的繪制系統進行繪制,無法提供像素級別的操作,而QImage則是使用獨立於硬件的繪制系統。

4. 圖像縮放

圖像縮放采用scaled函數。函數原型

QImage QImage::scaled ( const QSize & size,Qt::AspectRatioMode aspectRatioMode = Qt::IgnoreAspectRatio, Qt::TransformationModetransformMode = Qt::FastTransformation ) const

使用方法如下,還是利用上面的img:

QImage* imgScaled = new QImage;

*imgScaled=img->scaled(width,

height,

Qt::KeepAspectRatio);

ui->label->setPixmap(QPixmap::fromImage(*imgScaled));

scaled函數中width和height表示縮放後圖像的寬和高,即將原圖像縮放到(width,height)大小。

5. 圖像旋轉

圖像旋轉可以利用QImage類的transformed函數,向transformed函數傳入QMatrix對象,QMatrix對象指定了旋轉的角度。

代碼如下:

QImage* imgRatate = new QImage;

QMatrix matrix;

matrix.rotate(270);

*imgRotate = img->transformed(matrix);

ui->label->setPixmap(QPixmap::fromImage(*imgRotate));

註意:rotate函數中參數是旋轉的角度,旋轉是按順時針方向旋轉的,上面順時針旋轉270度,即逆時針旋轉90度。

6. 圖像連續縮放

有了圖像縮放的基礎,就可以實現圖像的連續縮放,可以放置一個橫向滑竿(中文解釋不標準,就是Horizontal Slider部件 ),滑動滑輪的位置以實現圖像連續縮放。

Horizontal Slider部件指向的值為整型value,即縮放後的圖像為

img->scaled(orignalWidth*value/100,

orignalHeight*value/100,

Qt::KeepAspectRatio);

orignalWidth和orignalHeight為原始圖像的寬和高。

註意:在對原始圖像進行縮放多少倍數時,在相應的槽函數內只需要調用Horizontal Slider部件對象的setValue函數即可,因為Horizontal Slider部件滑竿指向的值一旦變化就會觸發對應的槽函數來對圖像進行縮放。

【轉載】Qt中圖像的顯示與基本操作