安卓自定义控件之item高度不同的viewpager

定义:嵌套在scrollview或listview中时viewpager的高度需要固定,但是每一个item的高度都不相同,所以在viewpager切换结束的时候重置viewpager高度

import android.content.Context;
import android.support.v4.view.ViewPager;
import android.util.AttributeSet;
import android.view.View;

/**
 * Created by wangliang on 0018/2016/8/18.
 */
public class MyViewPager extends ViewPager {


    public MyViewPager(Context context) {
        super(context);
    }

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


    private int widthMeasureSpec;
    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        this.widthMeasureSpec = widthMeasureSpec;
        if(getChildCount() > 0) {
            View view = getChildAt(0);
            view.measure(widthMeasureSpec, MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
            super.onMeasure(widthMeasureSpec, MeasureSpec.makeMeasureSpec(view.getMeasuredHeight(), MeasureSpec.AT_MOST));
        }else {
            super.onMeasure(widthMeasureSpec, heightMeasureSpec);
        }

    }

    /**
     * 在切换tab的时候,重置ViewPager的高度
     */
        public void resetViewHeightToShowViewHeight(View showView){
            showView.measure(widthMeasureSpec, MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
            super.onMeasure(widthMeasureSpec, MeasureSpec.makeMeasureSpec(showView.getMeasuredHeight(), MeasureSpec.AT_MOST));
            layout(getLeft(),getTop(),getRight(), (int) (showView.getMeasuredHeight() + getY()));
    }




}

调用:

 @Override
        public void onPageScrollStateChanged(int state) {
            if( state == 0 && lvShowDetail.getFirstVisiblePosition() != 0) {
                lvShowDetail.smoothScrollToPosition(0);
            }

            if(vpgShowDetail != null && h1 != null && h2 != null) {
                switch (vpgShowDetail.getCurrentItem()) {
                    case 0:
                        vpgShowDetail.resetViewHeightToShowViewHeight(View);
                        break;
                    case 1:
                        vpgShowDetail.resetViewHeightToShowViewHeight(lv);
                        break;
                }
            }
        }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值