引导页圆点的滑动两种实现方式

首先看一下页面的布局:
这里写图片描述
就是通过向悬浮在viewpager上的LinearLayout里面添加ImageView,
添加是需要注意,不能将同一对象添加多次,所以每个图片都的创建然后再添加到LinearLayout里面去,在LinearLayout的最右边在放一个FrameLayout,也就是FocusImage(当前获得页面的指示器)。
方法一:用属性动画(不能实时跟随页面的滑动)
重点就是计算所添加图片相互之间的距离,其实就是先获得Linearlayout的两个ImageView的水平位置差:

m2PointWidth = mcontainer.getChildAt(1).getLeft()-mcontainer.getChildAt(0).getLeft();

这里也是要注意的,不能立即得到这个值,需要等界面都渲染完了之后才能得到。可以通过这种方式得到:

ViewTreeObserver treeObserver2=mcontainer.getViewTreeObserver();
        treeObserver2.addOnGlobalLayoutListener(new OnGlobalLayoutListener() {
            @Override
            public void onGlobalLayout() {
                mcontainer.getViewTreeObserver().removeOnGlobalLayoutListener(this);
                 m2PointWidth = mcontainer.getChildAt(1).getLeft()-mcontainer.getChildAt(0).getLeft();
                System.out.println("两个圆点之间的距离:" + m2PointWidth);
            }
        });

有时间会介绍几种计算获得控件大小的方法
然后再给ViewPager加PageChangeListener,就是在它的onPageSelected方法中去添加属性动画将FocusImage作为Target
之前说不能跟随滑动是因为该方法是在页面选中之后才会触发,
圆点移动计算:当前页position*两个小圆点的距离
属性动画就是滑动后停在那个位置,所以移动顺序0*m2PointWidthl—>1*m2PointWidthl—->2*m2PointWidthl, 反向也是类似
具体代码:

viewpager.addOnPageChangeListener(new OnPageChangeListener() {
            @Override
            public void onPageSelected(int pageindex) {
                ObjectAnimator animator = ObjectAnimator.ofFloat(focusdot, "translationX", pageindex*m2PointWidthl);
                animator.setDuration(600);
                animator.start();
            }

            @Override
            public void onPageScrolled(int arg0, float arg1, int arg2) {
                // 再次添加动画

            }

            @Override
            public void onPageScrollStateChanged(int arg0) {

            }
        });

方法二:用LayoutParam动画(可以实时跟随页面的滑动)
第二种方式和之前的那种前面的步骤其实一样,就是动画实现放在viewpager的pagerChangerListener中的方法不一样,而是放在onPageScrolled方法中,这个方法会在页面滑动时一直触发,所以才能跟随页面的滑动。
圆点移动计算:当前位置+手指滑动的距离=(小圆点间的距离当前页面position)+(小圆点间的距离*滑动的百分比positionOffset)

        viewpager.addOnPageChangeListener(new OnPageChangeListener() {
            @Override
            public void onPageSelected(int pageindex) {

            }

            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
                // 再次添加动画
                 int len = (int) (m2PointWidth * positionOffset) + position * m2PointWidth;
                FrameLayout.LayoutParams params = (FrameLayout.LayoutParams) focusdot.getLayoutParams();// 获取当前蓝点的布局参数
                params.leftMargin = len;// 设置左边距
                focusdot.setLayoutParams(params);
            }

            @Override
            public void onPageScrollStateChanged(int arg0) {

            }
        });

运行效果:
第一种
这里写图片描述
第二种
这里写图片描述

package com.bim.splash; import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.os.Bundle; import android.support.v4.view.ViewPager; import android.support.v4.view.ViewPager.OnPageChangeListener; import android.view.LayoutInflater; import android.view.View; import android.widget.ImageView; import android.widget.LinearLayout; import com.bim.smarterpark.R; public class GuideActivity extends Activity implements OnPageChangeListener { private ViewPager vp; private ViewPagerAdapter vpAdapter; private List<View> views; // 底部小点图片 private ImageView[] dots; // 记录当前选中位置 private int currentIndex; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.guide); // 初始化页面 initViews(); // 初始化底部小点 initDots(); } private void initViews() { LayoutInflater inflater = LayoutInflater.from(this); views = new ArrayList<View>(); // 初始化引导图片列表 views.add(inflater.inflate(R.layout.what_new_one, null)); views.add(inflater.inflate(R.layout.what_new_two, null)); views.add(inflater.inflate(R.layout.what_new_three, null)); // 初始化Adapter vpAdapter = new ViewPagerAdapter(views, this); vp = (ViewPager) findViewById(R.id.viewpager); vp.setAdapter(vpAdapter); // 绑定回调 vp.setOnPageChangeListener(this); } private void initDots() { LinearLayout ll = (LinearLayout) findViewById(R.id.ll); dots = new ImageView[views.size()]; // 循环取得小点图片 for (int i = 0; i < views.size(); i++) { dots[i] = (ImageView) ll.getChildAt(i); dots[i].setEnabled(true);// 都设为灰色 } currentIndex = 0; dots[currentIndex].setEnabled(false);// 设置为白色,即选中状态 } private void setCurrentDot(int position) { if (position < 0 || position > views.size() - 1 || currentIndex == position) { return; } dots[position].setEnabled(false); dots[currentIndex].setEnabled(true); currentIndex = position; } // 当滑动状态改变时调用 @Override public void onPageScrollStateChanged(int arg0) { } // 当当前页面滑动时调用 @Override public void onPageScrolled(int arg0, float arg1, int arg2) { } // 当新的页面被选中时调用 @Override public void onPageSelected(int arg0) { // 设置底部小点选中状态 setCurrentDot(arg0); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值