-
Notifications
You must be signed in to change notification settings - Fork 402
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Resume last played track now working! (especially for audiobooks) #47
Comments
Hi @Neponator you started a good feature here, I haven't found the time to really test what you are aiming at. Still, some feedback (to keep your motivation up! We all want your feature!). When I have more time, I will join in the effort.
a) try to give each action in your script more time by adding sleep. Just for testing. b) the bash c) |
You're my hero - a) already solved it - it's not only the time between calling the playlist and the track (min sleep 5) but also the time between calling track (goto x) and calling position (seek x) in the track, that requires a sleep 1, otherwise the requests confuse each other. It's running now - many thanks @MiczFlor ! I updated the code in post above. Will keep the issue open to create a manual that is easier to follow :-D |
Hi @Neponator
|
I am closing this ticket, because of the launch of version 1.0 on master. If you have any issues, please try first if they are still happening on the latest version 1.0. If so, open another ticket, please.
The version 1.0 has not been tested on
Version 1.0 is a major improvement (which will be full of bugs, for sure :) and I want to thank all the contributors and Phoniebox lovers with their input, pictures, bug fixes and suggestions. |
Hey,
I tried for the last week to implement a set of scripts that allows to resume the last played track and I finally made it work - the Jukebox now saves the last played playlist, song and position and resumes after reboot of the pi. It's not perfect since the song starts for a second before resuming to the last played position. I'm still trying to tweak that with mute/unmute or working with shorter sleep() in milliseconds.
My appraoch (code see below): The VLC which the RPi-Jukebox uses offers a XML file, that shows all information on the playing track (like artist, title, current position, current track number of the playlist). I took those information and saved it into separate text files - (artist and title for a display that I plan for the future) as well as the current track position and playlist number. Since the "download" of this xml is pretty slow (1-3 seconds), I only use it when pressing the button for "pause" or "shutdown".
Current track position and playlist number I use in combination with the VLC remote functions "goto x" and "seek x" (seek is already integrated in the code with seek 0 as a possibility to start the track from beginning). "goto x" works similarly, it makes vlc jump to the specific item on the playlist and plays it.
To make it work, the playlist cannot be temporary like in the original project, so I changed the path in the rfid_trigger_play.sh to RPi-Jukebox-RFID\shared\playlists\ (First I chose the Folder containing the mp3s itself, however that did not work as all the files in the folder are used to create the playlist, including the m3u's. So I added the subfolder. At the sametime I exported the path of the m3u to a textfile to use after reboot.
Now I have all I need, the playlist and the text files containing current position and current track.
I then created a bash-script that runs after boot of the pi, starts the VLC, loads the playlist, jumps to the current track and plays a specific position.
Now to my code:
cvlc --no-video --network-caching=10000 -I rc --rc-host localhost:4212 "$PLAYLISTPATH" &
to
cvlc --no-video --network-caching=10000 -I rc --extraintf=http --http-password 123 --rc-host localhost:4212 "$PLAYLISTPATH" &
instead of
PLAYLISTPATH="/tmp/$FOLDERNAME.m3u"
set
PLAYLISTPATH="$PATHDATA/../shared/playlists/$FOLDERNAME.m3u"
(not sure if you need to create the folder "playlists" in ./shared first or if the script does it for you - if you want to be sure, create it first withmkdir playlists
.Additionally we want to export the path of the playlist to a textfile, to be able to remember the last used playlist at start of the pi:
Still in rfid_trigger_play.sh add
echo "$PATHDATA/../shared/playlists/$FOLDERNAME.m3u" > $PATHDATA/../shared/lastplayed.txt
after
find
"$PATHDATA/../shared/audiofolders/$FOLDERNAME" -type f | sort -n >"$PLAYLISTPATH"
nano /home/pi/RPi-Jukebox-RFID/scripts/getCurrentSongDetails.py
)Relevant output are the the textfiles latestPlid.txt and latesttime.txt that contain the last played playlist-item and the track position. (I don't know why, but the VLC playlists start with track position 4 - so the first song of the playlist has PLID 4, the second has 5 and so on). Here I'm pretty sure python does not creates the textfiles latestPlid.txt, latesttime.txt and latestsong.txt in ./shared for you - better create them yourself beforehand via
nano latestPlid.txt
(then CTRL-O and Enter to save, CTRL-X to close; same for latesttime.txt, latestsong.txt).The service I use to start the script lies in /etc/systemd/system/ and looks like this:
(Just copy the code into a new file via
nano /etc/systemd/system/resumesong.service
thensudo systemctl daemon-reload
to inform the system that there's a new service, thensudo systemctl enable resumesong.service
to start the service.)To run the script fetching the data you need to change the gpio-buttons.py in the following way:
add in headline
import time
and change
to
Also change
to
Don't forget to make the new scripts and textfiles accessible with
sudo chmod +x <file>
!Done!
I started python only a week ago - so most of my code is stolen or the result of trial and error - if you have any recommendations for simplifying it, let me know.
The text was updated successfully, but these errors were encountered: