• <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>
            Cpper
            C/C++高級工程師 Android高級軟件工程師 IT集成工程師 音頻工程師 熟悉c,c++,java,c#,py,js,asp等多種語言 程序猿
            static void audio_encode(const char *filename)
            {
                AVCodec *codec;
                AVCodecContext *c = NULL;
                int frame_size, i, j, out_size, outbuf_size;
                FILE *f;
                short *samples;
                float t, tincr;
                uint8_t *outbuf;

                codec = avcodec_find_encoder(CODEC_ID_MP2);
                if(!codec)
                {
                    fprintf(stderr, "codec not found\n");
                    exit(1);
                }

                c = avcodec_alloc_context3(codec);

                c->bit_rate = 64000;
                c->sample_rate = 44100;
                c->channels = 1;
                c->sample_fmt = AV_SAMPLE_FMT_S16;

                if(avcodec_open(c, codec) < 0)
                {
                    fprintf(stderr, "could not open codec\n");
                    exit(1);
                }

                frame_size = c->frame_size;
                samples = malloc(frame_size * 2 * c->channels);
                outbuf_size = 10000;
                outbuf = malloc(outbuf_size);

                f = fopen(filename, "wb");
                if(!f)
                {
                    fprintf(stderr, "could not open %s\n", filename);
                    exit(1);
                }

                /* encode a single tone sound */
                t = 0;
                tincr = 2 * M_PI * 440.0 / c->sample_rate;
                for(i=0;i<200;i++) {
                    for(j=0;j<frame_size;j++) {
                        samples[2*j] = (int)(sin(t) * 10000);
                        samples[2*j+1] = samples[2*j];
                        t += tincr;
                    }
                    /* encode the samples */
                    out_size = avcodec_encode_audio(c, outbuf, outbuf_size, samples);
                    fwrite(outbuf, 1, out_size, f);
                }
                fclose(f);
                free(outbuf);
                free(samples);
                avcodec_close(c);
                av_free(c);
            }
            posted on 2012-01-10 21:31 ccsdu2009 閱讀(2238) 評論(2)  編輯 收藏 引用
            Comments
            • # re: 使用FFMPEG音頻編碼
              lc
              Posted @ 2012-03-18 17:26
              CODEC_ID_MP2
              我編譯的一個版本回報can‘t find codec
              請問一下,這是什么原因
              謝謝  回復  更多評論   
            • # re: 使用FFMPEG音頻編碼
              clonelyer
              Posted @ 2012-03-27 19:57
              @lc
              估計是你編譯avcodec.dll的時候沒有選mp2的編碼器  回復  更多評論   
             
            国产精品18久久久久久vr| 伊人热人久久中文字幕| 99久久亚洲综合精品网站| 久久精品中文字幕一区| 天天综合久久一二三区| 精品一二三区久久aaa片| 午夜精品久久久久久毛片| 国产成人精品白浆久久69| 91亚洲国产成人久久精品| 久久久久久久91精品免费观看| 久久久久国产精品人妻| 国产精品女同一区二区久久| 国产成人无码精品久久久免费| 要久久爱在线免费观看| 色综合久久久久久久久五月| 久久国产精品一区| 午夜天堂av天堂久久久| 国产三级观看久久| 久久久久四虎国产精品| 69久久精品无码一区二区| 一本一本久久a久久综合精品蜜桃| 99久久国产免费福利| 久久婷婷综合中文字幕| 久久99久久99精品免视看动漫| 无码超乳爆乳中文字幕久久 | 久久青青草原亚洲av无码app | 久久久无码精品午夜| 国产免费久久精品丫丫| 久久天天躁狠狠躁夜夜2020| 久久se精品一区二区影院 | 亚洲AV无码成人网站久久精品大| 亚洲天堂久久久| 久久久久成人精品无码中文字幕 | 久久综合综合久久狠狠狠97色88| 亚洲综合伊人久久综合| 久久亚洲国产欧洲精品一| 久久99精品久久久久久齐齐| 久久久久国产精品人妻| 久久久青草青青亚洲国产免观| 久久久久久av无码免费看大片| 亚洲?V乱码久久精品蜜桃|