最近发现GridView使用的时候,有两个Bug,在getView方法里边。
第一个bug:position的位置不准确,经常出现0.对于此bug目前还没有引起什么大的问题,就先不考虑。
第二个bug:先看图
这里,我的gridView放了100多张图片,但是按普通的做法,发现大概能显示20张图片之后,接下来再往下拉,所有图片都是重复的。
我之前的代码这么写的:
public View getView(final int position, View convertView, ViewGroup parent) {
if (convertView== null) {
//这里生成convertView...
//convertView=...省略若干行
}
return convertView;
我用log跟踪后,发现前二十多张图片,都可以进入 convertView== null 的条件里边,但是再往下啦,都进不去了,就是说,convertView已经不等于null,直接返回了,导致了,后来的图片,都和前面的图片一致重复....要想显示其余的图片,只好重新想办法了。
既然依靠这个convertView是否等于null来判断不靠谱,干脆就不用它了。我这里自己使用一个map来保存当前可显示的convertView,当往下拉时,就把上面的convertView删除,当往上拉时,就把下面的convertView删除。首先声明一个保存convertView的hashMap:
private HashMap currentViews;
别忘了new一下。
然后改写上面的getView方法:
public View getView(final int position, View convertView, ViewGroup parent) {
if (!currentViews.containsKey(position) || currentViews.get(position) == null) {
//这里生成convertView...
//convertView=...省略若干行
//currentViews.put(position, convertView);
//releaseCurrentViews();释放不可见的view
}
/***
*
* DOC 释放当前不可见的图片资源.
*/
private void releaseCurrentViews() {
synchronized (currentViews) {
if (currentViews.size() > 18) {
for (int i = 1; i < gridView.getFirstVisiblePosition() - 3; i++) {
currentViews.remove(i);
}
for (int i = gridView.getLastVisiblePosition() + 3; i < imageFile.getPicturesList().size(); i++) {
currentViews.remove(i);
}
}
}
}
这里,每当map里的view数量大于18的时候,就把不可见的view都去除。需要注意的是,移除view的时候,第一个循环是从1开始的,而不是0,这是因为刚才上面说的第一个bug,那个position老是出现0,如果这里把0位置的给移除了,上面getView的时候就会报nullpoint的异常。所以索性从1开始循环。最后问题得到解决。