在列表视图中,我想在列表条目上绘制一个图像。这 20 张图像必须缩放以填充垂直模式下的宽度。手机分辨率为 480 x 800 像素 (SGS2)。图像分辨率为 400x400,大小约为 100KB。我已将图像放在可绘制文件夹中。
当我滚动列表时,它并不顺利。
我了解一些事情: - 应用程序堆大小 = 有限,首次运行时分配 = 13MB,剩下 1 MB。- 我有 GC_FOR_ALLOC 日志消息,它会使系统停止 15 毫秒。(我认为这是我在滚动方面的滞后)。- 更改代码后,我还看到 GC_CONCURRENT 消息。
有了这些 GC 消息,我知道每次滚动到新列表视图条目中的另一个图像时,我的垃圾收集就会启动。到目前为止,我可以对此进行分析,但我不知道该怎么做才能永久修复和删除 GC。我已将图像缩小到 100x100,它会将 GC 消息推迟更长的时间。但最终 GC 开始了。我确实使用 convertview 回收视图,并已经在视图中使用了持有者。
我读过关于重用图像内存的文章,但不确定我是否以及如何做到这一点。或者,在列表视图中使用这些较大的图像时,这可能是“正常的”,我需要重新考虑图像的绘制,并且只有在 scolling 结束时才开始绘制?
我应该使用 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>