MPV基本使用方法
前言
mpv是一个开源的媒体播放器,它支持多种音频和视频格式,包括常见的文件格式(如MP4、AVI、MKV等)以及流媒体协议(如HTTP、RTSP等)。mpv是基于MPlayer和mplayer2项目的代码基础上发展而来的,它采用了许多现代化的设计和功能,如更好的视频输出、更好的性能和更好的代码可维护性。
一、特点
轻量级和高效
:mpv被设计为尽可能简单和快速,以提供最佳的媒体播放体验。
广泛的格式支持:mpv支持许多常见的音频和视频格式,以及许多不太常见的格式。命令行控制
:mpv可以通过命令行进行控制,具有丰富的命令行选项和功能。高度可定制性
:mpv允许用户根据自己的需求进行定制,可以通过配置文件或命令行选项来调整播放器的行为。主题和脚本支持
:mpv支持主题和脚本,允许用户自定义界面和功能。
总的来说,mpv是一个功能强大且灵活的媒体播放器,适用于各种平台和使用场景。
二、使用步骤
1.引入库
代码如下(示例):
#include <mpv/client.h>
2.创建实例
代码如下(示例):
mpv_handle *mpvPlayer = mpv_create();
3.设置显示窗口
代码如下(示例):
int64_t winID = QWidget->winId();
mpv_set_option(mpvPlayer, "wid", MPV_FORMAT_INT64, &winID);
4.请求级别日志消息
代码如下(示例):
// MPV_EVENT_LOG_MESSAGE的形式接收
mpv_set_option_string(mpvPlayer, "info");
5.设置控制台输出
代码如下(示例):
mpv_set_option_string(mpvPlayer, "terminal", "false");
6.设置消息级别
代码如下(示例):
// MPV_EVENT_LOG_MESSAGE的形式接收
mpv_set_option_string(mpvPlayer, "msg-level", "all=v");
7.设置硬件加速
代码如下(示例):
// no auto any d3dllva dxva2
mpv_set_option_string(mpvPlayer, "hwdec", "vaapi");
mpv_set_option_string(mpvPlayer, "vo", "vaapi");
8.设置音频处理
代码如下(示例):
mpv_set_option_string(mpvPlayer, "ad", "null");
mpv_set_option_string(mpvPlayer, "ao", "null");
9.设置通信协议
代码如下(示例):
mpv_set_option_string(mpvPlayer, "rtsp-tramsport", "tcp");
10.设置网络超时(单位秒)
代码如下(示例):
mpv_set_option_string(mpvPlayer, "network-timeout", "3");
11.初始化实例
代码如下(示例):
if (mpv_initialize(mpvPlayer) < 0) {
std::cout << "mpv failed to initialize." << std::endl;
}
12.播放视频流
代码如下(示例):
const char *args[] = {"loadfile", "流地址", NULL};
if (mpv_command_async(mpvPlayer, 0, args) < 0) {
std::cout << "mpv loadfile failed." << std::endl;
}
13.停止播放
代码如下(示例):
const char *args[] = {"loadfile", "流地址", NULL};
mpv_command(mpvPlayer, args);
14.释放资源
if (mpvPlayer) {
mpv_detach_destroy(mpvPlayer);
mpvPlayer = NULL;
}
三、命令补充
mpv_command_async
异步运行命令来避免阻塞,mpv_command
正好相反。