-Fixed incorrect indexing due to item removed after shuffle.
-Fixed activity binding not unbound after service shutdown.
This commit is contained in:
parent
94f7baf299
commit
770dcc1832
3 changed files with 55 additions and 26 deletions
|
@ -469,8 +469,8 @@ public final class BackgroundPlayer extends Service {
|
||||||
@Override
|
@Override
|
||||||
public void shutdown() {
|
public void shutdown() {
|
||||||
super.shutdown();
|
super.shutdown();
|
||||||
stopSelf();
|
|
||||||
stopActivityBinding();
|
stopActivityBinding();
|
||||||
|
stopSelf();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*//////////////////////////////////////////////////////////////////////////
|
/*//////////////////////////////////////////////////////////////////////////
|
||||||
|
|
|
@ -53,7 +53,7 @@ public class BackgroundPlayerActivity extends AppCompatActivity
|
||||||
////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
private static final int RECYCLER_ITEM_POPUP_MENU_GROUP_ID = 47;
|
private static final int RECYCLER_ITEM_POPUP_MENU_GROUP_ID = 47;
|
||||||
private static final int PLAYBACK_SPEED_POPUP_MENU_GROUP_ID = 61;
|
private static final int PLAYBACK_SPEED_POPUP_MENU_GROUP_ID = 61;
|
||||||
private static final int PLAYBACK_PITCH_POPUP_MENU_GROUP_ID = 97;
|
private static final int PLAYBACK_PITCH_POPUP_MENU_GROUP_ID = 97;
|
||||||
|
|
||||||
private View rootView;
|
private View rootView;
|
||||||
|
@ -92,8 +92,10 @@ public class BackgroundPlayerActivity extends AppCompatActivity
|
||||||
|
|
||||||
final Toolbar toolbar = rootView.findViewById(R.id.toolbar);
|
final Toolbar toolbar = rootView.findViewById(R.id.toolbar);
|
||||||
setSupportActionBar(toolbar);
|
setSupportActionBar(toolbar);
|
||||||
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
|
if (getSupportActionBar() != null) {
|
||||||
getSupportActionBar().setTitle(R.string.title_activity_background_player);
|
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
|
||||||
|
getSupportActionBar().setTitle(R.string.title_activity_background_player);
|
||||||
|
}
|
||||||
|
|
||||||
serviceConnection = backgroundPlayerConnection();
|
serviceConnection = backgroundPlayerConnection();
|
||||||
}
|
}
|
||||||
|
@ -101,9 +103,7 @@ public class BackgroundPlayerActivity extends AppCompatActivity
|
||||||
@Override
|
@Override
|
||||||
protected void onStart() {
|
protected void onStart() {
|
||||||
super.onStart();
|
super.onStart();
|
||||||
final Intent mIntent = new Intent(this, BackgroundPlayer.class);
|
bind();
|
||||||
final boolean success = bindService(mIntent, serviceConnection, BIND_AUTO_CREATE);
|
|
||||||
if (!success) unbindService(serviceConnection);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -123,24 +123,36 @@ public class BackgroundPlayerActivity extends AppCompatActivity
|
||||||
@Override
|
@Override
|
||||||
protected void onStop() {
|
protected void onStop() {
|
||||||
super.onStop();
|
super.onStop();
|
||||||
if(serviceBound) {
|
unbind();
|
||||||
unbindService(serviceConnection);
|
|
||||||
serviceBound = false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////
|
||||||
// Service Connection
|
// Service Connection
|
||||||
////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
private void bind() {
|
||||||
|
final Intent mIntent = new Intent(this, BackgroundPlayer.class);
|
||||||
|
final boolean success = bindService(mIntent, serviceConnection, BIND_AUTO_CREATE);
|
||||||
|
if (!success) {
|
||||||
|
unbindService(serviceConnection);
|
||||||
|
}
|
||||||
|
serviceBound = success;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void unbind() {
|
||||||
|
if(serviceBound) {
|
||||||
|
unbindService(serviceConnection);
|
||||||
|
serviceBound = false;
|
||||||
|
player = null;
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private ServiceConnection backgroundPlayerConnection() {
|
private ServiceConnection backgroundPlayerConnection() {
|
||||||
return new ServiceConnection() {
|
return new ServiceConnection() {
|
||||||
@Override
|
@Override
|
||||||
public void onServiceDisconnected(ComponentName name) {
|
public void onServiceDisconnected(ComponentName name) {
|
||||||
Log.d(TAG, "Background player service is disconnected");
|
Log.d(TAG, "Background player service is disconnected");
|
||||||
serviceBound = false;
|
|
||||||
player = null;
|
|
||||||
finish();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -149,12 +161,9 @@ public class BackgroundPlayerActivity extends AppCompatActivity
|
||||||
final BackgroundPlayer.LocalBinder mLocalBinder = (BackgroundPlayer.LocalBinder) service;
|
final BackgroundPlayer.LocalBinder mLocalBinder = (BackgroundPlayer.LocalBinder) service;
|
||||||
player = mLocalBinder.getBackgroundPlayerInstance();
|
player = mLocalBinder.getBackgroundPlayerInstance();
|
||||||
if (player == null) {
|
if (player == null) {
|
||||||
finish();
|
unbind();
|
||||||
} else {
|
} else {
|
||||||
serviceBound = true;
|
|
||||||
buildComponents();
|
buildComponents();
|
||||||
|
|
||||||
player.setActivityListener(BackgroundPlayerActivity.this);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -169,6 +178,7 @@ public class BackgroundPlayerActivity extends AppCompatActivity
|
||||||
buildMetadata();
|
buildMetadata();
|
||||||
buildSeekBar();
|
buildSeekBar();
|
||||||
buildControls();
|
buildControls();
|
||||||
|
buildListeners();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void buildQueue() {
|
private void buildQueue() {
|
||||||
|
@ -220,6 +230,10 @@ public class BackgroundPlayerActivity extends AppCompatActivity
|
||||||
buildPlaybackPitchMenu();
|
buildPlaybackPitchMenu();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void buildListeners() {
|
||||||
|
player.setActivityListener(this);
|
||||||
|
}
|
||||||
|
|
||||||
private void buildPlaybackSpeedMenu() {
|
private void buildPlaybackSpeedMenu() {
|
||||||
if (playbackSpeedPopupMenu == null) return;
|
if (playbackSpeedPopupMenu == null) return;
|
||||||
|
|
||||||
|
@ -241,11 +255,11 @@ public class BackgroundPlayerActivity extends AppCompatActivity
|
||||||
private void buildPlaybackPitchMenu() {
|
private void buildPlaybackPitchMenu() {
|
||||||
if (playbackPitchPopupMenu == null) return;
|
if (playbackPitchPopupMenu == null) return;
|
||||||
|
|
||||||
playbackPitchPopupMenu.getMenu().removeGroup(PLAYBACK_SPEED_POPUP_MENU_GROUP_ID);
|
playbackPitchPopupMenu.getMenu().removeGroup(PLAYBACK_PITCH_POPUP_MENU_GROUP_ID);
|
||||||
for (int i = 0; i < BasePlayer.PLAYBACK_PITCHES.length; i++) {
|
for (int i = 0; i < BasePlayer.PLAYBACK_PITCHES.length; i++) {
|
||||||
final float playbackPitch = BasePlayer.PLAYBACK_PITCHES[i];
|
final float playbackPitch = BasePlayer.PLAYBACK_PITCHES[i];
|
||||||
final String formattedPitch = player.formatPitch(playbackPitch);
|
final String formattedPitch = player.formatPitch(playbackPitch);
|
||||||
final MenuItem item = playbackPitchPopupMenu.getMenu().add(PLAYBACK_SPEED_POPUP_MENU_GROUP_ID, i, Menu.NONE, formattedPitch);
|
final MenuItem item = playbackPitchPopupMenu.getMenu().add(PLAYBACK_PITCH_POPUP_MENU_GROUP_ID, i, Menu.NONE, formattedPitch);
|
||||||
item.setOnMenuItemClickListener(new MenuItem.OnMenuItemClickListener() {
|
item.setOnMenuItemClickListener(new MenuItem.OnMenuItemClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public boolean onMenuItemClick(MenuItem menuItem) {
|
public boolean onMenuItemClick(MenuItem menuItem) {
|
||||||
|
@ -488,6 +502,6 @@ public class BackgroundPlayerActivity extends AppCompatActivity
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onServiceStopped() {
|
public void onServiceStopped() {
|
||||||
finish();
|
unbind();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -274,11 +274,11 @@ public abstract class PlayQueue implements Serializable {
|
||||||
queueIndex.set(0);
|
queueIndex.set(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
streams.remove(index);
|
|
||||||
if (backup != null) {
|
if (backup != null) {
|
||||||
final int backupIndex = backup.indexOf(getItem(index));
|
final int backupIndex = backup.indexOf(getItem(index));
|
||||||
backup.remove(backupIndex);
|
backup.remove(backupIndex);
|
||||||
}
|
}
|
||||||
|
streams.remove(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
public synchronized void move(final int source, final int target) {
|
public synchronized void move(final int source, final int target) {
|
||||||
|
@ -303,7 +303,8 @@ public abstract class PlayQueue implements Serializable {
|
||||||
*
|
*
|
||||||
* This method first backs up the existing play queue and item being played.
|
* This method first backs up the existing play queue and item being played.
|
||||||
* Then a newly shuffled play queue will be generated along with the index of
|
* Then a newly shuffled play queue will be generated along with the index of
|
||||||
* the previously playing item.
|
* the previously playing item if it is found in the shuffled play queue. If
|
||||||
|
* not found, the current index will reset to 0.
|
||||||
*
|
*
|
||||||
* Will emit a {@link ReorderEvent} in any context.
|
* Will emit a {@link ReorderEvent} in any context.
|
||||||
* */
|
* */
|
||||||
|
@ -313,7 +314,13 @@ public abstract class PlayQueue implements Serializable {
|
||||||
}
|
}
|
||||||
final PlayQueueItem current = getItem();
|
final PlayQueueItem current = getItem();
|
||||||
Collections.shuffle(streams);
|
Collections.shuffle(streams);
|
||||||
queueIndex.set(streams.indexOf(current));
|
|
||||||
|
final int newIndex = streams.indexOf(current);
|
||||||
|
if (newIndex != -1) {
|
||||||
|
queueIndex.set(newIndex);
|
||||||
|
} else {
|
||||||
|
queueIndex.set(0);
|
||||||
|
}
|
||||||
|
|
||||||
broadcast(new ReorderEvent());
|
broadcast(new ReorderEvent());
|
||||||
}
|
}
|
||||||
|
@ -321,17 +328,25 @@ public abstract class PlayQueue implements Serializable {
|
||||||
/**
|
/**
|
||||||
* Unshuffles the current play queue if a backup play queue exists.
|
* Unshuffles the current play queue if a backup play queue exists.
|
||||||
*
|
*
|
||||||
* This method undoes shuffling and index will be set to the previously playing item.
|
* This method undoes shuffling and index will be set to the previously playing item if found,
|
||||||
|
* otherwise, the index will reset to 0.
|
||||||
*
|
*
|
||||||
* Will emit a {@link ReorderEvent} if a backup exists.
|
* Will emit a {@link ReorderEvent} if a backup exists.
|
||||||
* */
|
* */
|
||||||
public synchronized void unshuffle() {
|
public synchronized void unshuffle() {
|
||||||
if (backup == null) return;
|
if (backup == null) return;
|
||||||
final PlayQueueItem current = getItem();
|
final PlayQueueItem current = getItem();
|
||||||
|
|
||||||
streams.clear();
|
streams.clear();
|
||||||
streams = backup;
|
streams = backup;
|
||||||
backup = null;
|
backup = null;
|
||||||
queueIndex.set(streams.indexOf(current));
|
|
||||||
|
final int newIndex = streams.indexOf(current);
|
||||||
|
if (newIndex != -1) {
|
||||||
|
queueIndex.set(newIndex);
|
||||||
|
} else {
|
||||||
|
queueIndex.set(0);
|
||||||
|
}
|
||||||
|
|
||||||
broadcast(new ReorderEvent());
|
broadcast(new ReorderEvent());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue