GridView的特殊派生应用

 一、ScrollView + GridView

 在ScrollView中放置GridView,无论GridView的高度是设置 wrap_content,还是 match_parent,最终渲染时GridView都会发生形变,原因是 ScrollView 不能正确算出 GridView 的实际显示高度。

 

 解决方法有两个:

 

  1.  设定GridView 高度的dp值,同时也可配合使用 values/dimens.xml 进行适配,缺点是适配难度大,不灵活,而且 GridView 的 Adapter 中的 convertView 可能不再重用(GridView不能滚动),导致需要调整 getView 的代码。
  2.  重写GridView 计算高度的方法:
public class CanInScrollGridView extends GridView {
    public CanInScrollGridView(Context context) {
        super(context);
    }

    public CanInScrollGridView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public CanInScrollGridView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }

    @Override
    public void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        // Calculate entire height by providing a very large height hint.
        // View.MEASURED_SIZE_MASK represents the largest height possible.
        int expandSpec = MeasureSpec.makeMeasureSpec(MEASURED_SIZE_MASK,
                MeasureSpec.AT_MOST);
        super.onMeasure(widthMeasureSpec, expandSpec);

        ViewGroup.LayoutParams params = getLayoutParams();
        params.height = getMeasuredHeight();     //获取实际的显示高度
    }

}

 

 二、GridView实现伪“瀑布流”

Github上的牛人项目:https://github.com/maurycyw/StaggeredGridView

StaggeredGridView本质上并不是GridView的派生,不过它实现GirdView的功能、并对其进行扩展,可以使得列表的项目不对称显示,如下图:

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值