在列表视图中,我想在列表条目上绘制一个图像。
这 20 张图像必须缩放以填充垂直模式的宽度。
手机分辨率为 480 x 800 像素 (SGS2)。
图像分辨率为 400x400,大小约为 100KB。
我已将图像放在可绘制文件夹中。
当我滚动列表时,它并不顺利。
我明白了一些事情:
- 应用程序堆大小 = 有限,首次运行时分配 = 13MB,剩余 1 MB。
- 我有 GC_FOR_ALLOC 日志消息,它使系统停止 15 毫秒。 (我认为这是我滚动的滞后)。
- 更改代码后,我还看到 GC_CONCURRENT 消息。
通过这些 GC 消息,我了解每次滚动到新列表视图条目中的另一个图像时都会启动垃圾收集。
到目前为止我可以分析这一点,但我不知道到底该怎么做才能永久修复和删除 GC。
我已将图像缩小到 100x100,这将 GC 消息推迟了更长的时间。
但最终 GC 开始发挥作用。
我确实使用 ConvertView 回收视图,并已经在视图中使用了持有者。
我读过有关重新使用图像内存的内容,但不确定是否以及如何执行此操作。
或者,也许在列表视图中使用这些较大的图像时这是“正常的”,我需要重新考虑图像的绘制,并且只在滚动结束时才开始绘制?
我应该使用 Listview 来滚动图片吗?
2012-12-31_02:11 我已经实现了setOnScrollListener,它使滚动变得平滑。
我认为这是我必须进一步研究的一段代码,以锦上添花。
列表视图适配器
public class ListviewAdapter extends BaseAdapter {
private static Activity activity;
private int[] data;
private static LayoutInflater mInflater = null;
public ListviewAdapter(Activity a, int[] d) {
activity = a;
data = d;
mInflater = (LayoutInflater) activity
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
}
public int getCount() {
return data.length;
}
public Object getItem(int position) {
return 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.listviewitem, parent,
false);
holder = new ViewHolder();
holder.picture = (ImageView) convertView.findViewById(R.id.image);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
if (!MainActivity.isScrolling) {
holder.picture.setImageResource(data[position]);
}
return convertView;
}
static class ViewHolder {
ImageView picture;
}
}
列表视图XML
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/image"
android:src="@drawable/stub"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:contentDescription="Animal images"
android:scaleType="fitCenter"
android:scrollingCache="false"
android:animationCache="false"
/>
</LinearLayout>