美文网首页
视频像素格式转换与音频重采样

视频像素格式转换与音频重采样

作者: 贝克街的猫大哥呀 | 来源:发表于2018-07-06 16:29 被阅读0次

现在我们已经解码出了每一帧,这里可以是音频帧,也可以是视频帧。

这些帧需要转换成我们需要的样子,比如转成RGB、YUV420P等等之类的。音频帧我们要转换成PCM格式等等。

首先我们需要引入这几包

#include <libswscale/swscale.h>

#include <libswresample/swresample.h>

很明显嘛,上面是像素格式转换的,下面的音频重采样的。

先说说视频,可以先定义出上下文以及输出的像素:

//初始化像素格式转换上下文

SwsContext *vctx =NULL;  //在解析出每一帧时,才初始化

//定义输出像素

int outWidth =1280;

int outHeight =720;

char *rgb =new char[1920 *1280 *4];

当解析出某帧以后,也就是说,得到了某帧frame并且该帧为视频帧时执行以下代码。

这里才会给vctx赋值,注意,上一篇我们讲到,我们会在一个for循环里接收解析过的frame,也就是说,这段代码会写在循环当中,就是说sws_getCachedContext会执行多次。但如果参数不变,无论sws_getCachedContext执行多少次,都会返回相同的对象。因此并不会有性能问题。

关键方法为:sws_scale 返回的是输出像素的高度

vctx = sws_getCachedContext(vctx,frame->width,frame->height,(AVPixelFormat) frame->format,//输入的帧格式

outWidth,outHeight,

AV_PIX_FMT_RGBA,//输出的RGBA的像素格式

SWS_FAST_BILINEAR,//采用快速线性算法转换

 0,0,0

    );

if (!vctx) {

LOGW("sws_getCachedContext failed");

}else {

//输出格式上文成功获取后,开始这个转换流程!

//data为输出的视频数据

uint8_t *data[AV_NUM_DATA_POINTERS] = {0};

data[0] = (uint8_t *) rgb;

int lines[AV_NUM_DATA_POINTERS] = {0};

lines[0] = outWidth *4;

int h = sws_scale(vctx,(const uint8_t **) frame->data,frame->linesize,0,frame->height,data, lines);

LOGW("已经完成了像素转换,输出的:sws_scale = %d", h);

}

}

这里的data就是最终输出的像素数据。

现在讲讲音频,跟视频的套路还有点不一样,视频是获得帧时才初始化,音频是一开始就能定义。这里设置了双

//音频重采样上下文初始化

SwrContext *actx = swr_alloc();

char *pcm =new char[48000 *4 *2]; //双通道

actx = swr_alloc_set_opts(actx,av_get_default_channel_layout(2),AV_SAMPLE_FMT_S16, ac>sample_rate,av_get_default_channel_layout(ac->channels),

ac->sample_fmt, ac->sample_rate,0,0);

//正初化音频

re = swr_init(actx);

if (re !=0) {

LOGW("swr_init failed,reason:%s",av_err2str(re));

}else {

LOGW("swr_init success!");

}

依然是获得每一音频帧的时候,再开启重采样。关键方法为:swr_convert,返回的是单通道采样数。

//音频 out为输出的音频数据

uint8_t *out[2] = {0};

out[0] = (uint8_t *) pcm;

//音频重采样

int len = swr_convert(actx,out,frame->nb_samples,(const uint8_t **) frame->data,frame->nb_samples);

LOGW("已完成音频重采样swr_convert = %d", len);

相关文章

  • 视频像素格式转换与音频重采样

    现在我们已经解码出了每一帧,这里可以是音频帧,也可以是视频帧。 这些帧需要转换成我们需要的样子,比如转成RGB、Y...

  • (四)Android通过ffmpeg解码音频

    音频解码与视频解码的流程大致相同,唯一的区别只有处理帧数据的时候,视频是像素转换并显示,而音频则是重采样并播放。所...

  • 音频重采样ffmpeg(九)

    前言 广义的音频重采样包括:1、采样格式转化:比如采样格式从16位整形变为浮点型2、采样率的转换:降采样和升采样,...

  • ffmpeg之-音频重采样(七)

    前言 广义的音频重采样包括:1、采样格式转化:比如采样格式从16位整形变为浮点型2、采样率的转换:降采样和升采样,...

  • 音频重采样

    音频重采样的概念(Audio Resample) 将一个音频X,更改X的采样率、采样格式、声道数等参数,最终转换成...

  • FFmpeg音频解码

    FFmpeg音频解码和上一章的视频解码流程差不多。区别在视频有像素格(YUV RGB)式而音频有采样格式(PCM ...

  • FFmpeg音频重采样

    一、什么是音频重采样 音频重采样就是改变音频的采样率、采样格式、声道数等参数,使之按照我们期望的参数输出。比如我们...

  • 12_采样格式&音频重采样

    采样格式 通过前面学习我们知道FFmpeg和SDL都有自己的采样格式的表达式,那么他们都表示什么意思呢?FFmpe...

  • Android:使用FFmpeg对音频进行重采样

    在音频开发中,音频重采样是一个比较复杂的操作。假设有一个采样率为44100的音频,将其转换成采样率为32000的音...

  • FFmpeg实践记录八:【实战】音频编码---上

    请注意以下命令/事例均基于Mac环境 音频重采样 音频重采样(代码)

网友评论

      本文标题:视频像素格式转换与音频重采样

      本文链接:https://www.haomeiwen.com/subject/mffbuftx.html