mirror of
https://github.com/playmusicexporter/playmusicexporter
synced 2024-06-08 05:10:00 +00:00
c04b5cbce6
Continue the settings develop Add the directory browser to the framework project Group support (playlist or artist)
204 lines
6.7 KiB
Java
204 lines
6.7 KiB
Java
/*
|
|
* Copyright (c) 2015 David Schulte
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*/
|
|
|
|
package de.arcus.playmusicexporter2.fragments;
|
|
|
|
import android.app.Activity;
|
|
import android.os.Bundle;
|
|
import android.support.v4.app.ListFragment;
|
|
import android.view.View;
|
|
import android.widget.ListView;
|
|
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
|
|
import de.arcus.playmusicexporter2.adapter.MusicTrackListAdapter;
|
|
import de.arcus.playmusiclib.items.MusicTrackList;
|
|
|
|
/**
|
|
* A list fragment representing a list of Tracks. This fragment
|
|
* also supports tablet devices by allowing list items to be given an
|
|
* 'activated' state upon selection. This helps indicate which item is
|
|
* currently being viewed in a {@link MusicTrackDetailFragment}.
|
|
* <p/>
|
|
* Activities containing this fragment MUST implement the {@link Callbacks}
|
|
* interface.
|
|
*/
|
|
public class MusicTrackListFragment extends ListFragment {
|
|
|
|
/**
|
|
* The serialization (saved instance state) Bundle key representing the
|
|
* activated item position. Only used on tablets.
|
|
*/
|
|
private static final String STATE_ACTIVATED_POSITION = "activated_position";
|
|
|
|
/**
|
|
* The fragment's current callback object, which is notified of list item
|
|
* clicks.
|
|
*/
|
|
private Callbacks mCallbacks = sDummyCallbacks;
|
|
|
|
/**
|
|
* The current activated item position. Only used on tablets.
|
|
*/
|
|
private int mActivatedPosition = ListView.INVALID_POSITION;
|
|
|
|
/**
|
|
* A callback interface that all activities containing this fragment must
|
|
* implement. This mechanism allows activities to be notified of item
|
|
* selections.
|
|
*/
|
|
public interface Callbacks {
|
|
/**
|
|
* Callback for when an item has been selected.
|
|
*/
|
|
void onItemSelected(MusicTrackList musicTrackList);
|
|
}
|
|
|
|
/**
|
|
* A dummy implementation of the {@link Callbacks} interface that does
|
|
* nothing. Used only when this fragment is not attached to an activity.
|
|
*/
|
|
private static Callbacks sDummyCallbacks = new Callbacks() {
|
|
@Override
|
|
public void onItemSelected(MusicTrackList musicTrackList) {
|
|
}
|
|
};
|
|
|
|
private MusicTrackListAdapter mMusicTrackListAdapter;
|
|
|
|
/**
|
|
* Mandatory empty constructor for the fragment manager to instantiate the
|
|
* fragment (e.g. upon screen orientation changes).
|
|
*/
|
|
public MusicTrackListFragment() {
|
|
}
|
|
|
|
/**
|
|
* Update the list view
|
|
*/
|
|
public void updateListView() {
|
|
getListView().invalidateViews();
|
|
}
|
|
|
|
/**
|
|
* @param list Set the list
|
|
*/
|
|
public void setMusicTrackList(List<? extends MusicTrackList> list) {
|
|
// Create a new list
|
|
List<MusicTrackList> newList = new ArrayList<>();
|
|
|
|
// Copy the list
|
|
for(MusicTrackList musicTrackList : list) {
|
|
newList.add(musicTrackList);
|
|
}
|
|
|
|
// Set the list in the adapter
|
|
mMusicTrackListAdapter.setList(newList);
|
|
getListView().invalidateViews();
|
|
getListView().setSelection(0);
|
|
}
|
|
|
|
|
|
@Override
|
|
public void onCreate(Bundle savedInstanceState) {
|
|
super.onCreate(savedInstanceState);
|
|
|
|
mMusicTrackListAdapter = new MusicTrackListAdapter(getActivity());
|
|
|
|
|
|
setListAdapter(mMusicTrackListAdapter);
|
|
}
|
|
|
|
@Override
|
|
public void onViewCreated(View view, Bundle savedInstanceState) {
|
|
super.onViewCreated(view, savedInstanceState);
|
|
|
|
// Restore the previously serialized activated item position.
|
|
if (savedInstanceState != null
|
|
&& savedInstanceState.containsKey(STATE_ACTIVATED_POSITION)) {
|
|
setActivatedPosition(savedInstanceState.getInt(STATE_ACTIVATED_POSITION));
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void onAttach(Activity activity) {
|
|
super.onAttach(activity);
|
|
|
|
// Activities containing this fragment must implement its callbacks.
|
|
if (!(activity instanceof Callbacks)) {
|
|
throw new IllegalStateException("Activity must implement fragment's callbacks.");
|
|
}
|
|
|
|
mCallbacks = (Callbacks) activity;
|
|
}
|
|
|
|
@Override
|
|
public void onDetach() {
|
|
super.onDetach();
|
|
|
|
// Reset the active callbacks interface to the dummy implementation.
|
|
mCallbacks = sDummyCallbacks;
|
|
}
|
|
|
|
@Override
|
|
public void onListItemClick(ListView listView, View view, int position, long id) {
|
|
super.onListItemClick(listView, view, position, id);
|
|
|
|
// Notify the active callbacks interface (the activity, if the
|
|
// fragment is attached to one) that an item has been selected.
|
|
mCallbacks.onItemSelected(mMusicTrackListAdapter.getItem(position));
|
|
}
|
|
|
|
@Override
|
|
public void onSaveInstanceState(Bundle outState) {
|
|
super.onSaveInstanceState(outState);
|
|
if (mActivatedPosition != ListView.INVALID_POSITION) {
|
|
// Serialize and persist the activated item position.
|
|
outState.putInt(STATE_ACTIVATED_POSITION, mActivatedPosition);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Turns on activate-on-click mode. When this mode is on, list items will be
|
|
* given the 'activated' state when touched.
|
|
*/
|
|
public void setActivateOnItemClick(boolean activateOnItemClick) {
|
|
// When setting CHOICE_MODE_SINGLE, ListView will automatically
|
|
// give items the 'activated' state when touched.
|
|
getListView().setChoiceMode(activateOnItemClick
|
|
? ListView.CHOICE_MODE_SINGLE
|
|
: ListView.CHOICE_MODE_NONE);
|
|
}
|
|
|
|
private void setActivatedPosition(int position) {
|
|
if (position == ListView.INVALID_POSITION) {
|
|
getListView().setItemChecked(mActivatedPosition, false);
|
|
} else {
|
|
getListView().setItemChecked(position, true);
|
|
}
|
|
|
|
mActivatedPosition = position;
|
|
}
|
|
}
|