Fixed hard freeze that occurred if gstreamer never started to actually play a song after calling the Player play method.
This commit is contained in:
parent
9164dff257
commit
daedca9bf6
@ -49,7 +49,7 @@ class Player {
|
||||
* Set a source Song file and start playing it via GStreamer.
|
||||
* @param inputSong Song to play.
|
||||
*/
|
||||
public void playSong(Optional<Song> inputSong){
|
||||
public void playSong(Optional<Song> inputSong) throws StartPlayingException {
|
||||
if (playBin.getState() == State.PLAYING)
|
||||
stop();
|
||||
if(inputSong.isPresent()) {
|
||||
@ -71,11 +71,16 @@ class Player {
|
||||
thread = new Thread(internalThread, "GSTThread");
|
||||
setVolume(currentVolume);
|
||||
playBin.play();
|
||||
thread.start();
|
||||
while (true) {
|
||||
if (playBin.queryDuration().getSeconds() > 0 || playBin.queryDuration().getNanoSeconds() > 0) break;
|
||||
} // Wait for song to actually be playing otherwise queryDuration is always zero
|
||||
callbackInterface.setSeekBarDuration((int) playBin.queryDuration().toSeconds());
|
||||
if(playBin.getState() == State.PLAYING) {
|
||||
thread.start();
|
||||
while (true) {
|
||||
if (playBin.queryDuration().getSeconds() > 0 || playBin.queryDuration().getNanoSeconds() > 0) break;
|
||||
} // Wait for song to actually be playing otherwise queryDuration is always zero
|
||||
callbackInterface.setSeekBarDuration((int) playBin.queryDuration().toSeconds());
|
||||
}
|
||||
else{
|
||||
throw new StartPlayingException(inputSong.get());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -162,12 +162,21 @@ public class PlayerGUI implements PlayerCallbackInterface, LibraryCallbackInterf
|
||||
playlistTableModel.setPlayingRow(index);
|
||||
}
|
||||
|
||||
private void playSong(Optional<Song> song){
|
||||
try {
|
||||
player.playSong(song);
|
||||
} catch (StartPlayingException e) {
|
||||
JOptionPane.showMessageDialog(mainPanel, "Failed to play " + song.get().toString() + ".\n" +
|
||||
"If file path contains non-ASCII characters, please restart the application with UTF-8 encoding.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the next song in the playlist and dispatch it to the Player to be played.
|
||||
*/
|
||||
public void playNextSong() {
|
||||
SwingUtilities.invokeLater(() -> seekBar.setValue(0));
|
||||
player.playSong(playlistTableModel.nextSong(player.getCurrentSong()));
|
||||
playSong(playlistTableModel.nextSong(player.getCurrentSong()));
|
||||
}
|
||||
|
||||
/**
|
||||
@ -175,7 +184,7 @@ public class PlayerGUI implements PlayerCallbackInterface, LibraryCallbackInterf
|
||||
*/
|
||||
public void playPreviousSong() {
|
||||
SwingUtilities.invokeLater(() -> seekBar.setValue(0));
|
||||
player.playSong(playlistTableModel.previous(player.getCurrentSong()));
|
||||
playSong(playlistTableModel.previous(player.getCurrentSong()));
|
||||
}
|
||||
|
||||
/**
|
||||
@ -355,9 +364,9 @@ public class PlayerGUI implements PlayerCallbackInterface, LibraryCallbackInterf
|
||||
playButton.addActionListener(e -> {
|
||||
if (playList.getRowCount() > 0) {
|
||||
if (playList.getSelectedRowCount() > 0)
|
||||
player.playSong(playlistTableModel.getSong(playList.getSelectedRow()));
|
||||
playSong(playlistTableModel.getSong(playList.getSelectedRow()));
|
||||
else
|
||||
player.playSong(playlistTableModel.getFirst());
|
||||
playSong(playlistTableModel.getFirst());
|
||||
}
|
||||
});
|
||||
toolBar.add(playButton);
|
||||
@ -545,9 +554,9 @@ public class PlayerGUI implements PlayerCallbackInterface, LibraryCallbackInterf
|
||||
else{
|
||||
if (playList.getRowCount() > 0) {
|
||||
if (playList.getSelectedRowCount() > 0)
|
||||
player.playSong(playlistTableModel.getSong(playList.getSelectedRow()));
|
||||
playSong(playlistTableModel.getSong(playList.getSelectedRow()));
|
||||
else
|
||||
player.playSong(playlistTableModel.getFirst());
|
||||
playSong(playlistTableModel.getFirst());
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
12
src/main/java/musicplayer/StartPlayingException.java
Normal file
12
src/main/java/musicplayer/StartPlayingException.java
Normal file
@ -0,0 +1,12 @@
|
||||
package musicplayer;
|
||||
|
||||
import musicplayer.model.Song;
|
||||
|
||||
public class StartPlayingException extends Exception {
|
||||
|
||||
private Song song;
|
||||
|
||||
public StartPlayingException(Song song){
|
||||
this.song = song;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user