Класс видит array.lengh но нет его данных - PullRequest
0 голосов
/ 12 февраля 2012

В моем коде странная ошибка, и я не вижу проблемы. У меня есть основной класс, где у меня есть другой класс внутри. У меня есть arraylist, объявленный в основном классе, и если я получаю к нему доступ в некоторой части класса, я могу иметь всю информацию, но когда я получаю к нему доступ во внутреннем классе, он не может видеть данные. Почему?

Внутренний класс - это BaseAdapter для создания списка просмотра. Я назвал это из oncreate bundle как:

public class Main extends ListActivity implements OnClickListener {
//new adapter
private EfficientAdapter adap;
//The variable which makes the error
public static ArrayList<String> data2 = new ArrayList<String>();    
protected static Context mContext=null;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.nuevoingr);

    data2.clear();
    data2.add("just adding 1");
    adap = new EfficientAdapter(this);
    setListAdapter(adap);

и внутренний класс (проблема в конце):

public static class EfficientAdapter extends BaseAdapter implements Filterable {
    private LayoutInflater mInflater;
    private Context context;

    public EfficientAdapter(Context context) {
        // Cache the LayoutInflate to avoid asking for a new one each time.
        mInflater = LayoutInflater.from(context);
        this.context = context;
    }

    /**
     * Make a view to hold each row.
     *
     * @see android.widget.ListAdapter#getView(int, android.view.View,
    *      android.view.ViewGroup)
    */
    public View getView(final int position, View convertView, ViewGroup parent) {
        // A ViewHolder keeps references to children views to avoid
        // unneccessary calls
        // to findViewById() on each row.
        ViewHolder holder;

        // When convertView is not null, we can reuse it directly, there is
        // no need
        // to reinflate it. We only inflate a new View when the convertView
        // supplied
        // by ListView is null.
        if (convertView == null) {
            convertView = mInflater.inflate(R.layout.pruebas, null);

            // Creates a ViewHolder and store references to the two children
            // views
            // we want to bind data to.
            holder = new ViewHolder();
            holder.textLine = (TextView) convertView.findViewById(R.id.pr2);
            holder.buttonLine = (ImageButton) convertView.findViewById(R.id.pr1);


            convertView.setOnClickListener(new OnClickListener() {
                private int pos = position;

                @Override
                public void onClick(View v) {
                    Toast.makeText(context, "Click-" + String.valueOf(pos), Toast.LENGTH_SHORT).show();   
                }
            });

            holder.buttonLine.setOnClickListener(new OnClickListener() {
                private int pos = position;

                @Override
                public void onClick(View v) {
                    Toast.makeText(context, "Delete-" + String.valueOf(pos), Toast.LENGTH_SHORT).show();     
                }
            });
            convertView.setTag(holder);
        } else {
            // Get the ViewHolder back to get fast access to the TextView
            // and the ImageView.
            holder = (ViewHolder) convertView.getTag();
        }

        // Bind the data efficiently with the holder.
        holder.textLine.setText(String.valueOf(position));

        return convertView;
    }

    static class ViewHolder {
        TextView textLine;
        ImageButton buttonLine;
    }

    @Override
    public Filter getFilter() {
        // TODO Auto-generated method stub
        return null;
    }

    @Override
    public long getItemId(int position) {
        // TODO Auto-generated method stub
        return 0;
    }


//Here it comes the problem. Before editing my program this code was provide to include     only a few values from 
a String array declared at the same moment of data2 called data. What I do now is to     declare an arraylist so
 I can include more values and then I refresh the adaptor and here I pass the arraylist     to an array to be equal as
 it was before.
    @Override
    public int getCount() {
        // TODO Auto-generated method stub
        String [] change = (String[]) data2.toArray(new String[data2.size()]);  
        return change.length;
        //return data.length;
    }
//Same problem   
    @Override
    public Object getItem(int position) {
        // TODO Auto-generated method stub

        String [] change = (String[]) data2.toArray(new String[data2.size()]);
        return change[position];
        //return data[position];
    }

}

Что странно, так это то, что этот baseAdapter предназначен для просмотра списка, и когда он обновляет свои данные, они отображаются в виде строк как arraylist.length, но его данные не включают его, и при щелчке по нему все строки определяются как одинаковые.

Ответы [ 2 ]

0 голосов
/ 16 февраля 2012

Проблема решена.Я изменил код на этот: techdroid.kbeanie.com / 2009/07 / custom-listview-for-android.html

0 голосов
/ 12 февраля 2012

попробуйте это:

@Override
public int getCount() {
    if(Main.data2!=null)
    {
        return Main.data2.size();
    }
    else
    {
        return 0;
    }
}

@Override
public String getItem(int position) {
    if(Main.data2!=null)
    {
        return Main.data2.get(position);
    }
    else
    {
        return null;
    }
}
...