From 3ae589147df3f36c56bdb74db003651f946ca304 Mon Sep 17 00:00:00 2001 From: owner Date: Thu, 20 Dec 2012 20:57:13 -0800 Subject: Closes #78 Fix for letter not showing in Artist list --- .../daneren2005/dsub/view/ArtistAdapter.java | 44 +++++++++++++++++++++- 1 file changed, 43 insertions(+), 1 deletion(-) diff --git a/subsonic-android/src/github/daneren2005/dsub/view/ArtistAdapter.java b/subsonic-android/src/github/daneren2005/dsub/view/ArtistAdapter.java index 12956a14..0edb03c5 100644 --- a/subsonic-android/src/github/daneren2005/dsub/view/ArtistAdapter.java +++ b/subsonic-android/src/github/daneren2005/dsub/view/ArtistAdapter.java @@ -23,19 +23,40 @@ import java.util.List; import android.view.View; import android.view.ViewGroup; import android.widget.ArrayAdapter; +import android.widget.SectionIndexer; import github.daneren2005.dsub.activity.SubsonicTabActivity; import github.daneren2005.dsub.domain.Artist; +import java.util.ArrayList; +import java.util.LinkedHashSet; +import java.util.Set; /** * @author Sindre Mehus */ -public class ArtistAdapter extends ArrayAdapter { +public class ArtistAdapter extends ArrayAdapter implements SectionIndexer { private final SubsonicTabActivity activity; + + // Both arrays are indexed by section ID. + private final Object[] sections; + private final Integer[] positions; public ArtistAdapter(SubsonicTabActivity activity, List artists) { super(activity, R.layout.artist_list_item, artists); this.activity = activity; + + Set sectionSet = new LinkedHashSet(30); + List positionList = new ArrayList(30); + for (int i = 0; i < artists.size(); i++) { + Artist artist = artists.get(i); + String index = artist.getIndex(); + if (!sectionSet.contains(index)) { + sectionSet.add(index); + positionList.add(i); + } + } + sections = sectionSet.toArray(new Object[sectionSet.size()]); + positions = positionList.toArray(new Integer[positionList.size()]); } @Override @@ -50,4 +71,25 @@ public class ArtistAdapter extends ArrayAdapter { view.setArtist(entry); return view; } + + @Override + public Object[] getSections() { + return sections; + } + + @Override + public int getPositionForSection(int section) { + section = Math.min(section, positions.length - 1); + return positions[section]; + } + + @Override + public int getSectionForPosition(int pos) { + for (int i = 0; i < sections.length - 1; i++) { + if (pos < positions[i + 1]) { + return i; + } + } + return sections.length - 1; + } } -- cgit v1.2.3