仿小红书顶部自适应高度viewpager

不废话,上效果图:


首先获取第一张图片的高度设置给viewpager,在viewpager滑动的时候调用onPageScrolled()方法,动态的设置viewpager的高

//为ViewPager设置高度
ViewGroup.LayoutParams params = mViewpager.getLayoutParams();
params.height = defaultheight;
mViewpager.setLayoutParams(params);
mViewpager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
    @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
        if (position == imgheights.length - 1) {
            return;
        }

        //计算ViewPager现在应该的高度,heights[]表示页面高度的数组。
        int height = (int) ((imgheights[position] == 0 ? defaultheight : imgheights[position])
                * (1 - positionOffset) +
                (imgheights[position + 1] == 0 ? defaultheight : imgheights[position + 1])
                        * positionOffset);

        //为ViewPager设置高度
        ViewGroup.LayoutParams params = mViewpager.getLayoutParams();
        params.height = height;
        mViewpager.setLayoutParams(params);
    }

    @Override
    public void onPageSelected(int position) {
    }

    @Override
    public void onPageScrollStateChanged(int state) {

    }
});


DEMO源码

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值