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);
    }

}