跳转至内容

MPRIS

来自 ArchWiki
(重定向自 Playerctl)

MPRIS (Media Player Remote Interfacing Specification) 是一个标准的 D-Bus 接口,旨在为控制媒体播放器提供通用的编程 API。

它提供了一种发现、查询和基本播放控制兼容媒体播放器的机制,以及一个用于为当前媒体项添加上下文的曲目列表接口。

支持的客户端

本文或本节需要在语言、wiki 语法或风格方面进行改进。请参阅 Help:Style 获取参考。

原因: 似乎大多数软件现在都支持 MPRIS,这一部分可能应该变成需要手动配置的特定情况列表。(在 Talk:MPRIS 讨论)

本文章或章节需要扩充。

原因: 您可以查看 您选择的播放器 并使用 playerctl 工具检查它是否支持 MPRIS。如果支持,请将其添加到以下列表中。(在 Talk:MPRIS 讨论)

控制工具

提示 为常用的控制命令和多媒体按键(如 XF86AudioPlayXF86AudioPauseXF86AudioStopXF86AudioPrevXF86AudioNext)创建 快捷键

Playerctl

playerctl 工具提供了一个命令行工具来向 MPRIS 客户端发送命令。最常用的命令是 play-pausenextpreviousstop

$ playerctl play-pause
$ playerctl next
$ playerctl previous
$ playerctl stop

playerctl 会将命令发送给它找到的第一个播放器。要手动选择播放器,请使用 --player 选项,例如 --player=vlc。为了更好的自动化,playerctl 带有一个守护进程,该守护进程会跟踪媒体播放器活动并将命令定向到最近活动的播放器。您可以通过以下方式将其启动到后台:

$ playerctld daemon

为了在您登录时启动 playerctld,您可以创建一个以下 systemd/User 服务

~/.config/systemd/user/playerctld.service
[Unit]
Description=Keep track of media player activity

[Service]
Type=oneshot
ExecStart=/usr/bin/playerctld daemon

[Install]
WantedBy=default.target

在此之后,您应该进行 daemon-reload,然后使用 --user 标志 启用 该服务。

提示 可以安装 playerctld-systemd-unitAUR 包,而不是手动创建服务。

此外,playerctld 还可以更改“活动”播放器,这在您有多个同步媒体流时可能很有用。

要切换到下一个播放器,请使用

$ playerctld shift

要切换到上一个播放器,请使用

$ playerctld unshift

mpris-player-control

mpris_player_control 是一个 shell 脚本,它集成了 dbus-sendpactl 来控制 MPRIS 客户端。它支持播放、暂停、播放/暂停和停止操作,以及 Spotify 的接收器音量控制(静音/取消静音/增大/减小)。

运行 mpris_player_control -h 来显示基本脚本用法。

D-Bus

上述方法的替代方法是手动使用 D-Bus,它应该默认可用,因为它是 systemd 的依赖项。

例如,以下命令可用于使用支持的 方法 控制 Spotify

$ dbus-send --print-reply --dest=org.mpris.MediaPlayer2.spotify /org/mpris/MediaPlayer2 org.mpris.MediaPlayer2.Player.Method

类似地,使用 busctl(1)

$ busctl --user call org.mpris.MediaPlayer2.spotify /org/mpris/MediaPlayer2 org.mpris.MediaPlayer2.Player Method

蓝牙

来自 蓝牙耳机 和类似设备的媒体控制可以转发到 MPRIS。

注意 某些耳机,如 Sony WH-1000XM3,提供 AVRCP 接口。对于这些类型,不需要 mpris-proxy。只需确保已为媒体按键设置了 快捷键

安装 bluez-utils 包,然后运行 mpris-proxy。为了让 mpris-proxy 在后台启动和/或在系统启动时启动,请使用 --user 标志 启动/启用 mpris-proxy.service