音视频项目—基于FFmpeg和SDL的音视频播放器解析(十三)

介绍

在本系列,我打算花大篇幅讲解我的 gitee 项目音视频播放器,在这个项目,您可以学到音视频解封装,解码,SDL渲染相关的知识。您对源代码感兴趣的话,请查看基于FFmpeg和SDL的音视频播放器

如果您不理解本文,可参考我的前一篇文章音视频项目---基于FFmpeg和SDL的音视频播放器解析(十二)

解析

我们到了后面,就应该播放出音频和视频了,这就了两个包,audiooutput,videooutput。我们今天解析负责播放音频的包,audiooutput。

我们先来看看 .h 文件的代码

cpp 复制代码
#ifndef AUDIOOUTPUT_H_
#define AUDIOOUTPUT_H_

#ifdef __cplusplus

extern "C"{
#include"libavutil/avutil.h"
#include"SDL.h"
#include"libswresample/swresample.h"
}

#include"avsync.h"
#include"avframequeue.h"

typedef struct AudioParams{
    int freq;
    int channels;
    int64_t channel_layout;
    enum AVSampleFormat fmt;
    int frame_size;
} AudioParams;

class AudioOutput
{
public:
    AudioOutput(AVSync* avsync, AVRational time_base, const AudioParams& audio_params, AVFrameQueue* frame_queue);
    ~AudioOutput();
    int Init();
    int DeInit();
private:
    int64_t pts = AV_NOPTS_VALUE;
    AudioParams src_tgt;
    AudioParams dst_tgt;
    AVFrameQueue* frame_queue = nullptr;
    struct SwrContext* swr_ctx = nullptr;
    uint8_t* audio_buf = nullptr;
    uint8_t* audio_buf1 = nullptr;
    uint32_t* audio_buf_size = 0;
    uint32_t* audio_buf1_size = 0;
    uint32_t* audio_buf_index = 0;
    AVSync* avsync = nullptr;
    AVRational time_base;
};

#endif

#endif

大体上看一遍,首部有 AudioParams,然后是 AudioOutput 的类。

AudioParams:
cpp 复制代码
typedef struct AudioParams{
    int freq;
    int channels;
    int64_t channel_layout;
    enum AVSampleFormat fmt;
    int frame_size;
} AudioParams;

这个结体体负责记录音频的各类参数

freq:频率

channels:频道数

channel_layout:

fmt:音频格式

frame_size:帧大小

AudioOutput:

我们先看私有成员

int64_t pts = AV_NOPTS_VALUE:显示时间戳

AudioParams src_tgt:源音频参数

AudioParams dst_tgt:目标音频参数

AVFrameQueue* frame_queue = nullptr:音频帧队列

struct SwrContext* swr_ctx = nullptr:

uint8_t* audio_buf = nullptr:音频缓冲区

uint8_t* audio_buf1 = nullptr:音频缓冲区

uint32_t* audio_buf_size = 0:音频缓冲区大小

uint32_t* audio_buf1_size = 0:音频缓冲区大小

uint32_t* audio_buf_index = 0:音频缓冲区 index

AVSync* avsync = nullptr:音视频同步

AVRational time_base:帧率

构造函数:

cpp 复制代码
AudioOutput::AudioOutput(AVSync* avsync, AVRational time_base, const AudioParams& audio_params, AVFrameQueue* frame_queue){
    this->avsync = avsync;
    this->time_base = time_base;
    this->src_tgt = audio_params;
    this->frame_queue = frame_queue;
}

将私有成员变量进行赋值

好了,今天先讲这么多,下一篇文章讲解的函数会比较多且难,大家慢慢来。

欲知后事如何,请听下回分解。

相关推荐
REDcker8 天前
WebCodecs VideoDecoder 的 hardwareAcceleration 使用
前端·音视频·实时音视频·直播·webcodecs·videodecoder
gihigo19988 天前
基于TCP协议实现视频采集与通信
网络协议·tcp/ip·音视频
山河君8 天前
四麦克风声源定位实战:基于 GCC-PHAT + 最小二乘法实现 DOA
算法·音视频·语音识别·信号处理·最小二乘法·tdoa
音视频牛哥8 天前
Android平台RTMP/RTSP超低延迟直播播放器开发详解——基于SmartMediaKit深度实践
android·人工智能·计算机视觉·音视频·rtmp播放器·安卓rtmp播放器·rtmp直播播放器
qq_416276428 天前
通用音频表征的对比学习
学习·音视频
美狐美颜sdk8 天前
Android全局美颜sdk实现方案详解
人工智能·音视频·美颜sdk·视频美颜sdk·美狐美颜sdk
EasyDSS8 天前
私有化部署EasyDSS视频点播能力:全链路视频技术赋能,打造企业级视听新体验
音视频·hls·m3u8·点播技术·智能转码
qq_416276428 天前
DeLoRes——一种通用的音频表征学习新方法(DeLoRes(基于 Barlow Twins 的冗余最小化方法)
学习·音视频
Q_4582838688 天前
从定位到视频:808 + 1078 在各行业的落地实践
音视频
山顶望月川8 天前
实测MiniMax-Hailuo-02:当“开工大吉“变成“无字天书“,国产AI视频模型的能与之不能
人工智能·音视频