詳解 QT 顯示視頻 Linux下 Qt 和 Xv實現
QT 顯示視頻 linux下 Qt 和 Xv 是本文要介紹的內容,先來對linux下的 Qt 和 Xv來做個總結,然后加了一段代碼,供大家參考!先來看內容。
采用Qt+Xv實現視頻顯示的原因是因為Xv可以使用顯卡進行顯示加速;比如,對于視頻大小的縮放,如果交給cpu來完成這項操作,那cpu的計算量是非常大的,一般的cpu基本上是滿負荷運轉了,所以,選用Xv來實現視頻縮放和顯示,是一個非常明智的選擇;這里我先簡單說一下,為什么Qt可以和Xv和在一起來顯示視頻幀呢?它的原理又是什么呢?
首先,我們要知道,無論是Qt還是Xv,他們都是基于一個顯示架構的,那就是X架構,Qt是對Xlib進行的更高層及的封裝,而Xv則是對Xlib功能上 的一個擴展,旨在盡可能的挖掘顯卡的運算能力,而實現更為強大的功能;這也是為什么兩者可以結合在一起顯示視頻的理論和實際基礎了;然而,又由于,兩者所 在的層次不同,而且目的也不同,那么如何將這兩者結合起來,就成為了當前的最大的問題了;
通過在網上搜索,可以知道Xv可以直接顯示YUV數據,并且很容易實現視頻縮放,而且這些都已經經過硬件加速優化過了;這也正是我最需要的!
我們直接開始介紹Xv中的顯示圖片的函數--XvPutImage,和Xlib提供的顯示圖片函數XPutImage只相差一個字母,但是這個函數功能確強大了許多;
此函數的函數原型為:
- XvPutImage(Display *, XvPortID, Window, GC *, XvImage *, int src_x, int src_y, int src_w, int src_h, int dst_x, int dst_y, int dst_w, int dst_h);
針對此函數,我們來看怎么使用此函數,會用了此函數,就可以顯示YUV數據了;
此函數需要結合一個QWidget才能夠顯示圖片;
第一個參數,可以通過QWidget的x11Display()函數得到;
第二個,可以通過XvQueryAdaptors得到;
第三個,通過QWidget的winId()得到;
第四個,通過XvCreateImage得到;
剩下的幾個坐標函數,我就不解釋了,光看參數名稱,就應該猜的出來;
這里需要注意的一點是,在使用XvCreateImage生成了新的XvImage時,此函數的第四個參數可以直接賦予AVFrame的data[0]指 針,這樣,就把ffmpeg的數據幀同要顯示的XvImage聯系到了一起,并且,這個AVFrame中的data[0]數據為YUV數據,完全符合要 求,可以直接刷新顯示了;
總的來說,大致就是這樣子了,以后有什么疑問,還會對此文檔進行詳細擴充;爭取寫成教程;
采用Xv進行顯示也是存在風險的,一旦當前系統的驅動對Xv支持不好,或者干脆不支持,那么就不能顯示視頻了。
QT 顯示視頻代碼:
- QPainter has a method called drawImage. You can do something like the
- following in a subclass of QWidget:
- void VideoWidget::paintEvent()
- {
- //Get
- the current frame and size data...
- //Passing QImage
- QImage frame(frameDataUCharPtr, frameWidth, frameHeight.
- QImage::Format_RBG32 );
- QPainter painter(this);
- painter.drawImage(rect(), frame);
- }
- Under Qtopia
- you can use QDirectPainter to write directly to framebuffer
- memory and get
- some faster access for drawing frames. You will have to
- do the color conversions yourself to get
- the frame into your
- framebuffer's color model.
- --Justin
小結:關于詳解 QT 顯示視頻 linux下 Qt 和 Xv 實現 的內容介紹到這里,希望本文對你有所幫助!