AFAIK simple_list_item_2 zawiera TwoLineListItem zawierający dwa TextViews. ArrayAdapter nie będzie tutaj działał, musisz albo utworzyć niestandardową kartę, albo użyć takiej, która obsługuje ją jak SimpleCursorAdapter.
ListAdapter adapter = new SimpleCursorAdapter(
this,
android.R.layout.simple_list_item_2,
mCursor, // Pass in the cursor to bind to.
new String[] {People.NAME, People.COMPANY}, // Array of cursor columns to bind to.
new int[] {android.R.id.text1, android.R.id.text2}); // Parallel array of which template objects to bind to those columns.
// Bind to our new adapter.
setListAdapter(adapter);
Albo jeśli nie chcesz SimpleCursorAdapter Trzeba będzie tworzyć niestandardowe ArrayAdapter lub BaseAdapter
Tworzenie niestandardowego ArrayAdapter zastosować obiekt (o dwie pozycje) tablicę do adaptera niestandardowego, a podaj go do getListView.setAdapter.
Zastąp metodę getView metody ArrayAdapter, aby zastosować łańcuchy nazw do widoku TextView w widoku niestandardowego widoku listy.
Poniższy fragment pomoże Ci.
SampleActivity.java
package org.sample;
import java.util.ArrayList;
import android.app.ListActivity;
import android.content.Context;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;
import android.widget.TwoLineListItem;
public class SampleActivity extends ListActivity {
@Override
public void onCreate(Bundle icicle) {
super.onCreate(icicle);
Person person;
ArrayList<Person> persons = new ArrayList<Person>();
person = new Person();
person.setName("Vipul");
person.setAge(20);
persons.add(person);
person = new Person();
person.setName("Anil");
person.setAge(22);
persons.add(person);
setListAdapter(new MyAdapter(this, persons));
}
}
Person.java
class Person {
String name;
int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
MyAdapter.java
class MyAdapter extends BaseAdapter {
private Context context;
private ArrayList<Person> persons;
public MyAdapter(Context context, ArrayList<Person> persons) {
this.context = context;
this.persons = persons;
}
@Override
public int getCount() {
return persons.size();
}
@Override
public Object getItem(int position) {
return persons.get(position);
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
TwoLineListItem twoLineListItem;
if (convertView == null) {
LayoutInflater inflater = (LayoutInflater) context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
twoLineListItem = (TwoLineListItem) inflater.inflate(
android.R.layout.simple_list_item_2, null);
} else {
twoLineListItem = (TwoLineListItem) convertView;
}
TextView text1 = twoLineListItem.getText1();
TextView text2 = twoLineListItem.getText2();
text1.setText(persons.get(position).getName());
text2.setText("" + persons.get(position).getAge());
return twoLineListItem;
}
}
użyć pobierające/ustawiaczy w 'Person.Java' to jest coś Porady Google w przewodniku skuteczności. – Fred
Strona z poradami dotyczącymi wydajności na stronie Android @ poleca programistom "unikanie programów pobierających/ustawiających WEWNĘTRZNE", dzięki którym wydają się odnosić do metod uzyskiwania dostępu do zmiennych członkowskich.To nie znaczy, że nie powinieneś pisać swoich klas z odpowiednimi interfejsami, z którymi reszta świata może wchodzić w interakcje. I w tym samym napiwku wskazują również, że ProGuard dodaje do siebie i pobiera setery, co czyni cały argument dyskusyjny. – spaaarky21
To jest doskonała odpowiedź, zawierająca zarówno wymagane informacje, jak i bardzo praktyczne zastosowania w kodzie. – LarsH