Как использовать ArrayAdapter <myClass>
ArrayList<MyClass> myList = new ArrayList<MyClass>();
ListView listView = (ListView) findViewById(R.id.list);
ArrayAdapter<MyClass> adapter = new ArrayAdapter<MyClass>(this, R.layout.row,
to, myList.);
listView.setAdapter(adapter);
Класс: MyClass
class MyClass {
public String reason;
public long long_val;
}
Я создал row.xml в макетах, но не знаю, как показать как причину, так и long_val в ListView с помощью ArrayAdapter.
Ответы
Ответ 1
Внедрение пользовательского адаптера для вашего класса:
public class MyClassAdapter extends ArrayAdapter<MyClass> {
private static class ViewHolder {
private TextView itemView;
}
public MyClassAdapter(Context context, int textViewResourceId, ArrayList<MyClass> items) {
super(context, textViewResourceId, items);
}
public View getView(int position, View convertView, ViewGroup parent) {
if (convertView == null) {
convertView = LayoutInflater.from(this.getContext())
.inflate(R.layout.listview_association, parent, false);
viewHolder = new ViewHolder();
viewHolder.itemView = (TextView) convertView.findViewById(R.id.ItemView);
convertView.setTag(viewHolder);
} else {
viewHolder = (ViewHolder) convertView.getTag();
}
MyClass item = getItem(position);
if (item!= null) {
// My layout has only one TextView
// do whatever you want with your string and long
viewHolder.itemView.setText(String.format("%s %d", item.reason, item.long_val));
}
return convertView;
}
}
Для тех, кто не очень хорошо знаком с каркасом Android, это более подробно описано здесь: https://github.com/codepath/android_guides/wiki/Using-an-ArrayAdapter-with-ListView.
Ответ 2
Вы можете просто добавить метод toString()
для MyClass, за http://developer.android.com/reference/android/widget/ArrayAdapter.html:
Однако ссылка TextView ссылается, она будет заполнена toString() каждого объекта в массиве. Вы можете добавлять списки или массивы пользовательских объектов. Переопределите метод toString() ваших объектов, чтобы определить, какой текст будет отображаться для элемента в списке.
class MyClass {
@Override
public String toString() {
return "Hello, world.";
}
}
Ответ 3
Я думаю, что это лучший подход. Использование общего класса ArrayAdapter и расширение вашего собственного адаптера объекта так же просто:
public abstract class GenericArrayAdapter<T> extends ArrayAdapter<T> {
// Vars
private LayoutInflater mInflater;
public GenericArrayAdapter(Context context, ArrayList<T> objects) {
super(context, 0, objects);
init(context);
}
// Headers
public abstract void drawText(TextView textView, T object);
private void init(Context context) {
this.mInflater = LayoutInflater.from(context);
}
@Override public View getView(int position, View convertView, ViewGroup parent) {
final ViewHolder vh;
if (convertView == null) {
convertView = mInflater.inflate(android.R.layout.simple_list_item_1, parent, false);
vh = new ViewHolder(convertView);
convertView.setTag(vh);
} else {
vh = (ViewHolder) convertView.getTag();
}
drawText(vh.textView, getItem(position));
return convertView;
}
static class ViewHolder {
TextView textView;
private ViewHolder(View rootView) {
textView = (TextView) rootView.findViewById(android.R.id.text1);
}
}
}
и вот ваш адаптер (пример):
public class SizeArrayAdapter extends GenericArrayAdapter<Size> {
public SizeArrayAdapter(Context context, ArrayList<Size> objects) {
super(context, objects);
}
@Override public void drawText(TextView textView, Size object) {
textView.setText(object.getName());
}
}
и, наконец, как его инициализировать:
ArrayList<Size> sizes = getArguments().getParcelableArrayList(Constants.ARG_PRODUCT_SIZES);
SizeArrayAdapter sizeArrayAdapter = new SizeArrayAdapter(getActivity(), sizes);
listView.setAdapter(sizeArrayAdapter);
Я создал Gist с TextView layout гравитацией настраиваемый ArrayAdapter:
https://gist.github.com/m3n0R/8822803
Ответ 4
Подкласс ArrayAdapter и переопределите метод getView(), чтобы вернуть собственное представление, содержащее содержимое, которое вы хотите отобразить.
Ответ 5
Вот быстрый и грязный пример использования ArrayAdapter, если вы не хотите беспокоиться о расширении материнского класса:
class MyClass extends Activity {
private ArrayAdapter<String> mAdapter = null;
@Override
protected void onCreate(Bundle savedInstanceState) {
mAdapter = new ArrayAdapter<String>(getApplicationContext(),
android.R.layout.simple_dropdown_item_1line, android.R.id.text1);
final ListView list = (ListView) findViewById(R.id.list);
list.setAdapter(mAdapter);
//Add Some Items in your list:
for (int i = 1; i <= 10; i++) {
mAdapter.add("Item " + i);
}
// And if you want selection feedback:
list.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
//Do whatever you want with the selected item
Log.d(TAG, mAdapter.getItem(position) + " has been selected!");
}
});
}
}