首页 > 其他分享 >AdPlayBanner:功能丰富、一键式使用的图片轮播插件

AdPlayBanner:功能丰富、一键式使用的图片轮播插件

时间:2023-06-15 12:31:39浏览次数:66  
标签:插件 颜色 轮播 int AdPlayBanner TitleView 设置 功能丰富 页码


概述


AdPlayBanner:功能丰富、一键式使用的图片轮播插件


详细



AdPlayBanner是一个Android平台基于ViewPager实现的轮播图插件,主要用以自动或者手动地播放轮播图,提供了Fresco、Picasso、Glide等图片加载方式供用户使用,以及多种图片切换动画,设置轮播时间,设置数据源顺序,提供不同分页指示器等功能,实现了一键式、灵活式的控件使用方式。下面是效果图:


目前AdPlayBanner已经开源到了Github上面,大家可以在Github上面查看本控件的Demo,或者直接使用。

Github地址为:https://github.com/ryanlijianchang/AdPlayBanner

一、使用方法

1.添加依赖

build.gradle文件添加依赖:


allprojects {
    repositories {
        ...
        maven { url 'https://jitpack.io' }
    }
}


build.gradle文件添加依赖:


dependencies {
    compile 'com.github.ryanlijianchang:AdPlayBanner:v0.2'
}



2.在布局文件中添加控件

在布局文件中添加AdPlayBanner控件,根据自己的需要设置高度,注意,控件需要在一个布局(可以是LinearLayout,RelativeLayout,FrameLayout等)之内。



<com.ryane.banner_lib.AdPlayBanner
    android:id="@+id/game_banner"
    android:layout_width="match_parent"
    android:layout_height="200dp" />



3.在Activity中绑定控件



mAdPlayBanner = (AdPlayBanner) findViewById(R.id.game_banner);



4.添加网络权限

由于加载的是网络图片,所以需要在Manifests文件中添加网络请求权限



<uses-permission android:name="android.permission.INTERNET" />



5.初始化Fresco

默认使用Fresco加载图片,所以按照Fresco官方做法,需要在Application创建时初始化Fresco,常规做法如下:

(1) 创建MyApplication类继承Application,然后在onCreate()方法中初始化Fresco:

public class MyApplication extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
        Fresco.initialize(this);
    }
}

android:name="你的类名":


<application
    android:name=".MyApplication"
    ...>

    ...

</application>



当然,如果你不使用Fresco加载,以上步骤可以跳过。

6.一键式使用

AdPlayBanner使用了Builder设计模式,所以可以通过一键式写法来直接装载AdPlayBanner,当然也可以使用常规写法。在使用之前需要先设置数据源,使用ArrayList来封装数据,而AdPageInfo是一个封装好的Bean类,封装如下:

public class AdPageInfo implements Parcelable {
    public String title;    // 广告标题
    public String picUrl;   // 广告图片url
    public String clickUlr; // 图片点击url
    public int order;       // 顺序
}

mDatas之后,使用Builder模式写法,一句话就可以使用AdPlayBanner了。注意,setUp()方法必须在调用完所有API之后,最后调用:


mAdPlayBanner.setInfoList(mDatas).setUp();


当然,你也可以使用常规写法:



mAdPlayBanner.setInfoList(mDatas);
mAdPlayBanner.setUp();



7.关闭AdPlayBanner

mAdPlayBanner.stop()方法结束AdPlayBanner,避免内存泄漏。

二、功能介绍

1.自定义数据顺序

setUp()方法之前,我们需要设置数据源,每一页的数据使用AdPageInfo来封装,它里面就有一个int型变量order,我们通过给每一个AdPageInfo赋值order,AdPlayBanner就会自动按照order的大小来排序,如:

我们封装了三个数据到ArrayList里面,按顺序是图片1->图片2->图片3

List<AdPageInfo> mDatas = new ArrayList<>();
AdPageInfo info1 = new AdPageInfo("图片1", "http://osjnd854m.bkt.clouddn.com/pic1_meitu_1.jpg", "链接1", 3);
AdPageInfo info2 = new AdPageInfo("图片2", "http://osjnd854m.bkt.clouddn.com/pic1_meitu_2.jpg", "链接2", 2);
AdPageInfo info3 = new AdPageInfo("图片3", "http://osjnd854m.bkt.clouddn.com/pic1_meitu_3.jpg", "链接3", 1);
mDatas.add(info1);
mDatas.add(info2);
mDatas.add(info3);

