【音视频】VLC播放器

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


一、vlc是什么?

VLC Media Player(简称VLC)是一款免费、开源、跨平台的多媒体播放器,由非营利组织VideoLAN开发,最初是法国巴黎中央理工学院学生的项目,现由全球志愿者维护。其核心特点包括支持几乎所有音视频格式、无广告、低资源占用以及强大的扩展功能,被誉为"万能播放器";

VLC 有一个理念 一切都是流的播放;

特点:

  1. **格式支持广泛:**支持超过 200种 音视频格式,包括MP4、AVI、MKV、FLAC、MP3等,甚至能播放未下载完成的文件或加密DVD ;
  2. 跨平台与轻量化: 支持 Windows、macOS、Linux、Android、iOS 等主流系统;
  3. 解码能力:集成FFmpeg解码器和libdvdcss库,直接解码加密内容,无需额外插件;
  4. 流媒体服务器:可作为unicast/multicast服务器,支持IPv4/IPv6网络流分发;

二、使用步骤

1.安装

  1. 首先需要在 VLC 的 github 官网获取源码 ;VLC 的下载地址:https://github.com/videolan/vlc
  2. 或者本文章提供了一套已经弄好的开发环境 (压缩包); 将其解压到需要使用这个库的项目中即可(文章最上面资源绑定);

有了库、头文件和动态库之后,按照下面设置在visual studio使用该库步骤:

  1. 头文件配置

  2. 库文件配置 库的目录的设置:连接器→常规→附加库目录→追加 lib 文件夹

  3. 至此,该库就可以进行使用

  4. 注意 ,后续要将生成结果打包为安装包的时候; Plugins 文件夹和其中的内容、dll 文件,都需要一起打包走 否则可执行程序将无法正常工作

  5. libVLC 使用的 UTF-8 编码,所以如果参数中有中文 需要进行转码才能起效

2.demo

实现一个命令行的播放器,媒体是本地或者url的视频源;

cpp 复制代码
#include <Windows.h>
#include <iostream>
#include "vlc.h"
#include <conio.h>

// 将 Unicode 字符串转换为 UTF-8 编码 因为 libVLC 通常使用 UTF-8 编码来处理文件路径或 URL
//如果路径有中文,无法创建正常的media
std::string Unicode2Utf8(const std::wstring& strIn)
{
    //多字节
    std::string str;
    // 获取转换成 UTF-8 所需的缓冲区大小
    int length = ::WideCharToMultiByte(CP_UTF8, 0, strIn.c_str(), strIn.size(), NULL, 0, NULL, NULL);
    str.resize(length + 1);
    // 将 Unicode 转换为 UTF-8
    ::WideCharToMultiByte(CP_UTF8, 0, strIn.c_str(), strIn.size(), (LPSTR)str.c_str(), length, NULL, NULL);
    return str;
}

int main()
{
    // 初始化 VLC 的参数
    int argc = 1;
    char* argv[2];
    argv[0] = (char*)"--ignore-config"; // 忽略 VLC 默认配置

    // 1、创建 VLC 实例
    libvlc_instance_t* vlc_ins = libvlc_new(argc, argv);
    if (!vlc_ins) {
        std::cout << "创建 VLC 实例失败!" << std::endl;
        return -1;
    }

    // 将文件路径转换为 UTF-8 格式(确保 VLC 正确处理)
    std::string path = Unicode2Utf8(L"file:///E:/study_project/VideoPlay/VideoPlay/美女.mp4");
    //反斜杠\是转义字符 \\ 表示反斜杠本身

    // 2、使用文件路径创建媒体对象(URL 格式)
    libvlc_media_t* media = libvlc_media_new_location(vlc_ins, path.c_str());
    if (!media) {
        std::cout << "加载媒体失败!" << std::endl;
        libvlc_release(vlc_ins);
        return -1;
    }

    // 3、使用媒体对象创建媒体播放器
    libvlc_media_player_t* player = libvlc_media_player_new_from_media(media);
    if (!player) {
        std::cout << "创建媒体播放器失败!" << std::endl;
        libvlc_media_release(media);
        libvlc_release(vlc_ins);
        return -1;
    }

    // 4、启动媒体播放
    int ret = libvlc_media_player_play(player);
    if (ret == -1) {
        std::cout << "启动播放失败!" << std::endl;
        libvlc_media_player_release(player);
        libvlc_media_release(media);
        libvlc_release(vlc_ins);
        return -1;
    }
    Sleep(300);//只有media加载完成,才会有下面的参数
    // 等待媒体加载完成,直到能够访问音量信息
    int vol = -1;
    while (vol == -1) {
        Sleep(10); // 每隔 10 毫秒检查一次
        vol = libvlc_audio_get_volume(player); // 获取当前音量
    }
    std::cout << "当前音量: " << vol << std::endl;

    // 将音量设置为 10
    libvlc_audio_set_volume(player, 10);

    // 获取并显示媒体总时长
    libvlc_time_t tm = libvlc_media_player_get_length(player);
    std::cout << "媒体时长: " 
              << int(tm / 3600000) << ":" 
              << int(tm / 60000) % 60 << ":" 
              << int(tm / 1000) % 60 << "." 
              << int(tm) % 1000 << std::endl;

    // 获取并显示视频的宽度和高度
    int width = libvlc_video_get_width(player);
    int height = libvlc_video_get_height(player);
    std::cout << "视频分辨率: " << width << "x" << height << std::endl;

    // 显示播放进度(百分比)
    while (!_kbhit()) { // 等待用户按键退出
        std::cout << "播放进度: " 
                  << 100.0 * libvlc_media_player_get_position(player) << "%" << "\r";
        Sleep(500); // 每 500 毫秒更新一次
    }

    // 当用户按下键盘时暂停播放
    getchar(); // 等待用户输入
    libvlc_media_player_pause(player); // 暂停播放

    getchar(); // 等待用户输入恢复播放
    libvlc_media_player_play(player); // 恢复播放

    getchar(); // 等待用户输入停止播放
    libvlc_media_player_stop(player); // 停止播放

    // 释放资源
    libvlc_media_player_release(player);
    libvlc_media_release(media);
    libvlc_release(vlc_ins);

    return 0;
}
相关推荐
EasyDSS3 小时前
私有化视频会议平台/视频高清直播点播EasyDSS构建智慧校园音视频协作新生态
音视频
txp玩Linux5 小时前
音频 AI 模型开源方案与音频 3A / ASR / TTS 全链路解析
人工智能·音视频
runafterhit5 小时前
显示调研专题-OLED行业技术趋势分析报告
音视频
灰灰勇闯IT6 小时前
DVPP 视频预处理:YOLO 视频检测的瓶颈与解法
yolo·音视频
Luna-player7 小时前
音频服务未运行,未安装音频设备,Windows 无法启动 Windows Audio 服务,错误 0x80070005:拒绝访问,本计算机无法播放音频
音视频
中小企业实战军师刘孙亮8 小时前
小微企业生存发展指南:从求稳到扩张的实战策略-佛山鼎策创局破局增长咨询
架构·产品运营·音视频·制造·业界资讯
视频号下载助手8 小时前
2026视频号视频下载去水印方法!4种无水印视频提取方法
音视频
青w韵8 小时前
视频链接处理 + 提取字幕
音视频
ting94520009 小时前
Vivago Video Agent 技术深度解析:大模型驱动的叙事视频全链路生成
人工智能·音视频
ZC跨境爬虫9 小时前
跟着 MDN 学CSS day_3:(为一个传记页面添加样式)
前端·javascript·css·ui·音视频·html5