Para controlar mpv
de forma remota (por ejemplo, desde otra sesión de terminal) también puede iniciarlo con la opción
--input-ipc-server=/tmp/mpvsocket
y controlarlo emitiendo comandos como este:
echo '{ "command": ["set_property", "pause", true] }' | socat - /tmp/mpvsocket
Ver man mpv
para (muchos) más detalles.
editar:ver también mpv --list-properties
edit2:la forma más sencilla que he encontrado para "alternar" pausa/reproducción es
{"command": ["cycle", "pause"]}
kill -s STOP $(pidof mpv)
y kill -s CONT $(pidof mpv)
o mejor :
xdotool key --window "$(xdotool search --class mpv)" p
La tecla "P", está configurada por defecto para pausar el video.
Es posible controlar mpv a través de IPC. Del manual mpv(1)
:
--input-ipc-server=<filename>
Enable the IPC support and create the listening socket at the given path.
On Linux and Unix, the given path is a regular filesystem path.
On Windows, named pipes are used, so the path refers to the pipe namespace (\\.\pipe\<name>). If the \\.\pipe\ prefix is missing, mpv will add it automatically before creating the pipe, so --input-ipc-server=/tmp/mpv-socket and --input-ipc-server=\\.\pipe\tmp\mpv-socket are equivalent for IPC on Windows.
See JSON IPC for details.
Un par de ejemplos:
$ echo 'cycle pause' | socat - /tmp/mpv-socket
$ echo 'playlist-prev' | socat - /tmp/mpv-socket
$ echo 'playlist-next' | socat - /tmp/mpv-socket
Ver mpv(1)
para obtener más información.
Véase también:
- https://alexherbo2.github.io/blog/mpv/command-line-controller/
- https://gist.github.com/dwgill/a66769e0edef69c04d3b