ViewPager标签栏滑条

本文介绍如何通过设置ViewPager的OnPageChangeListener监听器来实现页面切换时滑动块的同步移动效果。重点解析了onPageScrolled()方法的参数含义及其在同步滑动条位置中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


主要实现是依靠ViewPager设置OnPageChangeListener监听。

mViewPager.setOnPageChangeListener(new OnPageChangeListener() {

			@Override
			public void onPageSelected(int arg0) {
				// TODO Auto-generated method stub
				Log.d("onPageSelected", ""+arg0);
				if(!mIsBeChoose)
					mChooseBar.setCurrentPosition(arg0);
			}
			
			@Override
			public void onPageScrolled(int position, float arg1, int positionOffsetPixels) {
				// TODO Auto-generated method stub
				Log.i("onPageScrolled", ""+position+" "+arg1+" "+positionOffsetPixels);
				mSlideLayout.scrollTo((int) (-(position+arg1)*mWidthOfSlideBlock), 0);
			}
			
			@Override
			public void onPageScrollStateChanged(int arg0) {
				// TODO Auto-generated method stub
				if(arg0 == 0){
				    mIsBeChoose = false;
				}
				Log.e("onPageScrollStateChanged", ""+arg0);
			}
		});
关键是要理解onPageScrolled()函数的各个参数的含义:第一个参数position是当前屏幕显示的页中页号的最小值,然后第二个参数是页号最小的页占当前占屏幕的百分比。然后注意scrolleTo的原理,就可以写出调用的式子:mSlideLayout.scrollTo((int) (-(position+arg1)*mWidthOfSlideBlock), 0);


源码:https://github.com/HOOOOOO/ViewPagerSlideBlock

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值