第一次写博客,有不好的地方希望大家多多指正哦!
进入本文的重点,根据项目需求需要动态设置图片的大小,如果固定item的宽高,显示出来的图片之间的间距可能会很大,造成分布不均的后果。
上第一种情况的代码:
@Override
public View getView(int position, View convertView,
ViewGroup parent) {
// TODO Auto-generated method stub
DisplayMetrics dm = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(dm);
int screenWidth = dm.widthPixels;
int itemWidth = (screenWidth - BitmapUtil.Dp2Px(mcContext, 24) + 80 - 4 * BitmapUtil.Dp2Px(mcContext, 2))/3;
GridView.LayoutParams param = new GridView.LayoutParams(itemWidth, itemWidth);
final int curposition = position;
ImageViewHolder holder = null;
if (convertView == null) {
holder = new ImageViewHolder();
convertView = LayoutInflater.from(mcContext).inflate(
R.layout.wx_home_pic_item, parent, false);
convertView.setLayoutParams(param);
holder.image = (ImageView) convertView.findViewById(R.id.item_iv_display);
convertView.setTag(holder);
} else {
holder = (ImageViewHolder) convertView.getTag();
// convertView.setLayoutParams(param);
}
这种情况出来的效果是图片完全挤成一团,并没有均匀分布,原因是convertView.setLayoutParams(param);写在判断条件中获取不到每个item的宽度,放在外面的话显示正常,但点击无效,至于为什么无效,目前无解,希望大神告知一二,将不胜感激。
解决方法:
GridView.LayoutParams param = new GridView.LayoutParams(itemWidth, itemWidth);
把itemWidth改为(int)(parent.getWidth()/3 - 5)即可。
-5是为了扩大行间距。