RollViewPager图片轮播效果开源框架使用方法详解

作者:曹半斤 时间:2021-12-06 07:22:59 

RollViewPager是一个自动轮播的Viewpager,支持无限循环。 触摸时会暂停播放,直到结束触摸一个延迟周期以后继续播放。 看起来就像这样。指示器可以为点可以为数字还可以自定义,位置也可以变。

附上RollViewPager Github地址:https://github.com/Jude95/RollViewPager

使用Android Studio开发在gradle添加依赖:


compile 'com.jude:rollviewpager:1.4.5'

在布局文件当中使用:


<com.jude.rollviewpager.RollPagerView
 android:layout_width="match_parent"
 android:layout_height="180dp"
 app:rollviewpager_play_delay="3000"/>

要使用到RollViewPager自定义属性的时候,在布局文件当中我们必须添加:


xmlns:app="http://schemas.android.com/apk/res-auto

RollPagerView自定义属性:

app:rollviewpager_play_delay="3000" 播放间隔时间,单位ms。填0则不播放。默认为0 app:rollviewpager_hint_gravity="center" 指示器位置,提供left,center,right。默认center
app:rollviewpager_hint_color="#7c7c7c" 指示器背景颜色.默认黑色
app:rollviewpager_hint_alpha="80" 指示器背景透明度。0全透明,255不透明。默认0.
app:rollviewpager_hint_paddingLeft="16dp" 指示器左边距
app:rollviewpager_hint_paddingRight="16dp" 指示器右边距
app:rollviewpager_hint_paddingTop="16dp" 指示器上边距
app:rollviewpager_hint_paddingBottom="16dp" 指示器下边距

一般指定一下间隔时间。

RollViewPager提供了自定义指示器的类:HintView 用法

参数说明:上下文,当前轮播图指示器图片 默认指示器图片
mRollViewPager.setHintView(new IconHintView(this,R.drawable.point_focus,R.drawable.point_normal));
mRollViewPager.setHintView(new ColorPointHintView(this, Color.YELLOW,Color.WHITE));
mRollViewPager.setHintView(new TextHintView(this));
mRollViewPager.setHintView(null);//隐藏指示器

设置点击事件:


pagerView.setOnItemClickListener(new OnItemClickListener() {
     @Override
     public void onItemClick(int position) {
       Toast.makeText(MainActivity.this,""+position,Toast.LENGTH_SHORT).show();
     }
   });

提供以下三种种方便的PagerAdapter供使用。

本ViewPager也可以使用其他任意PagerAdapter。

StaticPagerAdapter:

存储页面的Adapter。view添加进去就存储不会再次getView,减少页面创建消耗,消耗内存。一般自动播放的情况这种方案比较好。不然会大量构造View。 概念参照FragmentPagerAdapter。可以用于其他ViewPager。


class MyPagerAdapter extends StaticPagerAdapter {

private int[] image = {R.mipmap.one, R.mipmap.two, R.mipmap.three, R.mipmap.four};

// SetScaleType(ImageView.ScaleType.CENTER_CROP);
   // 按比例扩大图片的size居中显示,使得图片长(宽)等于或大于View的长(宽)

@Override
   public View getView(ViewGroup container, int position) {
     ImageView imageView = new ImageView(container.getContext());
     imageView.setImageResource(image[position]);
     imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
     imageView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
     return imageView;
   }

@Override
   public int getCount() {
     return image.length;
   }
 }

DynamicPagerAdapter (跟以上Adapter用法一样)
动态的Adapter。当创建3号view时会销毁1号view(递推),会时常调用getView。增加页面创建消耗,减小内存消耗。 概念参照FragmentStatePagerAdapter。可以用于其他ViewPager。

LoopPagerAdapter

无限循环的Adapter。无限循环上采用的是getCount返回int大数的方法(并没有什么缺点,另外估计1s的间隔时间你在有生之年看不到他播放到底)。实测比第N页跳转到第1页的效果好。

数据采用StaticPagerAdapter的方案。节省创建View开销。 本Adapter只能用于本RollViewPager;

无需其他设置,很简单。


mRollViewPager.setAdapter(new TestLoopAdapter(mRollViewPager));
private class TestLoopAdapter extends LoopPagerAdapter{
 private int[] imgs = {
     R.drawable.img1,
     R.drawable.img2,
     R.drawable.img3,
     R.drawable.img4,
 };

public TestLoopAdapter(RollPagerView viewPager) {
   super(viewPager);
 }

@Override
 public View getView(ViewGroup container, int position) {
   ImageView view = new ImageView(container.getContext());
   view.setImageResource(imgs[position]);
   view.setScaleType(ImageView.ScaleType.CENTER_CROP);
   view.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
   return view;
 }

@Override
 public int getRealCount() {
   return imgs.length;
 }
}

播放控制


rollViewPager.pause()
rollViewPager.resume()
rollViewPager.isPlaying()

MainActivity代码:


public class MainActivity extends AppCompatActivity {

private RollPagerView pagerView;

@Override
 protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   setContentView(R.layout.activity_main);

pagerView = (RollPagerView) findViewById(R.id.rollPagerView);

//设置适配器
   pagerView.setAdapter(new MyPagerAdapter());

pagerView.setOnItemClickListener(new OnItemClickListener() {
     @Override
     public void onItemClick(int position) {
       Toast.makeText(MainActivity.this,""+position,Toast.LENGTH_SHORT).show();
     }
   });
   //对指示器的自定义 参数说明:上下文,当前轮播图指示器图片 默认指示器图片
//    pagerView.setHintView(new IconHintView(this,R.mipmap.ic_launcher,R.mipmap.fouse));

}

class MyPagerAdapter extends StaticPagerAdapter {

private int[] image = {R.mipmap.one, R.mipmap.two, R.mipmap.three, R.mipmap.four};

// SetScaleType(ImageView.ScaleType.CENTER_CROP);
   // 按比例扩大图片的size居中显示,使得图片长(宽)等于或大于View的长(宽)

@Override
   public View getView(ViewGroup container, int position) {
     ImageView imageView = new ImageView(container.getContext());
     imageView.setImageResource(image[position]);
     imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
     imageView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
     return imageView;
   }

@Override
   public int getCount() {
     return image.length;
   }
 }
}

xml代码:


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:app="http://schemas.android.com/apk/res-auto"
 android:layout_width="match_parent"
 android:layout_height="match_parent">
 <!--rollviewpager_play_delay 播放时间间隔默认为0-->
 <com.jude.rollviewpager.RollPagerView
   android:layout_width="match_parent"
   android:layout_height="150dp"
   android:id="@+id/rollPagerView"
   app:rollviewpager_play_delay="3000"
   >
 </com.jude.rollviewpager.RollPagerView>
</RelativeLayout>

附上效果图:

RollViewPager图片轮播效果开源框架使用方法详解

来源:http://blog.csdn.net/cgq1030699125/article/details/53760444

标签:RollViewPager,图片轮播
0
投稿

猜你喜欢

  • Unity实现切割图集工具

    2021-07-03 23:14:57
  • MyBatis的注解使用、ORM层优化方式(懒加载和缓存)

    2023-04-24 09:16:13
  • java IO流 之 输出流 OutputString()的使用

    2023-08-11 23:16:30
  • springboot异常处理的基本规范

    2023-11-23 15:48:19
  • Java中Mybatis-Plus使用方式介绍

    2021-11-14 05:49:56
  • Unity3D开发实战之五子棋游戏

    2023-06-01 12:25:56
  • MyBatisPlus中CRUD使用方法详解

    2023-04-10 18:31:43
  • Swagger2配置方式(解决404报错)

    2022-08-30 17:21:13
  • 浅析JAVA中的内存结构、重载、this与继承

    2023-09-24 19:15:07
  • Android Git submodule详解用法示例

    2021-10-23 11:39:03
  • Android游戏开发之黑白棋

    2023-05-24 13:39:03
  • Android沉浸式顶部实现代码及效果

    2021-06-19 18:51:49
  • LRU缓存替换策略及C#实现方法分享

    2021-08-27 04:20:49
  • java Matcher匹配头尾截取替换字符串的案例

    2023-01-30 11:44:48
  • mybatis mybatis-plus-generator+clickhouse自动生成代码案例详解

    2021-06-06 10:12:55
  • Android AndBase框架内部封装实现进度框、Toast框、弹出框、确认框(二)

    2022-01-14 12:18:38
  • 使用Java 实现一个“你画手机猜”的小游戏

    2021-06-03 19:19:27
  • java微信企业号开发之通讯录

    2022-04-28 12:51:40
  • 一文详解Reactor模型与实现示例

    2023-11-13 12:22:09
  • C#常用字符串加密解密方法封装代码

    2022-03-04 08:50:48
  • asp之家 软件编程 m.aspxhome.com