• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            牽著老婆滿街逛

            嚴(yán)以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            ffmpeg 進行視頻轉(zhuǎn)換圖像翻轉(zhuǎn)的問題的修正

            轉(zhuǎn)載自:http://blog.csdn.net/bluestn/article/details/2068351

            我在用FFMPEG 開發(fā)在DirectShow 環(huán)境下生成FLV的篩選器(Filter)的時候,碰到了一個比較古怪的問題。因為該篩選器的輸入格式需要支持常見的RGB,和YUV格式。但是在輸入是RGB格式的時候,最終生成的視頻圖像是翻轉(zhuǎn)的。而用YUV格式確實沒有問題的。

            分析了一下程序,因為ffmpeg支持的最終存入FLV的格式是YUV420P,需要調(diào)用sws_scale進行圖像的格式轉(zhuǎn)換,應(yīng)該是調(diào)用sws_scale進行圖像格式轉(zhuǎn)換的時候發(fā)生的圖像反轉(zhuǎn)。雖然問題很顯然,但是卻一直找不到好的辦法,這個問題困擾了好久,也查看了ffmpeg的源代碼。本想也一段代碼,先把RGB格式的圖像先手工做一次反轉(zhuǎn),再通過sws_scale進行處理,那樣負負得正正好解決問題,當(dāng)然實現(xiàn)這樣的反轉(zhuǎn)代碼也比較簡單,稍微花點時間就可以搞定。但是進行編解碼處理的程序關(guān)鍵是性能,這樣處理,因為圖像反轉(zhuǎn)操作,白白損失了大量的CPU。后來發(fā)現(xiàn)其實,有一個非常巧妙的方法可以解決這個問題。或許ffmpeg在開發(fā)的時候,他們早已考慮到了這個問題,已經(jīng)預(yù)留了這個后門了。

            辦法是這樣的:

            先看看sws_scale的函數(shù)定義

            int sws_scale(struct SwsContext *ctx, uint8_t* src[], int srcStride[],
                          int srcSliceY, int srcSliceH, uint8_t* dst[], int dstStride[])

            其中src和srcStride定義了輸入圖像的四個平面的數(shù)據(jù)起始指針和四個平面中每一行包含的像素的個數(shù)。

            dst和dstStride是輸出變量,定義的是輸出圖像的四個平面的數(shù)據(jù)起始指針和四個平面包含的數(shù)據(jù)的大小。

            為什么一個圖像有四個平面,可以找一下YUV格式的一些詳細介紹就可以明白。

            當(dāng)然,RGB格式是按照緊湊格式進行編碼的,因此只有一個平面,也就是說只要設(shè)置src[0]就可以,src[1],src[2],src[3]都為NULL。

            我們就在設(shè)置src[0]和srcStride[0]的地方做文章。

            按照一般處理src[0]和srcStride[0]分別設(shè)置為起始圖像數(shù)據(jù)的開始和圖像每一行的像素個數(shù)。

            那如果把src[0] 設(shè)置為 width * ( height - 1)    srcStride[0] = -height 結(jié)果會如何呢?是不是就會把圖像倒過來呢?

            實際確實如此。進行圖像倒置的操作盡然如此簡單。這樣避免了人為再添加一次圖像的反轉(zhuǎn)操作,提高了編碼的性能。

            posted on 2013-01-28 19:28 楊粼波 閱讀(2459) 評論(0)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            精品久久久无码人妻中文字幕| 久久精品免费一区二区三区| 99精品久久精品| 热久久国产精品| 人妻系列无码专区久久五月天| 久久一区二区三区99| 久久久久免费精品国产| 2022年国产精品久久久久| 久久国产免费观看精品| 国产精品成人99久久久久91gav| 日韩精品无码久久一区二区三| 蜜臀久久99精品久久久久久| 日韩电影久久久被窝网| 久久精品蜜芽亚洲国产AV| 久久精品国产亚洲7777| 亚洲色大成网站WWW久久九九| 久久超碰97人人做人人爱| 久久93精品国产91久久综合| 久久久无码一区二区三区| 久久久久亚洲AV无码专区网站| 久久综合噜噜激激的五月天| 亚洲人成电影网站久久| 国产精品永久久久久久久久久| 久久久久99精品成人片试看| 青青热久久国产久精品 | 久久久精品国产sm调教网站| 亚洲一区精品伊人久久伊人| 精品久久久久久中文字幕| 日产精品久久久久久久| 久久精品国产亚洲AV高清热| 久久九九久精品国产免费直播| 亚洲а∨天堂久久精品| 久久中文字幕精品| 久久精品青青草原伊人| 五月丁香综合激情六月久久| 中文字幕热久久久久久久| 久久无码国产| 日韩av无码久久精品免费| 国产亚洲欧美成人久久片| 99精品久久久久中文字幕| 久久亚洲欧美日本精品|