ubuntu中 使用C++ FFmpeg拉取RTSP视频流

news/2025/2/9 8:27:37 标签: ffmpeg, ubuntu, c++

在C++中使用FFmpeg拉取RTSP视频流涉及多个步骤,包括初始化FFmpeg库、打开RTSP流、读取帧数据等。以下是一个简单的示例代码,展示如何使用FFmpeg库拉取RTSP视频流并解码视频帧。

1. 安装FFmpeg库

首先,确保你已经安装了FFmpeg库。你可以通过以下命令在Ubuntu上安装FFmpeg开发库:

sudo apt-get install libavformat-dev libavcodec-dev libavutil-dev libswscale-dev

2. 示例代码

extern "C" {
#include <libavformat/avformat.h>
#include <libavcodec/avcodec.h>
#include <libswscale/swscale.h>
}

#include <iostream>

int main() {
// 初始化FFmpeg库
av_register_all();
avformat_network_init();

AVFormatContext* formatContext = avformat_alloc_context();
if (!formatContext) {
std::cerr << "Could not allocate format context" << std::endl;
return -1;
}

// 打开RTSP流
const char* rtspUrl = "rtsp://your_rtsp_stream_url";
if (avformat_open_input(&formatContext, rtspUrl, nullptr, nullptr) != 0) {
std::cerr << "Could not open RTSP stream" << std::endl;
return -1;
}

// 获取流信息
if (avformat_find_stream_info(formatContext, nullptr) < 0) {
std::cerr << "Could not find stream information" << std::endl;
return -1;
}

// 查找视频流
int videoStreamIndex = -1;
for (unsigned int i = 0; i < formatContext->nb_streams; i++) {
if (formatContext->streams[i]->codecpar->codec_type == AVMEDIA_TYPE_VIDEO) {
videoStreamIndex = i;
break;
}
}

if (videoStreamIndex == -1) {
std::cerr << "Could not find video stream" << std::endl;
return -1;
}

// 获取视频流的编解码器参数
AVCodecParameters* codecParameters = formatContext->streams[videoStreamIndex]->codecpar;

// 查找解码器
AVCodec* codec = avcodec_find_decoder(codecParameters->codec_id);
if (!codec) {
std::cerr << "Unsupported codec" << std::endl;
return -1;
}

// 创建解码器上下文
AVCodecContext* codecContext = avcodec_alloc_context3(codec);
if (!codecContext) {
std::cerr << "Could not allocate codec context" << std::endl;
return -1;
}

// 将编解码器参数复制到解码器上下文
if (avcodec_parameters_to_context(codecContext, codecParameters) < 0) {
std::cerr << "Could not copy codec parameters to context" << std::endl;
return -1;
}

// 打开解码器
if (avcodec_open2(codecContext, codec, nullptr) < 0) {
std::cerr << "Could not open codec" << std::endl;
return -1;
}

// 分配帧和包
AVFrame* frame = av_frame_alloc();
AVPacket* packet = av_packet_alloc();
if (!frame || !packet) {
std::cerr << "Could not allocate frame or packet" << std::endl;
return -1;
}

// 读取帧
while (av_read_frame(formatContext, packet) >= 0) {
if (packet->stream_index == videoStreamIndex) {
// 解码视频帧
if (avcodec_send_packet(codecContext, packet) == 0) {
while (avcodec_receive_frame(codecContext, frame) == 0) {
// 在这里处理解码后的帧(frame)
std::cout << "Decoded frame: " << frame->pts << std::endl;
}
}
}
av_packet_unref(packet);
}

// 释放资源
av_frame_free(&frame);
av_packet_free(&packet);
avcodec_free_context(&codecContext);
avformat_close_input(&formatContext);
avformat_free_context(formatContext);

return 0;
}

3. 编译代码

使用以下命令编译代码:

g++ -o rtsp_stream rtsp_stream.cpp -lavformat -lavcodec -lavutil -lswscale

4. 运行程序

运行编译后的程序:

./rtsp_stream