装载之后运行,可见轮播顺序是按照order的顺序来播放:


AdPlayBanner:功能丰富、一键式使用的图片轮播插件_ide

2.无限循环轮播

很多轮播插件没有实现无限循环轮播这个功能, 而在AdPlayBanner上得到了实现,如下图可见,当我们无限循环滑动时,插件仍能正常运行:


3.支持三种图片加载方式

setImageLoadType(ImageLoaderType type),只需要将传入数据设置为:FRESCOGLIDEPICASSO其中一种即可,同样,也是可以通过代码一键式使用,例如使用Glide方式加载(其他加载方式使用类似),使用方法如下:

mAdPlayBanner
        .setInfoList((ArrayList<AdPageInfo>) mDatas)
        .setImageLoadType(Glide)    // 设置Glide类型的图片加载方式
        .setUp();

4.支持多种ScaleType

FIT_XY,但是在AdPlayBanner中比ImageView少了一种MATRIX类型,在AdPlayBanner中具体支持的ScaleType有如下:FIT_XYFIT_STARTFIT_CENTERFIT_ENDCENTERCENTER_CROPCENTER_INSIDE其中,具体调用方法setImageViewScaleType(ScaleType scaleType),只需要将具体的ScaleType传入即可,同样,也是可以通过代码一键式使用,例如设置ScaleType为FIT_START(其他类似),使用方法如下:

mAdPlayBanner
        .setInfoList((ArrayList<AdPageInfo>) mDatas)
        .setImageViewScaleType(FIT_START)   // 设置FIT_START类型的ScaleType
        .setUp();

5.支持不同页码指示器

数字型点型空型页码指示器,用户可以通过调用setIndicatorType(IndicatorType type),传入NONE_INDICATORNUMBER_INDICATORPOINT_INDICATOR其中一种,即可显示对应的页码指示器,三种页码指示器对应效果如下:NONE_INDICATOR:空型页码指示器

AdPlayBanner:功能丰富、一键式使用的图片轮播插件_AdPlayBanner_02

NUMBER_INDICATOR:数字页码指示器

AdPlayBanner:功能丰富、一键式使用的图片轮播插件_背景颜色_03

POINT_INDICATOR:点型页码指示器

AdPlayBanner:功能丰富、一键式使用的图片轮播插件_控件_04

使用方法也是非常简单,如我需要使用数字型页码指示器,使用方法如下:

mAdPlayBanner
        .setInfoList((ArrayList<AdPageInfo>) mDatas)
        .setIndicatorType(NUMBER_INDICATOR)     //使用数字页码指示器
        .setUp();

setNumberViewColor(int normalColor, int selectedColor, int numberColor)来修改数字型页码指示器的样式,normalColor为数字没选中时的背景颜色,selectedColor为数字选中时的背景颜色,numberColor为数字的字体颜色,例如我通过调用这个方法,把三个颜色都改变掉(注意:传入int型颜色必须ARGB8888的颜色类型,或者通过资源文件定义颜色再获取才有效),使用方法如下:

mAdPlayBanner
        .setInfoList((ArrayList<AdPageInfo>) mDatas)
        .setIndicatorType(NUMBER_INDICATOR)     //使用数字页码指示器
        .setNumberViewColor(0xff00ffff, 0xffff3333, 0xff0000ff)
        .setUp();

得到如下效果:


AdPlayBanner:功能丰富、一键式使用的图片轮播插件_AdPlayBanner_05

6.添加灵活性标题

addTitleView(TitleView mTitleView),就可以插入标题了,并且该标题的灵活性很强,可以根据用户需要修改标题的背景、位置、字体大小、padding、magin等,先上一个提供的默认效果:

由于是使用了默认的效果,所以用法也是非常简单:

mAdPlayBanner
        .setInfoList((ArrayList<AdPageInfo>) mDatas)
        .setIndicatorType(POINT_INDICATOR)     //使用数字页码指示器
        .addTitleView(TitleView.getDefaultTitleView(getApplicationContext()))  // 使用默认标题
        .setUp();

