FastScroll ведет себя странно с пользовательским адаптером ListAd, который реализует SectionIndexer - PullRequest
1 голос
/ 19 июля 2011

Я работаю над ListActivity, у которого есть внутренний класс, являющийся дочерним элементом SimpleAdapter, который реализует SectionIndexer.

class MySimpleAdapter extends SimpleAdapter implements SectionIndexer {

    HashMap<String, Integer> letters;
    Object[] sections;
    AlphabetIndexer alphaIndexer;
    public MySimpleAdapter(Context context, List<? extends Map<String, ?>> data,
            int resource, String[] from, int[] to, 
            HashMap<String, Integer> letters, Object[] sections) {
        super(context, data, resource, from, to);

        this.letters = letters;
        this.sections = sections;
    }

    @SuppressWarnings("unchecked")
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {

        if (convertView == null) {
            convertView = getLayoutInflater().inflate(R.layout.common_image_row1, null);
        }

        HashMap<String, Object> data = (HashMap<String, Object>) getItem(position);
        Integer idArtist = Integer.parseInt((String) data.get("idArtist"));

        convertView.setTag(idArtist);

        ((TextView) convertView.findViewById(R.id.item_name))
            .setText((String) data.get("sName"));

        ImageView image = (ImageView) convertView.findViewById(R.id.item_image);
        image.setTag((String) data.get("sImageUrl"));           
        image.setImageResource(R.drawable.default_artwork);

        ((TextView) convertView.findViewById(R.id.item_count))
            .setText((String) data.get("iSongs") + " Songs");

        if (!bScrolling) {
            new API.DownloadImagesTask().execute(image);
        }
        return convertView;
    }

    public int getPositionForSection(int section) {
        String letter = (String) sections[section];

        return letters.get(letter);

    }

    public int getSectionForPosition(int position) {
        return 0;
    }

    public Object[] getSections() {
        return sections;
    }
}

Действие получает объект JSON в отдельной AysncTask.Этот объект состоит из различных JSONArrays, ключи которых являются первой буквой элемента элементов массива.Итак, массив состоит из набора элементов, которые начинаются с буквы «В».Следовательно, ключом JSONArray является «B».

{
    B: ["ball", "buck", "bill"]
    C: ["charlie", "chuck", "chap"]
}

Объект не обязательно должен иметь все буквы алфавита.Мне также известно, что порядок с JSONObjects не гарантирован, поэтому я сортирую их.
List> maps = new ArrayList> ();ArrayList section = new ArrayList ();HashMap letters = new HashMap ();

        String[] alphabet = {"A","B","C","D","E","F","G","H","I","J","K","L","M","N"
                ,"O","P","Q","R","S","T","U","V","W","X","Y","Z"};
        int k = 0;
        for (int i = 0; i < alphabet.length; i++) {
            if (playlistArtists.optJSONArray(alphabet[i]) != null) {
                try {
                    JSONArray artists = playlistArtists.getJSONArray(alphabet[i]);
                    sections.add(alphabet[i]);

                    for (int j = 0; j < artists.length(); j++) {
                        JSONObject artist = (JSONObject) artists.get(j);
                        HashMap<String, String> map= new HashMap<String, String>();
                        map.put("idArtist", artist.getString("idArtist"));
                        map.put("sName", artist.getString("sName"));
                        map.put("sImageUrl", artist.getString("sImageUrl-thumb"));
                        map.put("iSongs", artist.getString("iSongs"));
                        maps.add(map);

                        letters.put(alphabet[i], k);
                        k++;
                    }
                } catch (JSONException e) {
                    Log.d(TAG,"JSONException in Music::GetMusicCatlog.doInBackground");
                    e.printStackTrace();
                }

            }
        }
        SimpleAdapter adapter = new MySimpleAdapter(Catalog.this, 
                maps,
                R.layout.common_image_row1,
                new String[] {"idArtist","sName", "sImageUrl", "iSongs" },
                new int[] {R.id.item_id, R.id.item_name, R.id.item_image, R.id.item_count }, 
                letters, 
                sections.toArray());
        setListAdapter(adapter);

Проблема, с которой я столкнулся, связана с FastScroll.У меня все работает по большей части.Список сгруппирован по первой букве, и при использовании FastScroll буква появляется во всплывающем окне и попадает в правильную группу.Проблема в том, что когда я перехожу на FastScroll после перехода к нужному разделу, FastScroll «переходит» в случайную часть списка.Он не остается в том месте, где я его отпустил.Я думаю, что это происходит в произвольном месте в разделе, потому что у меня не правильно реализован SectionIndexer.Я думаю, что проблема с этим методом.

public int getSectionForPosition(int position) {
        return 0;
    }

Я просто не уверен, как правильно реализовать методы SectionIndexer ...

Ответы [ 2 ]

1 голос
/ 31 марта 2015

TL; DR Первый ответ не может быть правильным.Если вам нужен пример реализации метода getSectionForPosition, см. здесь .

Вы правы, похоже, проблема с вашей реализацией getSectionForPosition. Ответ , предоставленный до сих пор , не может быть правильным , потому что вам нужно вернуть индекс раздела, с которым связана определенная позиция, а не позиция, с которой связан раздел (то естьчто вы должны getPositionForSection метод).

Таким образом, вы должны переработать свой getSectionForPosition метод (снова).Вам необходимо действительное сопоставление для каждой позиции для секции .Документация гласит:

Учитывая позицию в адаптере, возвращает индекс соответствующего раздела в массиве объектов раздела.

Если вам нужен пример того, какпостроить такое отображение, см. здесь .Реализованный правильно, он решит проблему с прокручивающейся полосой прокрутки и вместо этого правильно расположит ее.

0 голосов
/ 20 июля 2011

Много раз я видел, как getSectionForPosition реализовывался так же, как getPositionForSection

    public int getPositionForSection(int section) {
        String letter = (String) sections[section];

        return letters.get(letter);
    }

    public int getSectionForPosition(int position) {
        String letter = (String) sections[position];

        return letters.get(letter);
    }
...