Android指示器,轮播与循环轮播

boyanx3周前技术教程7

Android UI Libs之CircleIndicator

1. 说明

CircleIndicator,顾名思义,圆形指示器,只一个可以用来做轮播的第三方库。

2. 配置

在模块的build.gradle中添加依赖:compile '
me.relex:circleindicator:1.2.1@aar'

3. 基本使用

在xml布局文件中定义ViewPagerCircleIndicator

<RelativeLayout

android:layout_width="match_parent"

android:layout_height="150dp">

<android.support.v4.view.ViewPager

android:id="@+id/view_pager"

android:layout_width="match_parent"

android:layout_height="150dp">

</android.support.v4.view.ViewPager>

<me.relex.circleindicator.CircleIndicator

android:id="@+id/indicator"

android:layout_width="match_parent"

android:layout_height="48dp"/>

</RelativeLayout>

注意:ViewPagerCircleIndicator一般放在同一个RelativeLayout中,并且CircleIndicator放在后面

在java文件中的相关操作:

this.indicator = (CircleIndicator) findViewById(R.id.indicator); this.viewpager = (ViewPager) findViewById(R.id.view_pager);

List<Fragment> list=new ArrayList<>();

myFragment1 = new MyFragment(R.drawable.image1);

myFragment2 = new MyFragment(R.drawable.image2);

myFragment3 = new MyFragment(R.drawable.image3); list.add(myFragment1); list.add(myFragment2); list.add(myFragment3);

MyPagerAdapter myPagerAdapter=new MyPagerAdapter(getSupportFragmentManager(),list);

viewpager.setAdapter(myPagerAdapter);

indicator.setViewPager(viewpager);

MyFragment是我自定义的Fragment,它里面包含一个ImageViewMyPagerAdapter是我自定义的Adapter。

程序运行界面:

我们发现可以轮播,但是不能循环,我们想要循环怎么办,别担心,下一节我们来实现循环轮播。

CircleIndicator还有下面一些属性,属性命名很规则,一看名字就知道属性是干什么的:

  • app:ci_width:

  • app:ci_height

  • app:ci_margin

  • app:ci_drawable

  • app:ci_drawable_unselected

  • app:ci_animator

  • app:ci_animator_reverse

  • app:ci_orientation (default:horizontal)

  • app:ci_gravity (default:center)

4. 高级使用

该库的LoopingViewPager目录下面为我们提供了循环的ViewPager,我们需要将其中的LoopPagerAdapterWrapperLoopViewPager这两个类复制到我们的项目中来就。然后要将
android.support.v4.view.ViewPager
改为
com.lavor.circleindicatordemo.LoopViewPager

  • 当我们的Adapter是继承自FragmentPagerAdapter 时,无法使用该循环的ViewPager(即LoopViewPager

  • 当我们的Adapter是SamplePagerAdapter时,SamplePagerAdapter是该库实例中的一个Adapter时,可以循环轮播,但是明显从最后一个滑动到第一个时,第一页显示了两次,貌似利用该库中的LoopViewPager还无法解决这个问题。

我们要实现循环轮播的最佳解决方案:

  • 利用另一个库LoopViewPager下面的LoopViewPager

  • 修改CircleIndicator下面CircleIndicator的源代码,将setViewPager(ViewPager viewPager)方法中的ViewPager改为上面所提库中的LoopViewPager,并将与之关联的ViewPager都改为上面所提库中的LoopViewPager,其他关联代码对应改过来。

程序运行后的界面:

程序源代码下载,我的github仓库:
https://github.com/lavor-zl/UILibs

欢迎关注我的微信公众号:Android技术漫谈

欢迎关注我的简述专题:Android技术漫谈

标签: 轮播图代码

相关文章

源码推荐(04.08):iOS八种传值,Login动画效果

iOS八种传值(上传者:iOS大小白)对八种传值通过不同小demo进行划分看起来更方便Login动画效果(上传者:miaoguodong)动画效果的简单实现.登录页面的动画效果.简易图片轮播器(上传者...

Uniapp开发鸿蒙购物项目教程之样式选择器

大家好,今天依然为大家带来鸿蒙跨平台开发教程的分享,我们本系列的教程最终要做一个购物应用,通过这个项目为大家分享uniapp开发鸿蒙应用从配置开发环境到应用打包上架的完成过程。昨天的文章实现了应用首页...

前端开发-CSS3动画实现焦点(图文轮播)图效果

焦点图主要是指网页焦点位置的图片,一般焦点图可以是单张图,也可以是一组动态切换的图片的组合。由于处在终端用户视觉焦点位置因此焦点图的作用至关重要,焦点图也成为网站首页面设计的重点。焦点图样式如下所示:...

如何用 DevEco Studio 的 ArkUI Inspector 轻松搞定鸿蒙应用 UI 布局

作为一名鸿蒙应用开发者,我最近遇到了一个让我头疼不已的 UI 问题——一个看似简单的页面布局,却在真机上出现了严重的错位问题。按钮重叠、文本溢出、图片显示不全……这些问题不仅影响了用户体验,还让我在调...

2022年版前端学习路线图-黑马程序员

由简易版前端学习路线图看详细的2022前端学习内容。本内容由黑马程序员2022年最新整理发布:HTML+CSS-->移动web->JavaScript基础-->Web APIs-&g...

照片尺寸/大小调整终极指南!10种方法+微信小程序秘技,全场景

血亏警告!这些操作90%的人都踩过坑 "证件照尺寸不对被退回!" "朋友圈封面裁成马赛克!" "压缩后图片模糊像打了马赛克..." 数据显示,83%的...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。