addTitleView(TitleView mTitleView),传入一个TitleView即可以生成标题,而上面是调用了AdPlayBanner提供的一个默认标题,当然,我们也说了这个标题的灵活性很强,就是我们可以设置TitleView的属性,我们来看一下TitleView提供了哪些API:TitleView setTitleColor(int color)

  • :设置标题字体颜色,传入color必须ARGB8888的颜色类型,或者通过资源文件定义颜色再获取才有效。

setPosition(Gravity gravity)

  • :设置标题在AdPlayBanner中的位置,有

PARENT_TOP

  • ,

PARENT_BOTTOM

  • ,

PARENT_CENTER

  • 三个取值,分别位于父布局顶部,父布局底部,父布局中间。

setViewBackground(int color)

  • :设置标题的背景颜色,传入int型颜色必须ARGB8888的颜色类型,或者通过资源文件定义颜色再获取才有效。

TitleView setTitleSize(int size)

  • :设置标题的字体大小,单位是sp。

setTitleMargin(int left, int top, int right, int bottom)

  • :设置标题的四个方向margin值,单位是dp。

setTitlePadding(int left, int top, int right, int bottom)

  • :设置标题的四个方向padding值,单位是dp。

同样,TitleView也是支持Builder模式的写法,例如我自定义一个TitleVIew并加到AdPlayBanner中,使用方法如下:

mAdPlayBanner
        .setInfoList((ArrayList<AdPageInfo>) mDatas)
        .setIndicatorType(POINT_INDICATOR)     // 使用数字页码指示器
        .addTitleView(new TitleView(getApplicationContext())    // 创建新的TitleView
                            .setPosition(PARENT_TOP)
                            .setTitleColor(0xffffffff)          // 设置字体颜色
                            .setViewBackground(0x9944ff18)      // 设置标题背景颜色
                            .setTitleSize(18)                   // 设置字体大小
                            .setTitleMargin(0,0,2,0)           // 设置margin值
                            .setTitlePadding(2,2,2,2))          // 设置padding值
        .setUp();

效果如下:


7.支持多样式切换动画

setPageTransfromer(ViewPager.PageTransformer transformer)方法,传入一个PageTransformer,即可改变它的切换样式,AdPlayBanner中提供了三种现成的切换方式:FadeInFadeOutTransformer

  • :淡入淡出效果


AdPlayBanner:功能丰富、一键式使用的图片轮播插件_ide_06

RotateDownTransformer

  • :旋转效果


AdPlayBanner:功能丰富、一键式使用的图片轮播插件_背景颜色_07

ZoomOutPageTransformer

  • : 空间切换效果


使用起来也是非常简单,例如使用ZoomOutPageTransformer切换效果:

mAdPlayBanner
        .setInfoList((ArrayList<AdPageInfo>) mDatas)
        .setIndicatorType(POINT_INDICATOR)     // 使用数字页码指示器
        .setBannerBackground(0xff000000)       // 设置背景颜色
        .setPageTransfromer(new ZoomOutPageTransformer())   // 设置切换效果
        .setUp();

transformPage(View view, float position)方法即可实现自定义的切换效果。

8.设置是否自动轮播

setAutoPlay(boolean autoPlay),传入boolean值控制是否自动播放的开关,传入true为自动,传入false为手动。

9.设置自动滑动间隔时间

setInterval(int interval),传入int型的时间(单位ms),即可改变AdPlayBanner自动轮播时的切换时间。

10.设置点击事件监听器

setOnPageClickListener(OnPageClickListener l),传入OnPageClickListener,即可完成AdPlayBanner的点击监听,使用方法非常简单:

mAdPlayBanner
    .setInfoList((ArrayList<AdPageInfo>) mDatas)
    .setIndicatorType(POINT_INDICATOR)     // 使用数字页码指示器
    .setOnPageClickListener(new AdPlayBanner.OnPageClickListener() {
        @Override
        public void onPageClick(AdPageInfo info, int postion) {
            // 点击操作
        }
    })
    .setUp();

三、API

AdPlayBanner:实现轮播效果的控件

AdPlayBanner

解释

备注

addTitleView(TitleView mTitleView)

添加一个TitleView

可以通过TitleView.getDefaultTitleView(Context context)来使用默认的TitleView或者通过new Title()的方式传入

setBannerBackground(int color)

设置AdPlayBanner的背景颜色

传入color必须ARGB8888的颜色类型,或者通过资源文件定义颜色再获取才有效

setIndicatorType(IndicatorType type)

设置页码指示器类型

NONE_INDICATORNUMBER_INDICATORPOINT_INDICATOR其中一种

