首页
/ GMT4/MPVC 项目日志手册解析:mpv控制工具的技术演进

GMT4/MPVC 项目日志手册解析:mpv控制工具的技术演进

2025-06-26 04:15:43作者:邓越浪Henry

项目概述

GMT4/MPVC 是一个基于命令行的 mpv 媒体播放器控制工具,提供类似 mpc (Music Player Client) 的功能接口。该项目通过 JSON IPC 与 mpv 播放器进行通信,实现了丰富的播放控制功能,并逐步发展出 TUI 界面、FZF 集成、Web 控制等扩展特性。

核心功能演进

基础控制功能

项目最初实现了基本的 mpv 控制功能:

  • 播放控制:play/pause/stop/toggle
  • 播放列表管理:add/remove/clear
  • 播放进度控制:seek/volume
  • 状态查询:status/current

这些功能通过 POSIX shell 脚本实现,与 mpv 通过 UNIX socket 进行 JSON IPC 通信。

播放列表持久化 (2022.11)

# 保存当前播放列表
mpvc autosave myplaylist.m3u

# 加载已保存的播放列表
mpvc autoload myplaylist.m3u

# 列出所有保存的播放列表
mpvc lsplaylists

播放列表默认存储在 $XDG_CONFIG_HOME/mpvc/playlist/ 目录下,支持标准的 M3U 格式。

TUI 界面开发 (2022.12)

mpvc-tui 是项目的重要扩展,提供了终端用户界面:

# 启动TUI界面
mpvc-tui

# 快速启动模式(适合窗口管理器快捷方式)
mpvc-tui -x

TUI 界面特点:

  1. 实时显示播放状态和播放列表
  2. 通过 Ctrl+C 进入交互式命令模式
  3. 支持三种命令类型:
    • 直接 mpvc 命令
    • 内部 Shell 命令(以!开头)
    • 外部 Shell 命令(以!!开头)

高级 IPC 控制 (2022.12)

项目支持直接发送 JSON IPC 命令给 mpv:

# 显示OSD消息
mpvc cmd show-text "Hello World" 2000

# 切换音频滤波器
mpvc cmd af toggle lavfi=[loudnorm=I=-16:TP=-3:LRA=4]

# 获取命令返回值
mpvc cmdr get_property volume

流媒体集成 (2022.12)

通过 mpvc-fzf 工具实现了流媒体服务集成:

# 搜索并播放YouTube内容
mpvc-fzf -p "search query"

# 工作流程分解
mpvc-fzf -s "query"  # 搜索
mpvc-fzf -s "query" | fzf -m  # 选择
mpvc-fzf -s "query" | fzf -m | awk '{print $1}' | mpvc load  # 加载

事件订阅系统 (2022.12)

实现了 mpv 事件订阅机制:

# 监听所有mpv事件
mpvc idleloop

# 监听特定事件并触发通知
mpvc idleloop | awk '/playback-restart/ {system("notify-send \"$(mpvc)\"");print}'

进阶功能

FZF 深度集成 (2022.12)

mpvc-fzf -l  # 本地文件搜索播放
mpvc-fzf -f  # 播放控制功能选择
mpvc-fzf -F  # 综合数据搜索

多实例管理 (2023.01)

# 控制特定实例
MPVC_SOCKET=/path/to/socket mpvc command

状态保存与恢复 (2023.02)

mpvc stash save  # 保存当前状态
mpvc stash load  # 恢复保存的状态

技术实现要点

  1. 通信机制:使用 mpv 的 JSON IPC over UNIX socket
  2. 配置系统:遵循 XDG 规范,配置存储在 $XDG_CONFIG_HOME/mpvc/
  3. 模块化设计:核心功能与扩展工具分离
  4. POSIX 兼容:主要使用 shell 脚本实现,保证跨平台性

使用建议

  1. 持久化 mpv 实例:
    mpvc --mpv  # 启动持久化实例
    
  2. TUI 定制化: 编辑 $XDG_CONFIG_HOME/mpvc/mpvc.conf 自定义界面
  3. 快捷键集成: 将 mpvc-tui -x 绑定到窗口管理器快捷键

总结

GMT4/MPVC 项目从一个简单的 mpv 控制脚本逐步发展成为一个功能丰富的媒体控制生态系统,展示了 shell 脚本在构建实用工具方面的强大能力。项目特别适合喜欢终端工作流、注重效率的用户,以及对媒体播放控制有定制化需求的高级用户。

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
868
513
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
268
308
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
373
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
599
58
GitNextGitNext
基于可以运行在OpenHarmony的git,提供git客户端操作能力
ArkTS
10
3