Это было на самом деле очень сложно, потому что проблема была в том, что -loop 0
я использовал на ведомом устройстве, фактически ждал, пока мастер не передаст свою позицию и синхронизируется. На самом деле я разговаривал с одним из моих друзей, который был одним из разработчиков mplayer, и он сказал мне, что то, что я хотел сделать, было невозможно.
Таким образом, хак, который я в итоге использовал, состоял в том, чтобы постоянно проверять текущее положение ведомого и так же, как это происходит, когда EOF перезапускает файл после определенного периода сна - который я должен был настроить вручную ...
Сначала, чтобы настроить мастер, используйте это:
mplayer -udp-master -udp-ip 10.42.0.255 masterVideo.mp4 -loop 0
Для раба я использовал следующий скрипт:
#!/bin/bash
fifo="/tmp/fifo"
rm -rf $fifo
mkfifo $fifo
mplayer -nocache -slave -fixed-vo -idle -udp-ip 10.42.0.255 -udp-slave -udp-seek-threshold 0.5 -osdlevel 0 -input file=$fifo >$fifo.answer "slaveVideo.mp4" &
somepid=$!
echo $somepid
function getpos() {
local newpos=none
while ! [[ "$newpos" =~ ANS_TIME ]]; do
echo "get_time_pos" > $fifo
newpos=$(tail -n 1 $fifo.answer)
[[ "$newpos" =~ "EOF code: 1" ]] && { pos=-1; echo > $fifo.answer; return; }
pos=${newpos#ANS_TIME_POSITION=}
done
pos=${pos#0}
pos2=$(echo "$pos + 0.14" | bc )
printf "%.2f" "$pos2"
}
function getlen() {
local newlen=none
while ! [[ "$newlen" =~ ANS_LENGTH ]]; do
echo "get_time_length" > $fifo
newlen=$(tail -n 1 $fifo.answer)
len=${newlen#ANS_LENGTH=}
sleep 0.1
done
len=${len#0}
echo ${len}
}
len=$(getlen)
while true; do
pos=$(getpos)
if [[ $pos == $len ]]
then
# YOU MUST TWEAK THE FOLLOWING
# SLEEP TIME FOR YOUR MACHINE
sleep 0.5
echo "loadfile /media/media/1.mp4" > $fifo
fi
done
Кстати, я использую скомпилированный mplayer, а не mplayer2. Пауза работает очень чисто, как и пропустить ... Однако очень важно, чтобы оба файла имели одинаковую длительность и использовали одинаковые кодеки ...