Intereting Posts
Удалить все фрагменты из контейнера Как получить значение как htmltext в textview в android? Как создать собственный языковой пакет для Android? Приложение Android запоминает свои данные после удаления и переустановки Когда я перетаскиваю поле «Обычный текст» в свой редактор WYSIWYG в Eclipse для Android 4.1, я получаю крах Java. Как исправить это? Как новый FragmentTransaction commitNow () работает внутри? Установка пользовательского .apk без adb / Eclipse Изображение из галереи автоматически поворачивается – Android Пауза и возобновление синхронизации репо Android Вращение изображений на Android. Есть ли способ лучше? LinearyLayout не будет изменять размер, если его высота равна 0 Может ли Dagger использоваться для выполнения инъекции в Content Provider? Добавить дополнительный элемент в адаптер курсора android Студия Android: предупреждение, когда я пытаюсь переместить класс в другой пакет Есть ли план по включению Android PdfRenderer в библиотеку поддержки?

Android – лучшая альтернатива расширяемому списку?

У меня есть список предметов, загруженных из веб-сервиса JSON. Каждый из этих элементов имеет собственный список подпунктов. Каждый элемент имеет множество текстовых представлений. Количество подэлементов изменяется динамически и состоит из нескольких текстовых просмотров. Есть временами десятки предметов с потенциально сотнями подэлементов. Я хочу, чтобы вся информация была видимой все время, т.е. мне действительно не нужна «расширяемая» часть расширяемого списка, но казалось, что это самый простой способ получить детский и групповой макет.

Item1 sub item 1 sub item 2 Item 2 sub item 1 sub item 2 sub item 3 etc 

В настоящее время я реализовал расширяемый список и заставил группы всегда расширяться. Это работает, однако очень медленно прокручивать не только эмулятор, но и мою галактику s2.
Мне интересно, есть ли лучший способ достичь этого?
Я рассмотрел одно представление списка и объединил строки в подтипах в одно текстовое представление, но думаю, что это не будет эстетически приятным, и я не смогу получить макет, который я хочу.
Я задавался вопросом, есть ли способ переопределить список, адаптированный так, чтобы один из элементов был массивом из других элементов. Адаптер может перебирать этот массив и создавать новые текстовые эффекты «на лету». Полагаю, это то, что делает расширяемый просмотр списка, так что, возможно, это закончится тем же прокруткой простоя.

Любая помощь была высоко оценена

Вы можете добиться этого с помощью класса ListView и пользовательского адаптера.

Обратите внимание, что у адаптера есть методы int getViewTypeCount() и int getItemViewType(int position) которые вы можете перезаписать.

Посмотрите на примерную реализацию набора данных в Map of lists

 public abstract class ExampleMapAdapter<V extends Map<?, ? extends List<?>>> extends BaseAdapter { public static final int VIEW_TYPE_HEADER = 0; public static final int VIEW_TYPE_LISTITEM = 1; protected V data; protected int[] sectionsStart; protected Object[] sections; protected int count; public ExampleMapAdapter(V data) { this.data = data; onSetData(); } @Override public int getCount() { return count; } @Override public Object getItem(int position) { int sectionIndex = getSectionForPosition(position); int innerIndex = position - sectionsStart[sectionIndex]; if(innerIndex == 0) { //head return sections[sectionIndex]; } else { //values return data.get(sections[sectionIndex]).get(innerIndex - 1); } } @Override public long getItemId(int position) { return position; } @Override public int getViewTypeCount() { return 2; } @Override public int getItemViewType(int position) { return Arrays.binarySearch(sectionsStart, position) < 0 ? VIEW_TYPE_LISTITEM : VIEW_TYPE_HEADER; } public int getPositionForSection(int section) { return sectionsStart[section]; } public int getSectionForPosition(int position) { int section = Arrays.binarySearch(sectionsStart, position); return section < 0 ? -section - 2 : section; } @Override public View getView(int position, View convertView, ViewGroup parent) { if(getItemViewType(position) == VIEW_TYPE_HEADER) { return getHeaderView(position, convertView, parent); } else { return getListItemView(position, convertView, parent); } } @Override public void notifyDataSetInvalidated() { data = null; onSetData(); super.notifyDataSetInvalidated(); } @Override public void notifyDataSetChanged() { onSetData(); super.notifyDataSetChanged(); } protected void onSetData() { if(data == null) { sectionsStart = null; sections = null; count = 0; } else { sectionsStart = new int[data.size()]; sections = data.keySet().toArray(new Object[data.size()]); count = 0; int i = 0; for(List<?> v : data.values()) { sectionsStart[i] = count; i++; count += 1 + v.size(); } } } protected abstract View getHeaderView(int position, View convertView, ViewGroup parent); protected abstract View getListItemView(int position, View convertView, ViewGroup parent); } 

И пример использования:

 public class ExampleActivity extends Activity { class SubItem { public final String text; public final int number; public final boolean checked; public SubItem(String text, int number, boolean checked) { this.text = text; this.number = number; this.checked = checked; } } //use LinkedHashMap or TreeMap as other map implementations may not keep key's order final Map<String, List<SubItem>> map = new LinkedHashMap<String, List<SubItem>>(); { List<SubItem> list = new ArrayList<SubItem>(); list.add(new SubItem("sub item", 1, false)); list.add(new SubItem("sub item", 2, true)); map.put("Item1", list); list = new ArrayList<SubItem>(); list.add(new SubItem("sub item", 1, true)); list.add(new SubItem("sub item", 2, false)); list.add(new SubItem("sub item", 3, false)); map.put("Item2", list); } @Override protected void onCreate(Bundle savedInstanceState) { ListView vList = new ListView(this); vList.setAdapter(new ExampleMapAdapter<Map<String, List<SubItem>>>(map) { @Override protected View getHeaderView(int position, View convertView, ViewGroup parent) { TextView v = convertView == null ? new TextView(parent.getContext()) : (TextView) convertView; v.setText((String) getItem(position)); return v; } @Override protected View getListItemView(int position, View convertView, ViewGroup parent) { CheckBox v = convertView == null ? new CheckBox(parent.getContext()) : (CheckBox) convertView; SubItem item = (SubItem) getItem(position); v.setText(item.text + " " + item.number); v.setChecked(item.checked); return v; } }); setContentView(vList); } }