使用opencv + ffmpeg 开发视频播放器Demo

使用opencv + ffmpeg 开发视频播放器Demo

cpp 复制代码
#include <opencv2/opencv.hpp>
#include <opencv2/highgui.hpp>
#include <opencv2/videoio.hpp>

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

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

    // 打开视频文件
    AVFormatContext* formatContext = avformat_alloc_context();
    if (avformat_open_input(&formatContext, "video.mp4", NULL, NULL) != 0) {
        std::cout << "无法打开视频文件" << std::endl;
        return -1;
    }

    // 获取视频流信息
    if (avformat_find_stream_info(formatContext, NULL) < 0) {
        std::cout << "无法获取视频流信息" << std::endl;
        return -1;
    }

    // 寻找视频流索引
    int videoStreamIndex = -1;
    for (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::cout << "无法找到视频流" << std::endl;
        return -1;
    }

    // 获取视频解码器
    AVCodecParameters* codecParameters = formatContext->streams[videoStreamIndex]->codecpar;
    AVCodec* codec = avcodec_find_decoder(codecParameters->codec_id);
    AVCodecContext* codecContext = avcodec_alloc_context3(codec);
    avcodec_parameters_to_context(codecContext, codecParameters);
    avcodec_open2(codecContext, codec, NULL);

    // 创建窗口
    cv::namedWindow("Video Player", cv::WINDOW_NORMAL);

    // 读取视频帧
    AVPacket packet;
    AVFrame* frame = av_frame_alloc();
    while (av_read_frame(formatContext, &packet) >= 0) {
        if (packet.stream_index == videoStreamIndex) {
            avcodec_send_packet(codecContext, &packet);
            avcodec_receive_frame(codecContext, frame);

            // 转换 AVFrame 到 OpenCV Mat
            cv::Mat image(cv::Size(frame->width, frame->height), CV_8UC3, frame->data[0], frame->linesize[0]);

            // 显示图像
            cv::imshow("Video Player", image);
            cv::waitKey(25);
        }

        av_packet_unref(&packet);
    }

    // 清理
    av_frame_free(&frame);
    avcodec_close(codecContext);
    avformat_close_input(&formatContext);

    return 0;
}
相关推荐
拾荒的小海螺5 小时前
开源项目:LTX2 高效可控的开源视频生成模型
开源·音视频
EasyGBS13 小时前
视频画面模糊、卡顿、丢失?EasyGBS新增“视频质量诊断”功能,告别人工盯屏
视觉检测·音视频·gb28181·花屏·视频质量诊断·蓝屏检测
zhuweisky14 小时前
ArkTS实现鸿蒙手机视频聊天、屏幕分享(HarmonyOS)
音视频·harmonyos·鸿蒙开发
XHW___00114 小时前
webrtc 关键模块创建的时机
网络·音视频·webrtc
Leinwin14 小时前
VibeVoice-ASR:突破60分钟长音频处理瓶颈,语音识别进入端到端时代
人工智能·音视频·语音识别
没有不重的名么14 小时前
Multiple Object Tracking as ID Prediction
深度学习·opencv·计算机视觉·目标跟踪
愚者游世15 小时前
Opencv知识点大纲
人工智能·opencv·计算机视觉
EasyDSS16 小时前
直播点播/视频会议EasyDSS一站式视频云平台,全场景视频服务开箱即用
音视频·hls·m3u8·点播技术·流媒体直播
格林威16 小时前
Baumer相机电池极耳对齐度检测:提升叠片工艺精度的 5 个实用方案,附 OpenCV+Halcon 实战代码!
人工智能·opencv·机器学习·计算机视觉·视觉检测·工业相机·堡盟相机
Guheyunyi17 小时前
什么是安全监测预警系统?应用场景有哪些?
大数据·运维·人工智能·安全·音视频