setInterval(int interval)

设置自动轮播时的切换时间

单位ms

setImageLoadType(ImageLoaderType type)

设置图片加载方式

FRESCOGLIDEPICASSO其中一种

setPageTransfromer(ViewPager.PageTransformer transformer)

设置切换动画,如果不设置动画,设置为null

FadeInFadeOutTransformerRotateDownTransformerZoomOutPageTransformer三种,也可以传入自定义的TransFormer

setNumberViewColor(int normalColor, int selectedColor, int numberColor)

设置数字页码的颜色

normalColor 数字正常背景颜色,selectedColor 数字选中背景颜色,numberColor 数字字体颜色

setOnPageClickListener(OnPageClickListener l)

设置事件点击监听器

传入一个OnPageClickListener

setImageViewScaleType(ScaleType scaleType)

设置图片的ScaleType

FIT_XYFIT_STARTFIT_CENTERFIT_ENDCENTERCENTER_CROPCENTER_INSIDE其中一种

setAutoPlay(boolean autoPlay)

设置是否自动播放

默认为true 自动播放,传入false为手动

setInfoList(ArrayList pageInfos)

设置Banner的数据源

传入必须为AdPageInfo类型的ArrayList

setUp()

装载AdPlayBanner

必须在以上所有方法调用完之后才能调用

TitleView : 标题控件

TitleView

解释

备注

getDefaultTitleView(Context context)

获取一个默认的TitleView

传入一个Context

setTitleSize(int size)

设置字体大小

单位sp

setTitleColor(int color)

设置字体颜色

传入color必须ARGB8888的颜色类型,或者通过资源文件定义颜色再获取才有效

setViewBackground(int color)

设置标题背景

传入color必须ARGB8888的颜色类型,或者通过资源文件定义颜色再获取才有效

setPosition(Gravity gravity)

设置标题在Banner的位置

PARENT_TOP,PARENT_BOTTOM,PARENT_CENTER其中一个值

setTitleMargin(int left, int top, int right, int bottom)

设置标题的margin值

单位dp

setTitlePadding(int left, int top, int right, int bottom)

设置标题的padding值

单位dp

AdPageInfo:AdPlayView指定的数据源

AdPageInfo

解释

备注

AdPageInfo(String title, String picUrl, String clickUlr, int order)

构造方法


void setTitle(String title)

设置标题


String getTitle()

获取标题


void setPicUrl(String picUrl)

设置图片源地址


String getPicUrl()

获取图片链接


void setClickUlr(String clickUlr)

设置点击事件地址


String getClickUlr()

获取点击事件链接


void setOrder(int order)

设置排序的优先级

设置了order,AdPlayBanner会根据order的大小由小到大排序

int getOrder()

获取排序优先级


四、版本特性

v0.1

  1. 基本框架搭建完成;

V0.2

  1. 支持定义数据顺序;
  2. 无限循环轮播;
  3. 支持Fresco、Glide、Picasso三种图片加载方式;
  4. 支持多种ScaleType;
  5. 支持点型、数字型、空型页码指示器;支持修改数字型页码器的样式;
  6. 支持灵活性标题;支持修改标题的位置、字体大小、颜色、边距值等属性;
  7. 支持多样式切换动画;
  8. 支持设置自动轮播开关;
  9. 自定义自动滑动间隔时间;
  10. 提供点击事件监听器;
  11. 支持修改AdPlayBanner的背景颜色;

V0.3

  1. 修复了静态变量造成的内存泄漏问题;
  2. 提供手动结束Banner播放的接口;

五、Demo

如果大家在使用在仍然有问题,可以通过下载Demo来学习,当然,大家更可以通过查看源代码来学习如何自定义一个轮播控件。

项目结构截图:


AdPlayBanner:功能丰富、一键式使用的图片轮播插件_ide_08

六、后记

AdPlayBanner作为作者的第一个开源控件,作者也是非常用心认真地完成,这个过程也学习到很多东西,可能其中会遇到很多错误,所以希望大家可以多多包涵,然后把错误提到Issues里面,作者会在看到的第一时间进行修正。在后面的时间里,作者也会将更多的特性加到这个控件里面,所以希望大家可以加个star,以作为对作者的小小鼓励。 当然,如果你想第一时间联系到作者



标签:插件,颜色,轮播,int,AdPlayBanner,TitleView,设置,功能丰富,页码
From: https://blog.51cto.com/u_7583030/6486252

相关文章

  • eclipse安装插件失败
    使用eclipse安装SpringToolSuite安装失败Cannotcompletetheinstallbecauseoneormorerequireditemscouldnotbefound.Softwarebeinginstalled:SpringIDEOSGiExtension(optional)3.8.3.201612191259-RELEASE(org.springframework.ide.eclipse.osgi.feat......
  • vray5.2 for SketchUp2017-2022插件安装教程(vray5.2安装包下载)
    vray5.2 forSketchUp2017-2022 Win版/64位下载地址:https://pan.baidu.com/s/1uqcVJrHl6Ae3yjsYZDUXmg密码:hdth材质库(大小17.00G,选择性安装)下载地址:https://pan.baidu.com/s/1q5xrChwJ4ocIMhfFvboF_g密码:fjn4[简介]:vrayforSketchUp是专门为草图大师推出的插件,是一款主流、实用......
  • 嘿,不升级CodeGeeX插件,哪来时间摸鱼?
    今天,CodeGeeX1.1.2版正式在JetBrainsIDEs中上线。和VSCode中的CodeGeeX2.0升级一样,新版本在JetBrainsIDEs中带来“AskCodeGeeX”的功能升级。使开发者可以在IDE中,通过问答对话的方式解决技术问题。下面的视频以DataGrip为例,展示新版将技术问答与IDE编程环境深度融合。编辑区......
  • DR5插件加强版 for Mac(ps磨皮滤镜) v5.0中文版
    dr5中文版是一款功能强大的ps磨皮插件集合版,整合了dr5磨皮美妆功能和工笔画功能,实现一个面板上集成众多修图功能,帮助用户一键磨皮降噪美白、局部平滑、表面平滑、改变色调、斑点祛除、液化校正、美白牙齿、眼睛增强等等,专注人像修饰,是您日常修图必备插件。DR5插件加强版下载Del......
  • STM32CubeIDE卸载插件/卸载汉化
    汉化时下载了所有的内容,打开就提示错误,大概是什么不能类转化查了下,说是不能全部都装,只装两个即可,然后就要卸载其他的话不多说直接上图哈哈哈,没有报错界面了,我找找,重启软件出来了然后 选中卸载项就能卸载了 可以用文件夹中选文件的快捷键哦 ......
  • centos7安装docker-compose插件
    引介docker-compose是docker的一款插件,常用来定义和运行多容器的docker应用。本篇文章就来介绍一下,如何在centos7的linux系统中安装docker-compose插件。安装方式docker-compose安装方式的主要可以分为两种,一是使用docker仓库进行安装,而是手动方式安装。使用docker仓库安装使......
  • springboot~代码风格统计spring-javaformat-maven-plugin插件
    SpringJavaformat是Spring团队开发的一款基于GoogleJavaFormat的代码格式化工具,可以帮助Java开发者自动化进行代码格式化,提高代码质量,降低代码维护成本。SpringJavaformat可以自定义配置文件,支持大量的代码风格配置选项,满足不同项目和团队的需求。还可以与Gradle、Maven、Int......
  • Postcat X APISIX 合作插件 :一键同步,轻松配置到 APISIX
    近日,云流科技(广州)有限公司(简称“Eolink”)旗下的开源API管理工具Postcat和深圳支流科技有限公司(简称“API7支流科技”)在各自擅长的领域携手合作,推出了Postcat&ApacheAPISIX插件,用户只需要安装此插件,即可轻松地将Postcat产品中管理的API相关配置的数据同步到开源网关......
  • Edge浏览器的JSON格式化插件(FeHelper)不生效
    问题有时候懒得打开ApiPost测试接口,就直接使用Edge浏览器进行接口测试,但是最近格式化出了问题,FeHelper插件的JSON格式化不生效,不对,也不能说是完全不生效吧,测试非本地的接口倒是可以本地接口(奇怪的格式化,好丑......
  • eclipse 3.6.1 安装maven插件失败的解决办法
      一、eclipse3.6.1下载地址[eclipse-jee-helios-SR1-win32.zip]http://www.eclipse.org/downloads/packages/eclipse-ide-java-ee-developers/heliossr1二、插件地址1、gef插件地址:http://download.eclipse.org/tools/gef/updates/interim/2、subclipse插件地址:http......