首页 > 系统 > Android > 正文

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

2020-02-21 17:23:14
字体:
来源:转载
供稿:网友

Rollviewpager是支持无限循环的自动旋转viewpager,其实这样的指示器可以是数字或自定义,接下来武林技术频道小编就给大家详解RollViewPager图片轮播效果开源框架使用方法。

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图片轮播效果开源框架使用方法,如果说还有什么好的技巧或者说是不懂的地方,欢迎大家和武林技术频道小编进行探讨。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表