【C语言ffmpeg】打开第一个视频
文章目录
- 前言
- 须知
- ffmpeg打开文件基本流程图
- ffmpeg打开媒体文件
- `AVFormatContext *avformat_alloc_context(void);`
- AVFormatContext 成员变量及其作用
- `AVInputFormat *iformat`
- `AVOutputFormat *oformat`
- `void *priv_data`
- `AVIOContext *pb`
- `unsigned int nb_streams`
- `AVStream **streams`
- `char filename[1024]`
- `int64_t duration`
- `int64_t bit_rate`
- `unsigned int nb_programs`
- `AVProgram **programs`
- `AVChapter **chapters`
- `unsigned int nb_chapters`
- `AVDictionary *metadata`
- `int flags`
- `int64_t start_time`
- `int64_t start_time_realtime`
- `int probesize`
- `int max_analyze_duration`
- `AVPacketList *packet_buffer`
- `int avformat_open_input(AVFormatContext **ps, const char *filename, AVInputFormat *fmt, AVDictionary **options);`
- `int avformat_find_stream_info(AVFormatContext *ic, AVDictionary **options);`
- `void av_dump_format(AVFormatContext *ic, int index, const char *url, int is_output);`
- `AVCodec *avcodec_find_decoder(enum AVCodecID id);`
- `const char *avcodec_get_name(enum AVCodecID id);`
- `const char *av_get_media_type_string(enum AVMediaType media_type);`
- `void avformat_close_input(AVFormatContext **s);`
- 示例
- 总结
前言
FFmpeg 是一个强大的多媒体处理库,广泛应用于音视频编解码、转换和流媒体处理等领域。C语言作为一种底层编程语言,与FFmpeg结合使用,可以高效地处理各种音视频任务。在本篇文章中,我们将探讨如何利用C语言和FFmpeg库打开一个音视频文件,并对其进行基本的处理操作。这不仅为深入学习FFmpeg的使用打下基础,也为从事多媒体处理工作的开发者提供实用的参考。
须知
本教程使用ffmpeg版本为7.0.1如有函数不同请下载和我一样的版本
ffmpeg打开文件基本流程图
开始↓
包含头文件和定义视频文件路径↓
分配格式上下文↓
打开输入文件↓
|----------------------|
| 打开失败 |
| ↓ |
| 打印错误信息并返回 |
|----------------------|↓
检查文件中的流信息↓
|----------------------|
| 检查失败 |
| ↓ |
| 打印错误信息并关闭文件 |
|----------------------|↓
打印文件格式信息↓
遍历所有流↓
获取流和编解码参数↓
查找解码器↓
打印流的基本信息↓
|----------------------|
| 没有找到解码器 |
| ↓ |
| 打印不支持的编解码器 |
|----------------------|↓
关闭输入文件并释放格式上下文↓
结束
ffmpeg打开媒体文件
AVFormatContext *avformat_alloc_context(void);
- 作用: 分配并初始化
AVFormatContext结构体。 - 参数: 无。
- 返回值: 指向新分配的
AVFormatContext的指针。
AVFormatContext 结构体是 FFmpeg 中非常重要的一个数据结构,它包含了与多媒体文件或流相关的所有信息。以下是一些常用且重要的成员及其作用:
AVFormatContext 成员变量及其作用
AVInputFormat *iformat
- 作用: 指向输入格式的指针。当打开输入文件时,这个成员将指向描述文件格式的
AVInputFormat结构。
AVOutputFormat *oformat
- 作用: 指向输出格式的指针。当创建输出文件时,这个成员将指向描述文件格式的
AVOutputFormat结构。
void *priv_data
- 作用: 私有数据,存储特定于输入/输出格式的私有数据。
AVIOContext *pb
- 作用: I/O 上下文,用于管理文件或流的输入/输出操作。
unsigned int nb_streams
- 作用: 文件中的流数量。
AVStream **streams
- 作用: 指向包含所有流(音频、视频、字幕等)的指针数组。
char filename[1024]
- 作用: 文件名或 URL。
int64_t duration
- 作用: 文件的总时长(以 AV_TIME_BASE 为单位)。
int64_t bit_rate
- 作用: 文件的总比特率(以比特每秒为单位)。
unsigned int nb_programs
- 作用: 文件中节目的数量。
AVProgram **programs
- 作用: 指向包含所有节目的指针数组。
AVChapter **chapters
- 作用: 指向包含所有章节的指针数组。
unsigned int nb_chapters
- 作用: 文件中的章节数量。
AVDictionary *metadata
- 作用: 文件的元数据(如标题、作者、版权等)。
int flags
- 作用: 标志位,用于控制各种操作行为。
int64_t start_time
- 作用: 文件的开始时间(以 AV_TIME_BASE 为单位)。
int64_t start_time_realtime
- 作用: 以实时起始时间的时间戳表示的开始时间。
int probesize
- 作用: 探测的大小,用于确定文件的格式。
int max_analyze_duration
- 作用: 分析的最大时长,用于确定文件的格式。
AVPacketList *packet_buffer
- 作用: 包含读取的数据包的缓冲区。
以下示例展示如何访问 AVFormatContext 的一些成员变量:
AVFormatContext *formatContext = avformat_alloc_context();
if (avformat_open_input(&formatContext, "example.mp4", NULL, NULL) == 0) {printf("Format: %s\n", formatContext->iformat->name);printf("Number of streams: %u\n", formatContext->nb_streams);printf("Duration: %" PRId64 "\n", formatContext->duration);printf("Bit rate: %" PRId64 "\n", formatContext->bit_rate);for (unsigned int i = 0; i < formatContext->nb_streams; i++) {AVStream *stream = formatContext->streams[i];printf("Stream #%u\n", i);printf(" Codec ID: %d\n", stream->codecpar->codec_id);printf(" Codec type: %s\n", av_get_media_type_string(stream->codecpar->codec_type));}avformat_close_input(&formatContext);
}
int avformat_open_input(AVFormatContext **ps, const char *filename, AVInputFormat *fmt, AVDictionary **options);
- 作用: 打开输入文件并读取头部信息。
- 参数:
ps: 指向AVFormatContext指针的指针。filename: 文件名。fmt: 指定输入格式,可以为 NULL。options: 一些额外的选项,可以为 NULL。
- 返回值: 成功返回 0,失败返回负值。
int avformat_find_stream_info(AVFormatContext *ic, AVDictionary **options);
- 作用: 检查文件中的流信息。
- 参数:
ic:AVFormatContext指针。options: 一些额外的选项,可以为 NULL。
- 返回值: 成功返回非负值,失败返回负值。
void av_dump_format(AVFormatContext *ic, int index, const char *url, int is_output);
- 作用: 打印文件格式信息。
- 参数:
ic:AVFormatContext指针。index: 要打印的流的索引,为 0 表示打印全部流信息。url: 文件的 URL。is_output: 指示是输入还是输出格式,0 表示输入,1 表示输出。
- 返回值: 无。
AVCodec *avcodec_find_decoder(enum AVCodecID id);
- 作用: 查找给定 codec id 的解码器。
- 参数:
id: codec 的 ID。
- 返回值: 指向
AVCodec的指针,如果未找到返回 NULL。
const char *avcodec_get_name(enum AVCodecID id);
- 作用: 获取 codec id 对应的 codec 名称。
- 参数:
id: codec 的 ID。
- 返回值: codec 名称的字符串指针。
const char *av_get_media_type_string(enum AVMediaType media_type);
- 作用: 获取媒体类型的字符串表示。
- 参数:
media_type: 媒体类型。
- 返回值: 媒体类型名称的字符串指针。
void avformat_close_input(AVFormatContext **s);
- 作用: 关闭输入文件并释放格式上下文。
- 参数:
s: 指向AVFormatContext指针的指针。
- 返回值: 无。
示例
#include <stdio.h>
#include "include/libavcodec/avcodec.h"
#include "include/libavformat/avformat.h"
#include "include/libavutil/avutil.h"int main() {const char *videoname = "/home/ubuntu/MyFFMPEG/template_c_first/test2.mp4";//打开输入文件并读取头部信息AVFormatContext *formatContext = avformat_alloc_context();if(avformat_open_input(&formatContext,videoname,NULL,NULL) != 0){printf("open err:%s\n",videoname);return -1;}// 检查文件中的流信息if (avformat_find_stream_info(formatContext, NULL) < 0) {printf("Could not find stream information in file %s\n", videoname);avformat_close_input(&formatContext);return -1;}// 打印文件格式信息av_dump_format(formatContext, 0, videoname, 0);// 遍历所有流并打印流信息for (unsigned int i = 0; i < formatContext->nb_streams; i++) {AVStream *stream = formatContext->streams[i];AVCodecParameters *codecParams = stream->codecpar;AVCodec *codec = avcodec_find_decoder(codecParams->codec_id);if (codec == NULL) {printf("Unsupported codec!\n");continue;}printf("Stream #%u:\n", i);printf(" Codec: %s (%s)\n", codec->name, avcodec_get_name(codecParams->codec_id));printf(" Type: %s\n", av_get_media_type_string(codecParams->codec_type));printf(" Duration: %ld\n", stream->duration);printf(" Time base: %d/%d\n", stream->time_base.num, stream->time_base.den);}// 关闭输入文件并释放格式上下文avformat_close_input(&formatContext);return 0;
}
输出:
ubuntu@ubuntu-virtual-machine:~/MyFFMPEG/template_c_first/build$ ./ffmpeg_test
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '/home/ubuntu/MyFFMPEG/template_c_first/test2.mp4':Metadata:major_brand : isomminor_version : 512compatible_brands: isomiso2avc1mp41encoder : Lavf61.1.100description : Packed by Bilibili XCoder v2.0.2Duration: 00:00:30.07, start: 0.000000, bitrate: 3275 kb/sStream #0:0[0x1](und): Video: h264 (High) (avc1 / 0x31637661), yuv420p(tv, bt709, progressive), 1920x1080 [SAR 1:1 DAR 16:9], 3124 kb/s, 60 fps, 60 tbr, 16k tbn (default)Metadata:handler_name : Bento4 Video Handlervendor_id : [0][0][0][0]Stream #0:1[0x2](und): Audio: aac (LC) (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 135 kb/s (default)Metadata:handler_name : Bento4 Sound Handlervendor_id : [0][0][0][0]
Stream #0:Codec: h264 (h264)Type: videoDuration: 481066Time base: 1/16000
Stream #1:Codec: aac (aac)Type: audioDuration: 1323000Time base: 1/44100
总结
通过本文的介绍,我们了解了如何使用C语言结合FFmpeg库来打开一个音视频文件,并对其进行基本处理。FFmpeg提供了丰富的功能和灵活的接口,能够满足各种多媒体处理需求。掌握FFmpeg的使用方法,不仅能够提升我们在多媒体领域的开发效率,还能拓宽我们的技术视野。希望本篇文章能为读者提供有益的帮助,激发进一步探索FFmpeg和多媒体处理技术的兴趣。
相关文章:
【C语言ffmpeg】打开第一个视频
文章目录 前言须知ffmpeg打开文件基本流程图ffmpeg打开媒体文件AVFormatContext *avformat_alloc_context(void);AVFormatContext 成员变量及其作用AVInputFormat *iformatAVOutputFormat *oformatvoid *priv_dataAVIOContext *pbunsigned int nb_streamsAVStream **streamscha…...
【Langchain大语言模型开发教程】模型、提示和解析
🔗 LangChain for LLM Application Development - DeepLearning.AI 学习目标 1、使用Langchain实例化一个LLM的接口 2、 使用Langchain的模板功能,将需要改动的部分抽象成变量,在具体的情况下替换成需要的内容,来达到模板复用效…...
Flutter 中的基本数据类型:num、int 和 double
在 Dart 编程语言中,数值类型的基础是 num,而 int 和 double 则是 num 的子类型。在开发 Flutter 应用时,理解这三者的区别和使用场景是非常重要的。本文将详细介绍 num、int 和 double 的定义及其使用区别。 num num 是 Dart 中的数值类型…...
基于Python+Django,开发的一个在线教育系统
一、项目简介 使用Python的web框架Django进行开发的一个在线教育系统! 二、所需要的环境与组件 Python3.6 Django1.11.7 Pymysql Mysql pure_pagination DjangoUeditor captcha xadmin crispy_forms 三、安装 1. 下载项目后进入项目目录cd Online-educ…...
密码学原理精解【9】
这里写目录标题 迭代密码概述SPN具体算法过程SPN算法基本步骤举例说明注意 轮换-置换网络一、定义与概述二、核心组件三、加密过程四、应用实例五、总结 轮函数理论定义与作用特点与性质应用实例总结 迭代密码理论定义与原理特点与优势应用场景示例发展趋势 AES特点概述一、算法…...
【Nacos】Nacos服务注册与发现 心跳检测机制源码解析
在前两篇文章,介绍了springboot的自动配置原理,而nacos的服务注册就依赖自动配置原理。 Nacos Nacos核心功能点 服务注册 :Nacos Client会通过发送REST请求的方式向Nacos Server注册自己的服务,提供自身的元数据,比如ip地址、端…...
python 66 个冷知识 0720
66个有趣的Python冷知识 一行反转列表 使用切片一行反转列表:reversed_list my_list[::-1] 统计文件单词数量 使用 collections.Counter 统计文件中每个单词的数量:from collections import Counter; with open(file.txt) as f: word_count Counter(f…...
利用PyTorch进行模型量化
利用PyTorch进行模型量化 目录 利用PyTorch进行模型量化 一、模型量化概述 1.为什么需要模型量化? 2.模型量化的挑战 二、使用PyTorch进行模型量化 1.PyTorch的量化优势 2.准备工作 3.选择要量化的模型 4.量化前的准备工作 三、PyTorch的量化工具包 1.介…...
Android 小白菜鸟从入门到精通教程
前言 Android一词最早出现于法国作家利尔亚当(Auguste Villiers de l’Isle-Adam)在1886年发表的科幻小说《未来的夏娃》(L’ve future)中。他将外表像人的机器起名为Android。从初学者的角度出发,通过通俗易懂的语言…...
php相关
php相关 借鉴了小迪安全以及各位大佬的博客,如果一切顺利,会不定期更新。 如果感觉不妥,可以私信删除。 默认有php基础。 文章目录 php相关1. php 缺陷函数1. 与2. MD53. intval()4. preg_match() 2. php特性1. php字符串解析特性2. 杂…...
uniapp上传功能用uni-file-picker实现
文章目录 html代码功能实现css样式代码 html代码 <uni-file-pickerselect"onFileSelected"cancel"onFilePickerCancel"limit"1"class"weightPage-upload-but"file-mediatype"image"></uni-file-picker><imag…...
【PPT笔记】1-3节 | 默认设置/快捷键/合并形状
文章目录 说明笔记1 默认设置1.1 OFFICE版本选择1.1.1 Office某某数字专属系列1.1.2 Office3651.1.3 产品信息怎么看 1.2 默认设置1.2.1 暗夜模式1.2.2 无限撤回1.2.3 自动保存(Office2013版本及以上)1.2.4 图片压缩1.2.5 字体嵌入1.2.6 多格式导出1.2.7…...
Qt中的高分辨率及缩放处理
写在前面 使用Qt开发界面客户端,需要考虑不同分辨率及缩放对UI界面的影响,否则会影响整体的交互使用。 问题 高分辨率/缩放设备上图片/图标模糊 若不考虑高分辨及缩放处理,在高分辨率/缩放设备上,软件中的图片、图标可能会出现…...
电机泵盖机器人打磨去毛刺,选德国进口高精度主轴
机器人打磨去毛刺该如何选择主轴呢?首先我们需要考虑的是工件的材质,电机泵盖通常使用铸铁、不锈钢、合金钢等金属材质,因此这类保持的硬度较高,一般会选择功率、扭矩较大的德国进口高精度主轴Kasite 4060 ER-S。 Kasite 4060 ER-…...
Android init.rc各阶段的定义和功能
Android开机优化系列文档-CSDN博客 Android 14 开机时间优化措施汇总-CSDN博客Android 14 开机时间优化措施-CSDN博客根据systrace报告优化系统时需要关注的指标和优化策略-CSDN博客Android系统上常见的性能优化工具-CSDN博客Android上如何使用perfetto分析systrace-CSDN博客A…...
.net dataexcel 脚本公式 函数源码
示例如: ScriptExec(""sum(1, 2, 3, 4)"") 结果等于10 using Feng.Excel.Builder; using Feng.Excel.Collections; using Feng.Excel.Interfaces; using Feng.Script.CBEexpress; using Feng.Script.Method; using System; using System.Collections.Gen…...
HarmonyOS ArkUi @CustomDialog 和promptAction.openCustomDialog踩坑以及如何选择
CustomDialog 内使用Link,如何正常使用 错误使用方式: 定义一个函数,在函数内使用弹窗,如下面代码showDialog: 这种使用方式,无法在自定义的CustomDialog内使用 Link,进行父子双向绑定&#x…...
Python面试题:详细讲解Python的多线程与多进程编程问题
在 Python 中,多线程和多进程编程是并发编程的两种主要方式,用于提高程序的执行效率和响应性。虽然它们都可以实现并发执行,但它们的工作原理和适用场景有所不同。以下是对 Python 多线程和多进程编程的详细讲解,包括它们的工作原…...
前端Canvas入门——用canvas写五子棋?
前言 五子棋的实现其实不难,因为本身就是一个很小的游戏。 至于画线什么的,其实很简单,都是lineTo(),moveTo()就行了。 难的在于——怎么让棋子落入到指定的格子上,怎么判断连子胜利。 当然啦,这部分是…...
[PaddlePaddle飞桨] PaddleDetection-通用目标检测-小模型部署
PaddleDetection的GitHub项目地址 推荐环境: PaddlePaddle > 2.3.2 OS 64位操作系统 Python 3(3.5.1/3.6/3.7/3.8/3.9/3.10),64位版本 pip/pip3(9.0.1),64位版本 CUDA > 10.2 cuDNN > 7.6pip下载指令: python -m pip i…...
实战驱动:告诉快马你的vue项目类型,获取量身定制的环境与示例
最近在做一个Vue 3移动端H5项目时,发现环境配置和基础搭建特别耗时。经过几次实践,我总结出了一套高效的项目初始化方法,今天就来分享这个实战经验。 项目初始化与移动端适配 使用Vue CLI创建项目后,首先要解决的就是移动端适配问…...
AI性能测试:TPS之外还要关注什么?
在AI驱动的时代,性能测试已成为软件测试从业者的核心技能。传统软件测试中,TPS(Transactions Per Second,每秒事务处理量)常被视为黄金指标,用于衡量系统的吞吐能力。然而,AI系统因其独特的计算…...
二分查找/二分答案
0.前言二分算法(Binary Search),也叫折半查找,是一种在有序数据集合中高效查找目标值的算法。它通过不断将查找范围缩小一半,快速定位目标,时间复杂度为 O(logn),远优于线性查找的 O(n)。1.原理…...
对抗训练新玩法:用AdverIN攻击自己反而提升医学分割模型20%泛化性
医学影像分割的对抗训练革命:AdverIN如何让模型在新设备上表现更优 医学影像分析领域正面临一个尴尬的现实:实验室里表现优异的深度学习模型,在真实临床环境中常常"水土不服"。不同医院使用的扫描设备、成像协议差异导致的域偏移&a…...
JVM中的各种垃圾回收算法
什么情况下JVM内存中的一个对象被垃圾回收被哪些变量引用的对象是不能回收的?JVM使用了一种可达性算法来判断哪些对象可以被回收哪些对象不可以被回收。这个算法的意思,就是说对每个对象,都分析一下有谁在引用他,然后一层一层去判…...
N诺机试题
2.整除(末尾无空格用printf“ ”)#include<stdio.h>int main(){int count0;for(int i100;i<1000;i){if(i%50&&i%60){printf("%d",i);count;if(count%100) printf("\n");else printf(" "); }}return 0;…...
java的for循环
public class Demo6 {public static void main(String[] args) {for (int money1;money<10;money){System.out.println("换一元纸币"money"张。换5角硬币"(10-money)*2"个");}} }public class Demo8 {public static void main(String[] args)…...
刷题无效、偏科严重?脑能模型解构 K12 学习底层能力问题
一、问题定义:K12 学习低效的核心并非知识缺口,而是大脑能力结构断链在 K12 家庭教育场景中,刷题耗时但效率无提升、偏科补学却差距扩大、孩子拖延喊不动、学习焦虑厌学等问题成为普遍痛点,多数家长将其归因于孩子智商、天赋或学习…...
如何突破英雄联盟操作效率瓶颈?League-Toolkit的5大革新功能解析
如何突破英雄联盟操作效率瓶颈?League-Toolkit的5大革新功能解析 【免费下载链接】League-Toolkit 兴趣使然的、简单易用的英雄联盟工具集。支持战绩查询、自动秒选等功能。基于 LCU API。 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 在快…...
so-vits-svc声压级标准化终极指南:避免音质损伤的10个关键步骤
so-vits-svc声压级标准化终极指南:避免音质损伤的10个关键步骤 【免费下载链接】so-vits-svc SoftVC VITS Singing Voice Conversion 项目地址: https://gitcode.com/gh_mirrors/so/so-vits-svc 你是否在使用so-vits-svc进行语音转换时,遇到过输出…...
