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

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

2025-06-26 12:58:52作者:邓越浪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 脚本在构建实用工具方面的强大能力。项目特别适合喜欢终端工作流、注重效率的用户,以及对媒体播放控制有定制化需求的高级用户。

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

热门内容推荐

最新内容推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
148
1.95 K
kernelkernel
deepin linux kernel
C
22
6
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
274
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
190
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
931
555
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
980
395
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
75
66
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.11 K
0
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
65
515