В моем коде странная ошибка, и я не вижу проблемы. У меня есть основной класс, где у меня есть другой класс внутри. У меня есть 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, но его данные не включают его, и при щелчке по нему все строки определяются как одинаковые.