您的位置:首页 > 其它

GridView动态设置Item的宽高 第一个Item不显示的问题

2014-12-09 12:53 381 查看
在viewpaper中添加了一个Gridview,每个viewpaper要正好铺满显示3X2个,由于girdview是纵向可扩展的,所以我需要动态设置Gridview中item的高度,来确认铺满。遇到的问题:Gridview中第一个item不显示动态设置Item的高度只需要在adapter的getView方法中 使用parent的宽高进行重新计算就行了废话不多说,直接上代码
@Override
public View getView(final int position, View convertView, ViewGroup parent) {

Holder holder = null;
if (null == convertView) {
holder = new Holder();
LayoutInflater mInflater = LayoutInflater.from(mContext);
convertView = mInflater.inflate(R.layout.f2_gridview_item, parent, false);//这句可以避免黄色的叹号
<span style="white-space:pre">			</span>/*根据parent的高度动态设置当前converView的宽高理论上就ok了 */
convertView.setLayoutParams(new AbsListView.LayoutParams((int) (parent.getWidth() / 3) - 1, (int) (parent.getHeight() / 2)));// 动态设置item的高度
holder.btn_gv_item = (ImageView) convertView.findViewById(R.id.btn_gv_item);
convertView.setTag(holder);
} else {
holder = (Holder) convertView.getTag();
<pre name="code" class="java">                       /*下边这句就是为了重新设置一下设置下converView大小 */
<pre name="code" class="java">                        convertView.setLayoutParams(new AbsListView.LayoutParams((int) (parent.getWidth() / 3) - 1, (int) (parent.getHeight() / 2)));
}// _Holder.btn_gv_item.setText(mLists.get(position));return convertView;}
解决这个问题的时候,参考了 农民伯伯的:http://www.cnblogs.com/over140/p/3999815.html   刚才是我按照农民伯伯的思路去写,没有在else中写convertView.setLayoutParams这个,就出现了第一条Item不显示的bug。经过调试发现是因为parent第一次高度获取不到,然后又在else中添加了这段代码,发现居然成功了
回过头来看了下农民伯伯的那篇,发现我的写法似乎正好符合他那个错误的方式。于是乎我就更加迷茫了。然后给农民伯伯留言,想和他交流下,这个具体是怎么回事。
如果你看见这篇文章后,你的问题没有解决,你去按照农民伯伯那个方式试验下。  后续有结果会即使通知大家
本着无图无真相的原则,上两种图。
bug显示图片<img src="https://img-blog.csdn.net/20141209125042273?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvWF9pX2Ffb19IX2FfaQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" /> 
修改后的代码<img src="https://img-blog.csdn.net/20141209125217027?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvWF9pX2Ffb19IX2FfaQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