Landscape artist view & new progress slider

This commit is contained in:
Karim Abou Zeid 2015-02-09 21:26:05 +01:00
commit 85854939c4
23 changed files with 98 additions and 116 deletions

View file

@ -77,7 +77,6 @@ public class AlbumDetailActivity extends AbsFabActivity implements OnMusicRemote
private View albumArtOverlayView;
private View songsBackgroundView;
private TextView albumTitleView;
private FloatingActionButton fab;
private Toolbar toolbar;
private int toolbarHeight;
private int headerOffset;
@ -109,8 +108,8 @@ public class AlbumDetailActivity extends AbsFabActivity implements OnMusicRemote
ViewHelper.setTranslationY(albumTitleView, titleTranslationY);
// Translate FAB
int fabTranslationY = titleTranslationY + titleViewHeight - (fab.getHeight() / 2);
ViewHelper.setTranslationY(fab, fabTranslationY);
int fabTranslationY = titleTranslationY + titleViewHeight - (getFab().getHeight() / 2);
ViewHelper.setTranslationY(getFab(), fabTranslationY);
if (TOOLBAR_IS_STICKY) {
// Change alpha of toolbar background
@ -167,7 +166,6 @@ public class AlbumDetailActivity extends AbsFabActivity implements OnMusicRemote
albumArtOverlayView = findViewById(R.id.overlay);
absSongListView = (ObservableListView) findViewById(R.id.list);
albumTitleView = (TextView) findViewById(R.id.album_title);
fab = (FloatingActionButton) findViewById(R.id.fab);
songsBackgroundView = findViewById(R.id.list_background);
statusBar = findViewById(R.id.statusBar);
}
@ -303,8 +301,8 @@ public class AlbumDetailActivity extends AbsFabActivity implements OnMusicRemote
} else {
setUpSongsAdapter();
fab.setScaleX(0);
fab.setScaleY(0);
getFab().setScaleX(0);
getFab().setScaleY(0);
animateHeader(DEFAULT_DELAY_NO_TRANSITION);
animateFab(DEFAULT_DELAY_NO_TRANSITION);
}
@ -346,7 +344,7 @@ public class AlbumDetailActivity extends AbsFabActivity implements OnMusicRemote
}
private void animateFab(int startDelay) {
ViewPropertyAnimator.animate(fab)
ViewPropertyAnimator.animate(getFab())
.scaleX(1)
.scaleY(1)
.setInterpolator(new DecelerateInterpolator(4))
@ -402,19 +400,10 @@ public class AlbumDetailActivity extends AbsFabActivity implements OnMusicRemote
}
}
@Override
public void onResume() {
super.onResume();
enableViews();
updateFabIcon();
app.getMusicPlayerRemote().addOnMusicRemoteEventListener(this);
}
@Override
public void enableViews() {
super.enableViews();
absSongListView.setEnabled(true);
fab.setEnabled(true);
toolbar.setEnabled(true);
}
@ -422,45 +411,9 @@ public class AlbumDetailActivity extends AbsFabActivity implements OnMusicRemote
public void disableViews() {
super.disableViews();
absSongListView.setEnabled(false);
fab.setEnabled(false);
toolbar.setEnabled(false);
}
@Override
protected void onStop() {
super.onStop();
app.getMusicPlayerRemote().removeOnMusicRemoteEventListener(this);
}
@Override
public void onMusicRemoteEvent(MusicRemoteEvent event) {
switch (event.getAction()) {
case MusicRemoteEvent.PLAY:
fab.setImageDrawable(getResources().getDrawable(R.drawable.ic_pause_white_48dp));
break;
case MusicRemoteEvent.PAUSE:
fab.setImageDrawable(getResources().getDrawable(R.drawable.ic_play_arrow_white_48dp));
break;
case MusicRemoteEvent.RESUME:
fab.setImageDrawable(getResources().getDrawable(R.drawable.ic_pause_white_48dp));
break;
case MusicRemoteEvent.STOP:
fab.setImageDrawable(getResources().getDrawable(R.drawable.ic_play_arrow_white_48dp));
break;
case MusicRemoteEvent.QUEUE_COMPLETED:
fab.setImageResource(R.drawable.ic_play_arrow_white_48dp);
break;
}
}
private void updateFabIcon() {
if (app.getMusicPlayerRemote().isPlaying()) {
fab.setImageResource(R.drawable.ic_pause_white_48dp);
} else {
fab.setImageResource(R.drawable.ic_play_arrow_white_48dp);
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_album_detail, menu);

View file

@ -231,7 +231,7 @@ public class ArtistDetailActivity extends AbsFabActivity implements OnMusicRemot
}
private int getListBackgroundTranslation(int scrollY) {
return Math.max(0, -scrollY + artistImageViewHeight);
return Math.max(0, -scrollY + artistImageViewHeight - 200);
}
private int getTitleTranslation(int scrollY) {
@ -425,18 +425,23 @@ public class ArtistDetailActivity extends AbsFabActivity implements OnMusicRemot
toolbar.setEnabled(false);
}
@Override
protected void onSaveInstanceState(Bundle outState) {
}
private static class NavigationAdapter extends FragmentPagerAdapter {
private String[] titles;
private SparseArray<Fragment> mPages;
private static SparseArray<Fragment> pages;
private Artist artist;
private Context context;
public NavigationAdapter(Activity activity, Artist artist) {
super(activity.getFragmentManager());
this.artist = artist;
mPages = new SparseArray<>();
pages = new SparseArray<>();
context = activity;
titles = new String[]{
context.getResources().getString(R.string.tab_songs),
@ -447,39 +452,40 @@ public class ArtistDetailActivity extends AbsFabActivity implements OnMusicRemot
@Override
public Fragment getItem(int position) {
Bundle args = new Bundle();
final Bundle args = new Bundle();
args.putInt(ARG_ARTIST_ID, artist.id);
args.putString(ARG_ARTIST_NAME, artist.name);
Fragment f;
switch (position) {
case 1:
f = mPages.get(position, new ViewPagerTabArtistAlbumFragment());
break;
case 0:
f = mPages.get(position, new ViewPagerTabArtistSongListFragment());
break;
case 2:
f = mPages.get(position, new ViewPagerTabArtistBioFragment());
break;
default:
f = mPages.get(position, new MainActivity.PlaceholderFragment());
break;
}
Fragment f = getOrCreateFragmentAt(position);
f.setArguments(args);
mPages.put(position, f);
pages.put(position, f);
return f;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
if (0 <= mPages.indexOfKey(position)) {
mPages.remove(position);
if (0 <= pages.indexOfKey(position)) {
pages.remove(position);
}
super.destroyItem(container, position, object);
}
public Fragment getItemAt(int position) {
return mPages.get(position, null);
return pages.get(position, null);
}
private Fragment getOrCreateFragmentAt(int position) {
switch (position) {
case 1:
return pages.get(position, new ViewPagerTabArtistAlbumFragment());
case 0:
return pages.get(position, new ViewPagerTabArtistSongListFragment());
case 2:
return pages.get(position, new ViewPagerTabArtistBioFragment());
default:
return pages.get(position, new MainActivity.PlaceholderFragment());
}
}
@Override

View file

@ -70,9 +70,9 @@ public abstract class AbsFabActivity extends AbsBaseActivity implements OnMusicR
private void updateFabState() {
if (getApp().getMusicPlayerRemote().isPlaying()) {
getFab().setImageResource(R.drawable.ic_pause_white_48dp);
getFab().setImageResource(R.drawable.ic_pause_white_24dp);
} else {
getFab().setImageResource(R.drawable.ic_play_arrow_white_48dp);
getFab().setImageResource(R.drawable.ic_play_arrow_white_24dp);
}
}
@ -149,19 +149,19 @@ public abstract class AbsFabActivity extends AbsBaseActivity implements OnMusicR
public void onMusicRemoteEvent(MusicRemoteEvent event) {
switch (event.getAction()) {
case MusicRemoteEvent.PLAY:
getFab().setImageDrawable(getResources().getDrawable(R.drawable.ic_pause_white_48dp));
getFab().setImageDrawable(getResources().getDrawable(R.drawable.ic_pause_white_24dp));
break;
case MusicRemoteEvent.PAUSE:
getFab().setImageDrawable(getResources().getDrawable(R.drawable.ic_play_arrow_white_48dp));
getFab().setImageDrawable(getResources().getDrawable(R.drawable.ic_play_arrow_white_24dp));
break;
case MusicRemoteEvent.RESUME:
getFab().setImageDrawable(getResources().getDrawable(R.drawable.ic_pause_white_48dp));
getFab().setImageDrawable(getResources().getDrawable(R.drawable.ic_pause_white_24dp));
break;
case MusicRemoteEvent.STOP:
getFab().setImageDrawable(getResources().getDrawable(R.drawable.ic_play_arrow_white_48dp));
getFab().setImageDrawable(getResources().getDrawable(R.drawable.ic_play_arrow_white_24dp));
break;
case MusicRemoteEvent.QUEUE_COMPLETED:
getFab().setImageResource(R.drawable.ic_play_arrow_white_48dp);
getFab().setImageResource(R.drawable.ic_play_arrow_white_24dp);
break;
}
}

View file

@ -42,7 +42,7 @@ public class ViewPagerTabArtistAlbumFragment extends AbsViewPagerTabArtistListFr
openAlbumDetailsActivityIfPossible(album, albumArtView);
}
});
setColumns(2);
setColumns(getResources().getInteger(R.integer.grid_columns));
return adapter;
}

View file

@ -101,8 +101,8 @@ public class AlbumViewFragment extends Fragment implements KabViewsDisableAble,
private void fillAbsListView(List<Album> albums) {
Collections.sort(albums, new AlbumAlphabeticComparator());
AlbumViewGridAdapter albumTileAdapter = new AlbumViewGridAdapter(getActivity(), albums);
absListView.setAdapter(albumTileAdapter);
AlbumViewGridAdapter albumViewGridAdapter = new AlbumViewGridAdapter(getActivity(), albums);
absListView.setAdapter(albumViewGridAdapter);
absListView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {