android ViewPager实现自动无限轮播和下方向导圆点

一、布局

小圆点形状的生成shape.xml文件

使用空心还是实心的把对应的注释去掉就可以了.

<?xml version="1.0" encoding="utf-8"?>
<shape
 xmlns:android="http://schemas.android.com/apk/res/android"
 android:shape="oval"
 android:useLevel="false">

 <!-- 实心圆
  <solid android:color="#F00"/>
 -->
 <!-- 空心圆
  <stroke
   android:width="1dp"
   android:color="@android:color/black"/>
 -->
 <size android:width="8dp"
 android:height="8dp"/>
</shape>

轮播的ViewPager和向导圆点的 布局文件XML

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="200dp">
 <android.support.v4.view.ViewPager
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/hometab_vp"
  android:layout_width="match_parent"
  android:layout_height="200dp">
 </android.support.v4.view.ViewPager>
 <RelativeLayout
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_alignParentBottom="true"
  android:layout_centerHorizontal="true"
  android:layout_marginBottom="20dp"
  >

  <LinearLayout
   android:id="@+id/ll_dot"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:orientation="horizontal">

   <ImageView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:src="@drawable/shape_guide_dot_default"/>

   <ImageView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginLeft="5dp"
    android:src="@drawable/shape_guide_dot_default"/>

   <ImageView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginLeft="5dp"
    android:src="@drawable/shape_guide_dot_default"/>

   <ImageView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginLeft="5dp"
    android:src="@drawable/shape_guide_dot_default"/>

   <ImageView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginLeft="5dp"
    android:src="@drawable/shape_guide_dot_default"/>
  </LinearLayout>

  <ImageView
   android:id="@+id/dot_red"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:src="@drawable/shape_guide_dot_solid"/>
 </RelativeLayout>
</RelativeLayout>

二,代码

左右轮播的ViewPager的Adapter

/**
 * 轮播 viewpager的adapter
 */
class MyLoopPagerAdapter extends PagerAdapter {

 private int[] welcomes;
 private Context mContext;

 public MyLoopPagerAdapter(int[] welcomes, Context context) {
  this.welcomes = welcomes;
  mContext = context;
 }

 //  //返回实际要显示的图片数+2
 @Override
 public int getCount() {
  return welcomes.length + 2;
 }

 @Override
 public boolean isViewFromObject(View view, Object object) {
  return view == object;
 }

 @Override
 public Object instantiateItem(ViewGroup container, int position) {
  ImageView iv = new ImageView(mContext);
  int realPosition = (position - 1 + welcomes.length) % welcomes.length;
//    设置背景图片
  iv.setBackgroundResource(welcomes[realPosition]);
  container.addView(iv);
  return iv;
 }

 @Override
 public void destroyItem(ViewGroup container, int position, Object object) {
  //注意不要remove 否则容易闪屏
  //     container.removeView((ImageView) object);
 }
}

添加viewpager的addOnPageChangeListener

/**
  * 循环轮播界面change的 监听器
  */
 class MyLoopPageChangeListener implements ViewPager.OnPageChangeListener {

  private ViewPager mViewPager;
  private LinearLayout mLlDot;
  private ImageView dotRed;
  private Handler mHandler;
  private Runnable mRunnable;

  /**
   * 初始化 控件 和 handler
   *
   * @param viewPager
   * @param llDot
   * @param dotRed
   */
  public MyLoopPageChangeListener(ViewPager viewPager, LinearLayout llDot, ImageView dotRed) {
   mViewPager = viewPager;
   this.mLlDot = llDot;
   this.dotRed = dotRed;
   initAutoLoop();
  }

  /**
   * 初始化 自动轮播 handler 和 runnable
   */
  private void initAutoLoop() {
   mHandler = new Handler() {
    @Override
    public void handleMessage(Message msg) {
//     LogUtils.e("have received a msg");
     int curindex = (mViewPager.getCurrentItem() + 1) % (welcomes.length + 2);
     mViewPager.setCurrentItem(curindex, true);
    }
   };
   mRunnable = new Runnable() {
    @Override
    public void run() {
     Message message = new Message();
     mHandler.sendMessage(message);
    }
   };
//   开始 轮播
   mHandler.postDelayed(mRunnable, 3 * 1000);
  }

  /**
   * 当页面在滑动了调用
   *
   * @param position    当前页面,即点击滑动的页面
   * @param positionOffset  当前页面偏移的百分比
   * @param positionOffsetPixels 当前页面偏移的像素位置
   */
  @Override
  public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
//   获取到 真正图片所在的位置.
   int realPosition = (position - 1 + welcomes.length) % welcomes.length;
//   获取到红点 的 layout 参数
   RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) dotRed.getLayoutParams();
//   计算两个点之间的距离
   int dotDis = mLlDot.getChildAt(1).getLeft() - mLlDot.getChildAt(0).getLeft();
//   计算总共的左边距
   int totalLeftMargin = (welcomes.length - 1) * dotDis;
   // 计算滑动的距离
   float dis = realPosition * dotDis + positionOffset * dotDis;
//   设置 margin_left 的值,
//   如果 position 等于 0 说明正在从第一个图片想最后一个滑动,那么保持 向导的状态为不动
   if (position == 0) {
    params.leftMargin = 0;
//    如果滑动距离超过了 最大边距,那么将最大边距赋值给 红点的参数左边距
   } else if (dis > totalLeftMargin) {
    params.leftMargin = totalLeftMargin;
//    正常情况 就将滑动的距离 直接赋值
   } else {
    params.leftMargin = (int) dis;
   }
//   设置红点的 参数
   dotRed.setLayoutParams(params);
//    在position4左滑且左滑positionOffset百分比接近1时,偷偷替换为position1(原本会滑到position5)
   if (position == welcomes.length && positionOffset > 0.99) {
    mViewPager.setCurrentItem(1, false);
//    在position1右滑且右滑百分比接近0时,偷偷替换为position4(原本会滑到position0)
   } else if (position == 0 && positionOffset < 0.01) {
    mViewPager.setCurrentItem(welcomes.length, false);
   }
  }

  @Override
  public void onPageSelected(int position) {
  }

  @Override
  public void onPageScrollStateChanged(int state) {
   switch (state) {
    case 0://什么都没做 空闲状态
     break;
    case 1://正在滑动:
//     手动滑动 取消自动滑动
     mHandler.removeCallbacks(mRunnable);
     break;
    case 2://滑动完毕:
//     继续 自动滑动
     mHandler.postDelayed(mRunnable, 3 * 1000);
     break;
   }
  }
 }
// 主要的算法参考下图
int realPosition = (position - 1 + welcomes.length) % welcomes.length; 

由下图可以发现,应该初始化ViewPager.setCurrentItem(1);才能从预设的第一页开始播放。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android使用ViewPager加载图片和轮播视频

    作为Android基础组件之一,大家对viewpager已经很熟悉了,网上也有很多使用viewpager来加载图片的案例.但是像微信那样点击图片,可以轮播显示图片和视频的例子却没找到.正巧项目中有需求,可以就花时间写了下,现在给一下核心代码,希望对有此需求的同学们起一个抛砖引玉的作用.话不多说了,上代码: 以下是initData的代码 public void initData() { //把聊天界面的图片和视频找出来,并加到数组中,并在 //并根据传进来的position来找到视频或图片在数组中

  • Android中用RxJava和ViewPager实现轮播图

    前言 很多人要实现轮播图都会想到使用ViewPager + Handler来完成轮播图的效果.但是在RxJava快速发展的情况下,已经可以使用RxJava来代替Handler完成这样任务了. 下面我们就来介绍如何实现RxJava+ViewPager的轮播图. 效果图如下 ViewPager的操作 说到ViwePager应该大家都不陌生,它可以结合普通的View也可以结合Fragment一起使用.在此我也就不对它的使用方法进行过多的介绍了.直接开始介绍轮播的方法. 常见的轮播操作 private

  • Android viewpager自动轮播和小圆点联动效果

    本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下 首先来看一下我们要做成的而效果: 主页面要显示一个viewpager自动轮播+小圆点联动的效果 : 废话不多说,直接上代码: 布局文件: activity_main.xml: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.andro

  • Android实现基于ViewPager的无限循环自动播放带指示器的轮播图CarouselFigureView控件

    最近用到需要无限轮播自动播放的轮播轮播图,网上感觉都有这样那样的问题,于是自己写了一个通用的控件CarouselFigureView. 特点: 1.可以轮播view可以自己定义,不一定是要是ImageView2.指示器默认显示,但是可以隐藏3.可以设置指示器的颜色.间距.大小 4.有基础的可以自己修改代码改变指示器位置,这个应该不难5.可以自己开启和关闭自动轮播,开启轮播的时候可以设置轮播时间间隔,默认3000毫秒 我们先来看看效果图: 然后来看看使用代码 xml代码 <?xml version

  • Android 中使用 ViewPager实现屏幕页面切换和页面轮播效果

    之前关于如何实现屏幕页面切换,写过一篇博文<Android中使用ViewFlipper实现屏幕切换>,相比ViewFlipper,ViewPager更适用复杂的视图切换,而且Viewpager有自己的adapter,这也让其适应复杂对象,实现数据的动态加载. ViewPager是谷歌官方给我们提供的一个兼容低版本安卓设备的软件包,里面包囊了只有在安卓3.0以上可以使用的api.而viewpager就是其中之一,利用它,我们可以做很多事情,从最简单的导航,到页面菜单等等. 下面我们就展示下Vie

  • Android 使用ViewPager实现左右循环滑动及轮播效果

    ViewPager是一个常用的Android组件,不过通常我们使用ViewPager的时候不能实现左右无限循环滑动,在滑到边界的时候会看到一个不能翻页的动画,可能影响用户体验.此外,某些区域性的ViewPager(例如展示广告或者公告之类的ViewPager),可能需要自动轮播的效果,即用户在不用滑动的情况下就能够看到其他页面的信息. 循环滑动效果的实现:PagerAdapter 我们知道ViewPager自带的滑动效果非常出色,因此我们基本不需要处理这个滑动,只处理内容的显示.而内容的显示是由

  • Android ViewPager实现轮播图效果

    先上一张效果图: 说到ViewPager实现轮播图效果,那么肯定会用到PagerAdapter,下面先介绍下这个类. PagerAdapter简介 PagerAdapter是Android.support.v4包中的类,是一个抽象类,直接继承于Object,导入包android.support.v4.view.PagerAdapter即可使用. PagerAdapter主要是viewpager的适配器,而viewPager则也是在android.support.v4扩展包中新添加的一个强大的控件

  • Android使用ViewPager实现自动轮播

    很多APP中都实现了类似引导页的自动轮播,不由得想到昨天的引导页上修改一下代码实现轮播. 其实大体上只需要添加一个线程循环执行就可以了. 项目已同步至:https://github.com/nanchen2251/viewpagerDemo 同样的先上图 直接上代码,注释都全的,我想这样更有利于理解. 先改了Adapter  package com.example.nanchen.taketurnplaydemo; import android.support.v4.view.PagerAdap

  • Android 使用ViewPager自动滚动循环轮播效果

    对Android 利用ViewPager实现图片可以左右循环滑动效果,感兴趣的朋友可以直接点击查看内容详情. 主要介绍如何实现ViewPager自动播放,循环滚动的效果及使用.顺便解决ViewPager嵌套(ViewPager inside ViewPager)影响触摸滑动及ViewPager滑动速度设置问题. 先给大家展示下效果图,喜欢的朋友可以下载源码: 1.实现 没有通过ScheduledExecutorService或Timer定期执行某个任务实现,而是简单的通过handler发送消息去

  • Android ViewPager实现图片轮播效果

    在app中图片的轮播显示可以说是非常常见的实现效果了,其实现原理不过是利用ViewPager,然后利用handler每隔一定的时间将ViewPager的currentItem设置为当前item的position+1即可.先来看看效果图吧: 就是实现这样的一个轮播广告的效果. 因为这个是自己为了练习仿照某旅游类App做的,所以这里的数据是使用抓包工具抓取的,准备数据等工作就不在这里赘述了,反正数据的添加大体都是相同的.我的思路是这样的,从网络上实时的获取数据(当然你也可以将数据写死),然后通过网络

随机推荐