diff options
author | daniel oeh <daniel.oeh@gmail.com> | 2014-06-07 16:38:04 +0200 |
---|---|---|
committer | daniel oeh <daniel.oeh@gmail.com> | 2014-06-07 16:38:04 +0200 |
commit | c4e0078382c6ea048456e127cc887476d48a6686 (patch) | |
tree | eeb73f942e53832fb011356db224027ea6c594f3 /src | |
parent | a174b4db75d00f0391e493e1ba849a1bb996fbf5 (diff) | |
download | AntennaPod-c4e0078382c6ea048456e127cc887476d48a6686.zip |
Bugfix: Playback could not be restarted in some cases. fixes #387
Diffstat (limited to 'src')
-rw-r--r-- | src/de/danoeh/antennapod/service/playback/PlaybackService.java | 1 | ||||
-rw-r--r-- | src/de/danoeh/antennapod/service/playback/PlaybackServiceMediaPlayer.java | 36 |
2 files changed, 33 insertions, 4 deletions
diff --git a/src/de/danoeh/antennapod/service/playback/PlaybackService.java b/src/de/danoeh/antennapod/service/playback/PlaybackService.java index fb2569bfd..b7ff62129 100644 --- a/src/de/danoeh/antennapod/service/playback/PlaybackService.java +++ b/src/de/danoeh/antennapod/service/playback/PlaybackService.java @@ -541,6 +541,7 @@ public class PlaybackService extends Service { (nextMedia.getMediaType() == MediaType.VIDEO) ? EXTRA_CODE_VIDEO : EXTRA_CODE_AUDIO); } else { sendNotificationBroadcast(NOTIFICATION_TYPE_PLAYBACK_END, 0); + mediaPlayer.stop(); //stopSelf(); } } diff --git a/src/de/danoeh/antennapod/service/playback/PlaybackServiceMediaPlayer.java b/src/de/danoeh/antennapod/service/playback/PlaybackServiceMediaPlayer.java index 24ff9b3fa..2915da5a1 100644 --- a/src/de/danoeh/antennapod/service/playback/PlaybackServiceMediaPlayer.java +++ b/src/de/danoeh/antennapod/service/playback/PlaybackServiceMediaPlayer.java @@ -77,7 +77,8 @@ public class PlaybackServiceMediaPlayer { public void rejectedExecution(Runnable r, ThreadPoolExecutor executor) { if (BuildConfig.DEBUG) Log.d(TAG, "Rejected execution of runnable"); } - }); + } + ); mediaPlayer = null; statusBeforeSeeking = null; @@ -150,6 +151,8 @@ public class PlaybackServiceMediaPlayer { if (media != null) { if (!forceReset && media.getIdentifier().equals(playable.getIdentifier())) { // episode is already playing -> ignore method call + if (BuildConfig.DEBUG) + Log.d(TAG, "Method call to playMediaObject was ignored: media file already playing."); return; } else { // stop playback of this episode @@ -284,7 +287,8 @@ public class PlaybackServiceMediaPlayer { reinit(); } } else { - if (BuildConfig.DEBUG) Log.d(TAG, "Ignoring call to pause: Player is in " + playerStatus + " state"); + if (BuildConfig.DEBUG) + Log.d(TAG, "Ignoring call to pause: Player is in " + playerStatus + " state"); } playerLock.unlock(); @@ -385,9 +389,10 @@ public class PlaybackServiceMediaPlayer { /** * Seeks to the specified position. If the PSMP object is in an invalid state, this method will do nothing. + * * @param t The position to seek to in milliseconds. t < 0 will be interpreted as t = 0 - * <p/> - * This method is executed on the caller's thread. + * <p/> + * This method is executed on the caller's thread. */ private void seekToSync(int t) { if (t < 0) { @@ -758,6 +763,29 @@ public class PlaybackServiceMediaPlayer { } /** + * Moves the PlaybackServiceMediaPlayer into STOPPED state. This call is only valid if the player is currently in + * INDETERMINATE state, for example after a call to endPlayback. + * This method will only take care of changing the PlayerStatus of this object! Other tasks like + * abandoning audio focus have to be done with other methods. + */ + public void stop() { + executor.submit(new Runnable() { + @Override + public void run() { + playerLock.lock(); + + if (playerStatus == PlayerStatus.INDETERMINATE) { + setPlayerStatus(PlayerStatus.STOPPED, null); + } else { + if (BuildConfig.DEBUG) Log.d(TAG, "Ignored call to stop: Current player state is: " + playerStatus); + } + playerLock.unlock(); + + } + }); + } + + /** * Holds information about a PSMP object. */ public class PSMPInfo { |