• <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>

            牽著老婆滿街逛

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

            使用FFMPEG SDK解碼流數據

            轉載自:http://blog.csdn.net/gwinner/article/details/5462855

            本文以H264視頻流為例,講解解碼流數據的步驟。

            為突出重點,本文只專注于討論解碼視頻流數據,不涉及其它(如開發環境的配置等)。如果您需要這方面的信息,請和我聯系。

            • 準備變量

            定義AVCodecContext。如果您使用類,可以定義成類成員。我這里定義成全局變量。

             

            static AVCodecContext * g_pCodecCtx = NULL;

            定義一個AVFrame,AVFrame描述一個多媒體幀。解碼后的數據將被放在其中。

            static AVFrame * g_pavfFrame = NULL;


             

            • 初始化解碼器

            現在開始初始化您的解碼器。我把整個初始化過程包在了一個函數里,除非您有更好的主意,我建議您也這么做。函數長得象這樣:

            BOOL H264_Init()

            {

            }

            初始化libavcodec,MMPEG要求,這個函數一定要第一個被調用:

            avcodec_init();

            掛上所有的codec。也許只掛一個H264的codec就行,我沒試過:

            av_register_all();

            得到H264的解碼器:

            AVCodec * pCodec = avcodec_find_decoder(CODEC_ID_H264);

            創建一個AVCodecContext,并用默認值初始化:

            g_pCodecCtx = avcodec_alloc_context();

            更改g_pCodecCtx的一些成員變量的值,您應該從解碼方得到這些變量值:

            g_pCodecCtx->time_base.num = 1//這兩行:一秒鐘25幀

            g_pCodecCtx
            ->time_base.den = 25;

            g_pCodecCtx
            ->bit_rate = 0//初始化為0

            g_pCodecCtx
            ->frame_number = 1//每包一個視頻幀

            g_pCodecCtx
            ->codec_type = CODEC_TYPE_VIDEO;

            g_pCodecCtx
            ->width = 704//這兩行:視頻的寬度和高度

            g_pCodecCtx
            ->height = 576;

            打開codec。如果打開成功的話,分配AVFrame:

             

            if(avcodec_open(g_pCodecCtx, pCodec) >= 0)

            {

            g_pavfFrame 
            = avcodec_alloc_frame();// Allocate video frame

            }

            列出完整的初始化解碼庫的代碼:

            image

            • 解碼

            如果您只要求解成YUV 420I數據,只需一次調用就可以了:

             

            avcodec_decode_video(g_pCodecCtx, g_pavfFrame, (int *)&nGot, (unsigned __int8 *)pSrcData, dwDataLen);

            這里,nGot用來返回解碼成功與否,avcodec_decode_video調用完成后,如果nGot不等于0,則表示解碼成功,否則未解出視頻幀。

            pSrcData是待解的H264編碼的一段數據流,dwDataLen表示該段數據流的長度,單位是byte。

            解碼后的視頻幀(YUV數據)被存入g_pavfFrame,g_pavfFrame->data[0]、g_pavfFrame->data[1]、g_pavfFrame->data[2]即是YUV數據。下面的示例代碼把YUV數據壓在了一塊內存里,排列方式為:

            YY

            YY

            U

            V

            該函數有返回值:如果解碼成功,則返回本次解碼使用的碼流字節數,否則返回0。為簡單起見,我這里假設pSrcData只包含一個視頻幀。

            同樣,出于模塊化的要求和代碼維護的方便,我把解碼動作也包在了一個函數里:

             

            BOOL H264_Decode(const PBYTE pSrcData, const DWORD dwDataLen, PBYTE pDeData, int * pnWidth, int * pnHeight)

            pSrcData – 待解碼數據

            dwDataLen – 待解碼數據字節數

            pDeData – 用來返回解碼后的YUV數據

            pnWidth, pnHeight – 用來返回視頻的長度和寬度

            下面列出完整的代碼:

            image

            • 釋放解碼器

            以上其實已經完成了本文的任務,但從負責任的角度,要善始善終嘛。

            釋放的過程沒什么好說的,一看就明白。同樣,我也把它們包在了一個函數里:

            image

            (抱歉的很,文章本來是用Word寫的,代碼塊是一個個文本框,但貼到這里卻變成了圖片。) 

            posted on 2013-01-11 00:44 楊粼波 閱讀(1811) 評論(0)  編輯 收藏 引用

            1000部精品久久久久久久久| 久久久久久人妻无码| 欧美日韩精品久久久免费观看| 久久久久久无码Av成人影院| 国产亚洲美女精品久久久2020| 国产69精品久久久久观看软件| 精品久久久久久久久中文字幕| 久久久久久久久无码精品亚洲日韩 | 久久人人爽人人爽人人片AV麻豆 | 国产精品99久久不卡| 一日本道伊人久久综合影| 日本强好片久久久久久AAA| 久久99久久99小草精品免视看| 三级片免费观看久久| 国产成人无码久久久精品一| 亚洲精品成人网久久久久久| 国产成年无码久久久久毛片| 久久一区二区三区99| 一本大道久久a久久精品综合| 一本大道久久东京热无码AV| 99久久精品国产一区二区| 日本久久久久亚洲中字幕| 中文字幕精品久久| 国产精品美女久久久免费| 久久久久99精品成人片直播| 久久亚洲精品无码aⅴ大香| 久久久精品人妻无码专区不卡 | 久久久久99精品成人片欧美 | 欧美噜噜久久久XXX| 久久99这里只有精品国产| 久久乐国产精品亚洲综合 | 中文无码久久精品| 久久人人爽人人爽人人av东京热| 久久www免费人成看国产片| 伊人久久综在合线亚洲2019 | 亚洲精品无码专区久久同性男| 久久精品成人免费网站| 九九99精品久久久久久| 久久青青草原国产精品免费| 狠狠色婷婷综合天天久久丁香| 久久精品一区二区|