Я успешно реализовал отложенную загрузку для списка. Все в порядке; загрузка изображений и текста. У меня есть 2 части информации для текста; Наименование и описание. Я могу безупречно отобразить изображение и имя. Но как только я пытаюсь включить описание в него, кажется, что все в порядке до определенной позиции. Программа принудительно закрывается в этой позиции. Не могу понять, что вызывает его закрытие. Есть идеи, что может быть причиной? Результаты, отображаемые в logcat, печатают примерно до половины от общего количества печатаемых элементов.
Программа способна извлекать все изображения и отображать их корректно. Это точно. Но возникли проблемы с извлечением всего фрагмента текстового содержимого. Он извлекает только половину всего доступного текста.
Я использую пример из здесь .
LazyAdapter.java
public class LazyAdapter extends BaseAdapter {
private Activity activity;
private String[] data;
private String[] text;
private static LayoutInflater inflater=null;
public ImageLoader imageLoader;
public LazyAdapter(Activity a, String[] d, String[] t) {
activity = a;
data=d;
text = t;
inflater = (LayoutInflater)activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
imageLoader=new ImageLoader(activity.getApplicationContext());
}
public int getCount() {
return data.length;
}
public Object getItem(int position) {
return position;
}
public long getItemId(int position) {
return position;
}
public static class ViewHolder{
public TextView text;
public ImageView image;
}
public View getView(int position, View convertView, ViewGroup parent) {
View vi=convertView;
ViewHolder holder;
if(convertView==null){
vi = inflater.inflate(R.layout.item, null);
holder=new ViewHolder();
holder.text=(TextView)vi.findViewById(R.id.text);;
holder.image=(ImageView)vi.findViewById(R.id.image);
vi.setTag(holder);
}
else
holder=(ViewHolder)vi.getTag();
holder.text.setText(text[position]);
holder.image.setTag(data[position]);
imageLoader.DisplayImage(data[position], activity, holder.image);
return vi;
}
}
Ошибка исключения в logcat показана ниже.
ERROR/AndroidRuntime(270): java.lang.ArrayIndexOutOfBoundsException
ERROR/AndroidRuntime(270): at com.lazy.LazyAdapter.getView(LazyAdapter.java:59)
ERROR/AndroidRuntime(270): at android.widget.AbsListView.obtainView(AbsListView.java:1294)
ERROR/AndroidRuntime(270): at android.widget.ListView.makeAndAddView(ListView.java:1727)
ERROR/AndroidRuntime(270): at android.widget.ListView.fillDown(ListView.java:652)
ERROR/AndroidRuntime(270): at android.widget.ListView.fillGap(ListView.java:623)
ERROR/AndroidRuntime(270): at android.widget.AbsListView.trackMotionScroll (AbsListView.java:2944)
ERROR/AndroidRuntime(270): at android.widget.AbsListView$FlingRunnable.run (AbsListView.java:2485)
ERROR/AndroidRuntime(270): at android.os.Handler.handleCallback(Handler.java:587)
ERROR/AndroidRuntime(270): at android.os.Handler.dispatchMessage(Handler.java:92)
ERROR/AndroidRuntime(270): at android.os.Looper.loop(Looper.java:123)
ERROR/AndroidRuntime(270): at android.app.ActivityThread.main(ActivityThread.java:4627)
ERROR/AndroidRuntime(270): at java.lang.reflect.Method.invokeNative(Native Method)
ERROR/AndroidRuntime(270): at java.lang.reflect.Method.invoke(Method.java:521)
ERROR/AndroidRuntime(270): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
ERROR/AndroidRuntime(270): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
ERROR/AndroidRuntime(270): at dalvik.system.NativeStart.main(Native Method)