Вам может понадобиться использовать настраиваемое представление списка с адаптером пользовательского массива. См. Например, link.
Содержание:
Андроида HelloListView (http://developer.android.com/resources/tutorials/views/hello-listview.html) учебнике показано, как связать ListView в массив строковых объектов, но вы, вероятно, перерастет, что довольно быстро. Это сообщение покажет вам, как привязать ListView к ArrayList для пользовательских объектов, а также создать многострочный ListView.
Предположим, у вас есть какая-то функция поиска, которая возвращает список людей, а также адреса и номера телефонов. Мы собираемся отобразить эти данные в трех отформатированных строках для каждого результата и сделать его интерактивным.
Сначала создайте новый проект для Android и создайте два файла макета. Main.xml, вероятно, уже будет создан по умолчанию, поэтому вставьте в:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<TextView
android:layout_height="wrap_content"
android:text="Custom ListView Contents"
android:gravity="center_vertical|center_horizontal"
android:layout_width="fill_parent" />
<ListView
android:id="@+id/ListView01"
android:layout_height="wrap_content"
android:layout_width="fill_parent"/>
</LinearLayout>
Затем создайте файл макета под названием custom_row_view.xml. Этот макет будет шаблоном для каждой отдельной строки в ListView. Вы можете использовать почти любой тип макета - относительная, таблица и т.д., но для этого мы будем использовать Linear:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<TextView android:id="@+id/name"
android:textSize="14sp"
android:textStyle="bold"
android:textColor="#FFFF00"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
<TextView android:id="@+id/cityState"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
<TextView android:id="@+id/phone"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
</LinearLayout>
Теперь добавьте объект под названием SearchResults. Вставьте этот код в:
public class SearchResults {
private String name = "";
private String cityState = "";
private String phone = "";
public void setName(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setCityState(String cityState) {
this.cityState = cityState;
}
public String getCityState() {
return cityState;
}
public void setPhone(String phone) {
this.phone = phone;
}
public String getPhone() {
return phone;
}
}
Это класс, который мы будем заполнять с нашими данными, и загружаются в ArrayList.
Далее вам понадобится специальный адаптер. Это просто расширяет BaseAdapter, но вы можете расширить ArrayAdapter, если хотите.
public class MyCustomBaseAdapter extends BaseAdapter {
private static ArrayList<SearchResults> searchArrayList;
private LayoutInflater mInflater;
public MyCustomBaseAdapter(Context context, ArrayList<SearchResults> results) {
searchArrayList = results;
mInflater = LayoutInflater.from(context);
}
public int getCount() {
return searchArrayList.size();
}
public Object getItem(int position) {
return searchArrayList.get(position);
}
public long getItemId(int position) {
return position;
}
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
convertView = mInflater.inflate(R.layout.custom_row_view, null);
holder = new ViewHolder();
holder.txtName = (TextView) convertView.findViewById(R.id.name);
holder.txtCityState = (TextView) convertView.findViewById(R.id.cityState);
holder.txtPhone = (TextView) convertView.findViewById(R.id.phone);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
holder.txtName.setText(searchArrayList.get(position).getName());
holder.txtCityState.setText(searchArrayList.get(position).getCityState());
holder.txtPhone.setText(searchArrayList.get(position).getPhone());
return convertView;
}
static class ViewHolder {
TextView txtName;
TextView txtCityState;
TextView txtPhone;
}
}
(Это в основном то же, что и List14.Java API демо)
Наконец, мы телеграфировать все это в главном файле класса:
public class CustomListView extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ArrayList<SearchResults> searchResults = GetSearchResults();
final ListView lv1 = (ListView) findViewById(R.id.ListView01);
lv1.setAdapter(new MyCustomBaseAdapter(this, searchResults));
lv1.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> a, View v, int position, long id) {
Object o = lv1.getItemAtPosition(position);
SearchResults fullObject = (SearchResults)o;
Toast.makeText(ListViewBlogPost.this, "You have chosen: " + " " + fullObject.getName(), Toast.LENGTH_LONG).show();
}
});
}
private ArrayList<SearchResults> GetSearchResults(){
ArrayList<SearchResults> results = new ArrayList<SearchResults>();
SearchResults sr1 = new SearchResults();
sr1.setName("John Smith");
sr1.setCityState("Dallas, TX");
sr1.setPhone("214-555-1234");
results.add(sr1);
sr1 = new SearchResults();
sr1.setName("Jane Doe");
sr1.setCityState("Atlanta, GA");
sr1.setPhone("469-555-2587");
results.add(sr1);
sr1 = new SearchResults();
sr1.setName("Steve Young");
sr1.setCityState("Miami, FL");
sr1.setPhone("305-555-7895");
results.add(sr1);
sr1 = new SearchResults();
sr1.setName("Fred Jones");
sr1.setCityState("Las Vegas, NV");
sr1.setPhone("612-555-8214");
results.add(sr1);
return results;
}
}
Обратите внимание, что мы сначала получить ArrayList объектов SearchResults (обычно это было бы от внешнего источника данных ...), перейдите к пользовательскому адаптеру, затем настройте прослушиватель кликов. Слушатель получает элемент, который был нажат, преобразует его обратно в объект SearchResults и делает все, что ему нужно.
благодаря @thinksteep, я имел взгляд через него и адаптировать его к моему коду, но я все еще получаю ошибки - 'окончательный ListView lv1 = (ListView) findViewById (R.id.list);' это значение null и выбрасывает исключение NullPointerException – Krath
У вас есть расширенный список? Если это так, getlistview должно быть достаточно. Обновите вопрос с помощью последнего кода. – kosa
Я думаю, что у меня есть - я следовал примеру слово в слово, но заменил бит, в котором вы заполняете список, - какой код я должен добавить в редактирование? – Krath