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

            99久久国语露脸精品国产| 777午夜精品久久av蜜臀| 国产午夜电影久久| 亚洲人成电影网站久久| 国内精品久久久久久99| 欧美一级久久久久久久大片| 99久久人妻无码精品系列蜜桃| 久久99精品久久久久久噜噜| 亚洲精品国精品久久99热一| 久久成人18免费网站| 久久99精品国产麻豆| 精品综合久久久久久88小说| 国产成人综合久久综合| 久久久久波多野结衣高潮| 国产人久久人人人人爽| 武侠古典久久婷婷狼人伊人| 嫩草影院久久99| 久久婷婷激情综合色综合俺也去| 99热都是精品久久久久久| 精品综合久久久久久98| 日本精品一区二区久久久| 99久久婷婷国产一区二区 | 国产精品久久久久jk制服| 亚洲Av无码国产情品久久| 狠狠人妻久久久久久综合| 77777亚洲午夜久久多喷| 久久精品一本到99热免费| 久久天天躁夜夜躁狠狠躁2022| 久久一本综合| 精品久久久久久无码中文字幕| 久久99热精品| 久久精品国产福利国产秒| 国产精品久久国产精麻豆99网站| 久久综合国产乱子伦精品免费| 久久亚洲美女精品国产精品| 亚洲精品乱码久久久久久自慰| 狠狠色婷婷久久一区二区| 人妻无码久久一区二区三区免费| 麻豆精品久久久久久久99蜜桃 | 久久久久久国产精品美女| 五月丁香综合激情六月久久|