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

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

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

登录后查看全文

热门内容推荐

项目优选

收起
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
51
15
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
574
416
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
125
208
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
77
146
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
442
39
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
98
253
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
693
91
folibfolib
FOLib 是一个为Ai研发而生的、全语言制品库和供应链服务平台
Java
108
6
CS-BooksCS-Books
🔥🔥超过1000本的计算机经典书籍、个人笔记资料以及本人在各平台发表文章中所涉及的资源等。书籍资源包括C/C++、Java、Python、Go语言、数据结构与算法、操作系统、后端架构、计算机系统知识、数据库、计算机网络、设计模式、前端、汇编以及校招社招各种面经~
120
16
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
299
1.03 K