listview с arraylist, простой адаптер в android
Я пытаюсь показать что-то в listview, используя arraylist и простой адаптер. Я попробовал что-то вроде ниже, но в моем результате показаны фамилии arraylist. В чем моя ошибка, Я не могу понять.
final ListView listView = (ListView) findViewById(R.id.mylist);
ArrayList<HashMap<String, String>> list_of_bookmarks = new ArrayList<HashMap<String, String>>();
HashMap<String, String> b = new HashMap<String, String>();
String[] from = { "php_key","c_key","android_key","hacking_key" };
String[] name_of_bookmarks = { "php","c","android","hacking" };
for(int i=0;i<4;i++)
{
b.put(from[i],name_of_bookmarks[i]);
list_of_bookmarks.add(b);
}
};
int[] to = { R.id.txt1,R.id.txt1,R.id.txt1,R.id.txt1};
SimpleAdapter adapter = new SimpleAdapter(getBaseContext(), list_of_bookmarks, R.layout.list_layout, from, to);
listView.setAdapter(adapter);
Я просто хочу показать "php","c","android", "hacking" в listview. И что должен быть более эффективный способ сделать это.Я новичок, поэтому вы можете предложить лучший способ, который я должен следовать
5 ответов
Main.в XML
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="60dp" >
<ListView
android:id="@+id/zone_list"
android:layout_marginBottom="70dp"
android:background="@drawable/batteryborder"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
</ListView>
</LinearLayout>
setlanguage.в XML
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="60dp">
<TextView
android:id="@+id/tvName"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:textSize="18dp"
android:gravity="center_vertical" />
</LinearLayout>
добавить в onCreate () файла деятельностью
ListView listView;
String[] from = { "php_key","c_key","android_key","hacking_key" };
ArrayAdapter arrayAdapter;
listView = (ListView) findViewById(R.id.zone_list);
arrayAdapter = new ArrayAdapter(this,R.layout.setlanguage, R.id.tvName, from);
listView.setAdapter(arrayAdapter);
мой совет вам будет создать отдельный класс, который расширяет адаптер (или какой-то его подкласс)
вот простой пример адаптера массива строк.
package ro.gebs.captoom.adapters;
import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import antistatic.spinnerwheel.adapters.AbstractWheelTextAdapter;
import com.example.captoom.R;
public class LanguagesAdapter extends AbstractWheelTextAdapter {
// Countries names
private String languages[];
public LanguagesAdapter(Context context) {
super(context, R.layout.lang_item, NO_RESOURCE);
languages = context.getResources().getStringArray(R.array.lang_array);
setItemTextResource(R.id.language_txt);
}
@Override
public View getItem(int index, View cachedView, ViewGroup parent) {
View view = super.getItem(index, cachedView, parent);
return view;
}
@Override
public int getItemsCount() {
return languages.length;
}
@Override
protected CharSequence getItemText(int index) {
return languages[index];
}
}
и использование просто просто используйте метод .setAdapter();
или другой пример, который использует arrayAdapter:
package apc.example;
import java.util.ArrayList;
import utils.BitmapManager;
import android.app.Activity;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView;
public class PersonAdapter extends ArrayAdapter<Person> {
Context context;
int layoutResourceId;
ArrayList<Person> data = null;
public PersonAdapter(Context context, int layoutResourceId,
ArrayList<Person> data) {
super(context, layoutResourceId, data);
this.layoutResourceId = layoutResourceId;
this.context = context;
this.data = data;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View row = convertView;
ItemHolder holder = null;
if (row == null) {
LayoutInflater inflater = ((Activity) context).getLayoutInflater();
row = inflater.inflate(layoutResourceId, parent, false);
holder = new ItemHolder();
holder.imgIcon = (ImageView) row.findViewById(R.id.icon);
holder.txtName = (TextView) row.findViewById(R.id.title);
holder.txtDescription = (TextView) row.findViewById(R.id.desc);
row.setTag(holder);
} else {
holder = (ItemHolder) row.getTag();
}
Person bean = data.get(position);
holder.txtName.setText(bean.getName());
holder.txtDescription.setText(bean.getDescription());
Bitmap b = BitmapFactory.decodeResource(context.getResources(), R.drawable.user);
BitmapManager.INSTANCE.setPlaceholder(b);
BitmapManager.INSTANCE.loadBitmap(bean.getUrl(), holder.imgIcon, 80, 80);
return row;
}
public static class ItemHolder {
public ImageView imgIcon;
TextView txtName;
TextView txtDescription;
}
public void updateAdapter(ArrayList<Person> pers){
this.data = pers;
}
}
это пример адаптера для более сложного класса, который имеет больше полей, чем простая строка. Но это можно легко изменить на ArrayAdapter<String>
и затем идти оттуда.
в любом случае, я думаю, что всегда лучше писать пользовательские адаптеры для listviews.
надеюсь, что это помогает!
вы повторно используете тот же вид в своем объекте int [].
int[] to = { R.id.txt1,R.id.txt1,R.id.txt1,R.id.txt1};
похоже, что он рассматривает их все как один и тот же объект, поэтому каждый раз, когда он добавляет новый элемент, он изменяет предыдущие.
чтобы использовать SimpleAdapter
вам нужно будет определить каждое представление в XML с разными идентификаторами.
int[] to = { R.id.txt1,R.id.txt2,R.id.txt3,R.id.txt4};
на SimpleAdapter
может быть проще в отношении его внутренней сложности,но это определенно не проще в использовании. С Ан ArrayAdapter
вы можете просто передать ему список элементов и позволить ему автоматически генерировать представления. Это может быть любой размер, который вам нужен, пока у вас не закончится память. (См. ниже пример)
как только вы начнете работать с пользовательскими адаптерами, я настоятельно рекомендую вам смотреть Romain Guy & Adam Powell's I/O talk. Это все трудно принять, но они делают большую работу, объясняя, как ListViews
работа.
//List of Items
String[] name_of_bookmarks = { "php","c","android","hacking" };
//Create your List object for the ArrayAdapter
//and make it the same size as name_of_books
List<String> listBookmarks = new ArrayList<String>(Array.getLength(name_of_bookmarks));
//Add name_of_bookmarks contents to listBookmarks
Collections.addAll(listBookmarks, name_of_books);
//Create an ArrayAdapter passing it the Context, a generic list item and your list
//An alternative to "this" would be "getApplicationContext()" from your main activity
//or "getActivity()" from a fragment. "getBaseContext()" is not recommended.
ArrayAdapter arrayAdapter = new ArrayAdapter(this, R.layout.list_item_text, listBookmarks);
//Set the adapter to your ListView
final ListView listView = (ListView) findViewById(R.id.mylist);
listView.setAdapter(arrayAdapter);
Независимо От Того, С Какой Проблемой Вы Сталкиваетесь, Именно Я Сталкиваюсь С Проблемой Под Названием " Список Вид Отображение Последней Позиции Данных Массива..."
Проблема Генерируется С Помощью Хэш-Карты
final ListView listView = (ListView) findViewById(R.id.mylist);
ArrayList<HashMap<String, String>> list_of_bookmarks = new ArrayList<HashMap<String, String>>();
String[] from = { "php_key","c_key","android_key","hacking_key" };
String[] name_of_bookmarks = { "php","c","android","hacking" };
for(int i=0;i<4;i++)
{
HashMap<String, String> b = new HashMap<String, String>();
b.put(from[i],name_of_bookmarks[i]);
list_of_bookmarks.add(b);
}
};
int[] to = { R.id.txt1,R.id.txt1,R.id.txt1,R.id.txt1};
SimpleAdapter adapter = new SimpleAdapter(getBaseContext(), list_of_bookmarks, R.layout.list_layout, from, to);
listView.setAdapter(adapter);
Попробуйте Это, Если Какие-Либо Сомнения, Созданные В Вашем Уме, Затем Задайте Мне Любой Вопрос Снова Просто Вы Должны Объявить Свою Хэш-Карту Внутри Своего Цикла For ...
используя хэш-карту внутри вашей переменной цикла For 'b', созданной каждым & Каждый Раз, Когда Рассматривается Как Другой Объект. А Затем Просто Список Массивов Отображает Другой Объект Хэш-Карты.
вы используете тот же объект для хранения значения хэш-карты, и эта переменная была переопределена с тем же именем, поэтому вы столкнулись с проблемой спасибо...
попробуй этот
public class MyFragment extends ListFragment{
String[] from = { "php_key","c_key","android_key","hacking_key" };
String[] name_of_bookmarks = { "php","c","android","hacking" };
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
List<HashMap<String, String>> list= new ArrayList<HashMap<String,String>>();
for (int i = 0; i < name_of_bookmarks.length; i++) {
HashMap<String, String> map= new HashMap<String, String>();
map.put("key", name_of_bookmarks[i]);
list.add(map);
}
String[] from = { "key" };
int[] to = { R.id.txt};
SimpleAdapter adapter = new SimpleAdapter(getActivity().getBaseContext(), list, R.layout.list_layout, from, to);
setListAdapter(adapter);
return super.onCreateView(inflater, container, savedInstanceState);
}
}