5. 代码说明

  • avformat_open_input:打开RTSP流。
  • avformat_find_stream_info:获取流信息。
  • avcodec_find_decoder:查找解码器。
  • avcodec_open2:打开解码器。
  • av_read_frame:读取帧数据。
  • avcodec_send_packetavcodec_receive_frame:解码视频帧。

6. 注意事项

  • 确保RTSP URL正确。
  • 处理解码后的帧时,可以根据需要进行进一步处理,如显示、保存等。
  • 在实际应用中,可能需要处理更多的错误情况和资源管理。

通过以上步骤,你可以在C++中使用FFmpeg拉取RTSP视频流并解码视频帧。


http://www.niftyadmin.cn/n/5845834.html

相关文章

Windows编程:下载与安装 Visual Studio 2019

本节前言 在写作本节的时候&#xff0c;本来呢&#xff0c;我正在写的专栏&#xff0c;是 MFC 专栏。而 VS2010 和 VS2019&#xff0c;正是 MFC 学习与开发中&#xff0c;可以使用的两款软件。然而呢&#xff0c;如果你去学习 Windows API 知识的话&#xff0c;那么&#xff0…

10vue3实战-----实现登录的基本功能

10vue3实战-----实现登录的基本功能 1.基本页面的搭建2.账号登录的验证规则配置3.点击登录按钮4.表单的校验5.账号的登录逻辑和登录状态保存6.定义IAccount对象类型 1.基本页面的搭建 大概需要搭建成这样子的页面: 具体的搭建界面就不多讲。各个项目都有自己的登录界面&#…

基于ESP32的远程开关灯控制(ESP32+舵机+Android+物联网云平台)

目录 材料环境准备物理材料软件环境 物联网平台配置&#xff08;MQTT&#xff09;MQTT阿里云平台配置创建产品添加设备自定义topic esp32配置接线代码 Android部分和云平台数据流转 前言&#xff1a;出租屋、宿舍网上关灯问题&#xff0c;计划弄一个智能开关以及带一点安防能力…

ElementUI的<el-image>组件引用网络图片加载失败

1. 验证图片 URL 是否有效 直接访问图片链接&#xff0c;确保 URL 正确且可公开访问 如果浏览器无法加载图片&#xff0c;可能是图片服务器限制了外链或已失效。 解决方法&#xff1a;更换为可用的图片 URL。 2. 检查浏览器开发者工具 打开浏览器开发者工具&#xff08;F12…

docker环境下部署face-search开源人脸识别模型

由于我们是直接将face-search部署在docker容器中的,所以,在部署之前一定要检查一下自己的docker环境,要不然部署过程中会出现各种各样的问题 我这里的docker环境是 一、安装docker环境 如果docker版本比较低或者docker-compose的版本比较低的情况下,部署的时候docker的yml…

[Meet DeepSeek] 如何顺畅使用DeepSeek?告别【服务器繁忙,请稍后再试。】

文章目录 [Meet DeepSeek] 如何顺畅使用DeepSeek&#xff1f;告别【服务器繁忙&#xff0c;请稍后再试。】引言使用渠道一&#xff1a;硅基流动 Chatbox AI【推荐】硅基流动 Chatbox AI的优势 使用渠道二&#xff1a;秘塔AI搜索秘塔AI搜索的优势 其它方案1. DeepSeek官网2. 纳…

B树详解及其C语言实现

目录 一、B树的基本原理 二、B树操作过程图形化演示 三、B树的应用场景 四、C语言实现B树及示例 五、代码执行结果说明 六、应用实例&#xff1a;文件系统目录索引 七、总结 一、B树的基本原理 B树&#xff08;B-Tree&#xff09; 是一种自平衡的树数据结构&#xff0c;…

数据结构--八大排序算法

1. 直接插入排序 当插入第 i(i>1) 个元素时&#xff0c;前面的 array[0],array[1],…,array[i-1] 已经排好序&#xff0c;此用 array[i] 的排序码与 array[i-1],array[i-2],… 的排序码顺序进行比较&#xff0c;找到插入位置即将 array[i] 插入&#xff0c;原来位置上的元素…