• <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 楊粼波 閱讀(1814) 評論(0)  編輯 收藏 引用

            很黄很污的网站久久mimi色| 久久青青草原亚洲av无码| 久久99国产精品成人欧美| 国产精品无码久久综合| 色88久久久久高潮综合影院| 久久夜色精品国产亚洲| 婷婷久久五月天| 无码乱码观看精品久久| 久久久WWW成人| 久久人妻少妇嫩草AV蜜桃| 久久久久久久久久久免费精品| 热久久这里只有精品| 国产69精品久久久久99| 精品久久久无码中文字幕天天| 国产福利电影一区二区三区久久久久成人精品综合 | 中文字幕热久久久久久久| 91精品国产高清91久久久久久| 久久99国产精品尤物| 久久亚洲综合色一区二区三区| 精品乱码久久久久久久| 国产成人精品久久亚洲| 欧美激情精品久久久久久久| 久久人妻AV中文字幕| 久久精品人人槡人妻人人玩AV| 99久久无码一区人妻a黑| 婷婷综合久久狠狠色99h| 狠狠精品干练久久久无码中文字幕| 久久久久久毛片免费看| 久久久久亚洲精品日久生情| 婷婷久久香蕉五月综合加勒比| 九九久久99综合一区二区| 无码精品久久一区二区三区| 久久亚洲日韩精品一区二区三区| 亚洲成人精品久久| 久久精品一区二区三区AV| 四虎国产精品免费久久5151 | 亚洲精品国产字幕久久不卡| 99久久无色码中文字幕| 久久久久久无码国产精品中文字幕 | 久久精品国产亚洲精品| 狠狠色婷婷久久一区二区|