Форум программистов, компьютерный форум CyberForum.ru

Конвертация фрейма в формате AAC в PCM - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Принят черновик стандарта С++14 http://www.cyberforum.ru/cpp/thread1244422.html
Черновик стандарта С++14 принят. С чем всех и поздравляю. Ждем как официальный в конце года и конечно ждем C++17. Пруф: https://isocpp.org/blog/2014/02/trip-report Краткое изложение фич: http://en.wikipedia.org/wiki/C%2B%2B14#New_language_features Статья на хабре: http://habrahabr.ru/post/233829/
C++ Опубликована программа конференции CppCon 2014 Конференция по C++, посвященная в том числе и грядущему стандарту C++14, пройдет с 7 по 12 сентября 2014 года в Вашингтоне, США. С программой конференции можно ознакомиться на официальном сайте: http://cppcon.org/conference-program/ http://www.cyberforum.ru/cpp/thread1221708.html
C++ Забиндить функцию с параметрами, чтобы она хранилась в классе и вызывалась без placeholders
Значит привет всем. Суть в кратце: хочу забиндить функцию с параметрами (кол-во произвольно), чтобы она хранилась в классе, и чтобы я мог вызвать её без placeholders. Для наилучшего понимания того что я хочу, ниже следует "псевдо-код" (разумеется не рабочий):struct function_holder { auto f; function_holder( auto f ) : f(f) {} void call() { f(); }
Размер типа C++
Такой небольшой занимательный код. #include <iostream> struct S1 { }; struct S2 { int a;
C++ Константные глобальные переменные - константные ли? http://www.cyberforum.ru/cpp/thread1075042.html
Сейчас вспомнил один момент, который остался неразрешенной для меня загадкой. Случилось это более года назад. Пытался устроиться на стажировку в Яндекс. Дали 3 задания, последнее требовало из 10000 исходников на С++ любыми средствами вытащить список глобальных переменных. При этом, в примере что они предоставили, глобальные константы за оные не считаются. Переписка: Здравствуйте, ув. XXX! ...
C++ clang начал поддерживать С++14 Привет! Вот такая новость :) Все, что реализовано можно посмотреть здесь (там снизу). Сейчас попробовал следующий код #include <iostream> int main() { int n = 0b110110110; std::cout << n << std::endl; } Работает :) ключ компиляции -std=c++1y. подробнее

Показать сообщение отдельно
castaway
Эксперт С++
4870 / 3009 / 370
Регистрация: 10.11.2010
Сообщений: 11,059
Записей в блоге: 10
Завершенные тесты: 1
22.05.2015, 10:25     Конвертация фрейма в формате AAC в PCM
А что на вход подаётся? Если есть небольшой файл то можно прикрепить.

Добавлено через 38 минут
Немого переписал, заменил deprecated функции. Ошибок нет.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include <cstdint>
#include <vector>
#include <iostream>
#include <fstream>
 
extern "C" {
 #define __STDC_CONSTANT_MACROS
 #include <libavformat/avformat.h>
 #include <libavcodec/avcodec.h>
 #include <libswscale/swscale.h>
}
 
bool load_file( std::vector <uint8_t> & buffer, const char * filename ) {
    std::ifstream file( filename, std::ios::in | std::ios::binary | std::ios::ate );
    std::streamsize size = 0;
    if ( file.seekg( 0, std::ios::end ).good() ) size = file.tellg();
    if ( file.seekg( 0, std::ios::beg ).good() ) size -= file.tellg();
    if ( size > 0 ) {
        buffer.resize( (size_t)size );
        file.read( (char *)(&buffer[0]), size );
        return true;
    }
    buffer.clear();
    return false;
}
 
bool AacToPcm( uint8_t * inBuffer, int inSize, uint8_t ** outBuffer, int * outSize ) {
 
    uint8_t * inputBytes = new uint8_t [inSize + FF_INPUT_BUFFER_PADDING_SIZE];
    memset( inputBytes, 0, inSize + FF_INPUT_BUFFER_PADDING_SIZE );
    memcpy( inputBytes, inBuffer, inSize );
 
    avcodec_register_all();
    av_register_all();
 
    bool result = false;
    AVCodec * codec = avcodec_find_decoder( AV_CODEC_ID_AAC );
    if ( codec ) {
        AVCodecContext * avCtx = avcodec_alloc_context3( codec );
        if ( avCtx ) {
            avCtx->sample_fmt       = AV_SAMPLE_FMT_S16;
            avCtx->bit_rate         = 32000;
            avCtx->sample_rate      = 48000;
            avCtx->channels         = 1;
            avCtx->channel_layout   = AV_CH_LAYOUT_MONO;
            if ( avcodec_open2( avCtx, codec, 0 ) >= 0 ) {
 
                AVPacket avPacket;
                av_init_packet( &avPacket );
                avPacket.size = inSize;
                avPacket.data = inputBytes;
 
                AVFrame * frame = av_frame_alloc();
                frame->nb_samples = avCtx->frame_size;
                frame->format = avCtx->sample_fmt;
                frame->channel_layout = avCtx->channel_layout;
                frame->sample_rate = avCtx->sample_rate;
                frame->channels = avCtx->channels;
 
                int nGotFrame = 0;
                int cbDecoded = avcodec_decode_audio4( avCtx, frame, &nGotFrame, &avPacket );
                if ( cbDecoded > 0 && nGotFrame ) {
                    int data_size = av_samples_get_buffer_size( 0,  avCtx->channels,  frame->nb_samples, avCtx->sample_fmt, 1 );
                    if ( data_size > 0 ) {
                        *outSize = data_size;
                        *outBuffer = new uint8_t [*outSize];
                        memcpy( *outBuffer, (uint8_t *)frame->data[0], *outSize );
                        result = true;
                    }
                }
                av_frame_free( &frame );
            }
            av_free( avCtx );
        }
        avcodec_close( avCtx );
    }
    delete [] inputBytes;
    return result;
}
 
int main()
{
    std::vector <uint8_t> data;
 
    if ( load_file( data, "test2.adts" ) ) {
        std::cout << data.size() << std::endl;
 
        uint8_t * out;
        int out_size;
        if ( AacToPcm( data.data(), data.size(), &out, &out_size ) ) {
            std::cout << "ok\n";
        } else {
            std::cout << "fail\n";
        }
    }
    return 0;
}
 
Текущее время: 02:36. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru