Rollviewpager图片轮播框架的使用

特别说明

当前博客平台账号已废弃,如果有使用细节问题请前往我新博客平台进行讨论交流。

个人博客平台 HuRuWo的技术小站

文章首发于个人博客HuRuWo的技术小站,如果本文非vip用户无法完全浏览或者图片无法打开,可前往个人博客文章地址查看文章并留言讨论。

个人博客文章地址Rollviewpager图片轮播框架的使用

更多技术文章访问本人博客HuRuWo的技术小站,包括 Electron从零开发 Android 逆向 app 微信数据抓取 抖音数据抓取 闲鱼数据抓取 小红书数据抓取 其他软件爬虫 等技术文章

这个框架已知 有 严重 BUG 但是作者放弃更新 所以不建议使用 可以使用其他框架

效果:

Paste_Image.png

参考github说明:

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

项目地址:

https://github.com/Jude95/RollViewPager

引用:

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"/>

其他属性:

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" 指示器下边距

一般指定一下间隔时间就好了。

HintView

提供了HintView是对指示器进行自定义。
setHintView(HintView hintview)

HintView

        ShapeHintView

            IconHintView

            ColorPointHintView

        TextHintView

用法:

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);//隐藏指示器

 

ItemClickListener

 

mRollViewPager.setOnItemClickListener(new OnItemClickListener() {

  @Override

  public void onItemClick(int position) {

      Toast.makeText(MainActivity.this,"Item "+position+" clicked",Toast.LENGTH_SHORT).show();

  }

});

Adapter

提供以下三种种方便的PagerAdapter供使用。
本ViewPager也可以使用其他任意PagerAdapter。

StaticPagerAdapter

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

DynamicPagerAdapter

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

//2个Adapter用法一样;

mRollViewPager.setAdapter(new TestNomalAdapter());

private class TestNomalAdapter extends StaticPagerAdapter{

   private int[] imgs = {

           R.drawable.img1,

           R.drawable.img2,

           R.drawable.img3,

           R.drawable.img4,

   };



   @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 getCount() {

       return imgs.length;

   }

}

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()

简单的LoopDapter示例:

布局

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

调用:

private RollPagerView mLoopViewPager;
private TestLoopAdapter mLoopAdapter;
private String[] url = {
        "http://img4.imgtn.bdimg.com/it/u=149733435,2204929951&fm=21&gp=0.jpg",
        "http://img0.imgtn.bdimg.com/it/u=1822612231,1570693415&fm=21&gp=0.jpg",  "http://imgb.mumayi.com/android/wallpaper/2011/12/02/sl_600_2011120206442919871869.jpg",    "http://f.hiphotos.baidu.com/zhidao/pic/item/c9fcc3cec3fdfc03dfdfafcad23f8794a4c22618.jpg"};

代码设置:

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


    mLoopViewPager = (RollPagerView) findViewById(R.id.loop_view_pager);
    mLoopViewPager.setPlayDelay(1000);
    mLoopViewPager.setAdapter(mLoopAdapter = new TestLoopAdapter(mLoopViewPager));
    mLoopAdapter.setImgs(url);
    mLoopViewPager.setHintView(new IconHintView(this, R.drawable.point_focus, R.drawable.point_normal));
    //mRollViewPager.setHintView(new TextHintView(this));
    //mRollViewPager.setHintView(null);
    mLoopViewPager.setOnItemClickListener(new OnItemClickListener() {
        @Override
        public void onItemClick(int position) {
            Toast.makeText(MainActivity.this, "Item " + position + " clicked", Toast.LENGTH_SHORT).show();
        }
    });
}

适配器:

private class TestLoopAdapter extends LoopPagerAdapter {
    String[] imgs = new String[0];

    public void setImgs(String[] imgs) {
        this.imgs = imgs;
        notifyDataSetChanged();
    }


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

    @Override
    public View getView(ViewGroup container, int position) {
        Log.i("RollViewPager", "getView:" + imgs[position]);

        ImageView view = new ImageView(container.getContext());
        view.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Log.i("RollViewPager", "onClick");
            }
        });
        view.setScaleType(ImageView.ScaleType.CENTER_CROP);
        view.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
        Glide.with(MainActivity.this)
                .load(imgs[position])
                .placeholder(R.drawable.img4)
                .error(R.drawable.img1)
                .into(view);
        return view;
    }

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

}

测试:

my.gif
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,392评论 5 470
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,258评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,417评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,992评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,930评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,199评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,652评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,327评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,463评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,382评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,432评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,118评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,704评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,787评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,999评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,476评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,057评论 2 341

推荐阅读更多精彩内容