Android自动播放Banner图片轮播效果

先看一下效果图

支持本地图片以及网络图片or本地网络混合。

使用方式:

android:id="@+id/banner"

android:layout_width="match_parent"

android:layout_height="230dip">

核心代码:

int length = mList.size();

View view = LayoutInflater.from(mContext).inflate(R.layout.banner_view,this,true);

LinearLayout ll = (LinearLayout) view.findViewById(R.id.ll_points);

vp= (ViewPager) view.findViewById(R.id.vp);

ll.removeAllViews();

LinearLayout.LayoutParams ll_parmas = new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT);

ll_parmas.leftMargin=5;

ll_parmas.rightMargin=5;

for(int i=0;i

ImageView img = new ImageView(mContext);

img.setLayoutParams(ll_parmas);

if(i==0){

img.setImageResource(R.mipmap.dot_focus);

}else{

img.setImageResource(R.mipmap.dot_blur);

}

ll.addView(img);

mImgs.add(img);

final ImageView imgforview = new ImageView(mContext);

imgforview.setOnClickListener(this);

imgforview.setScaleType(ImageView.ScaleType.FIT_XY);

if(mList.get(i).getType()==0){//本地图片

imgforview.setImageResource(mList.get(i).getDrawableforint());

}else{//网络

Glide.with(mContext).load(mList.get(i).getDrawableforurl()).diskCacheStrategy(DiskCacheStrategy.ALL).into(imgforview);

// Glide.with(mContext).load(mList.get(i).getDrawableforurl()).listener(new RequestListener() {

// @Override

// public boolean onException(Exception e, String model, Target target, boolean isFirstResource) {

// Log.d("yu","Faile:"+e.toString());

// return false;

// }

//

// @Override

// public boolean onResourceReady(GlideDrawable resource, String model, Target target, boolean isFromMemoryCache, boolean isFirstResource) {

// imgforview.setImageDrawable(resource);

// return false;

// }

// }).into(imgforview);

// Log.d("yu","url: "+mList.get(i).getDrawableforurl());

}

mViews.add(imgforview);

}

vp.setAdapter(new MyAdapter());

vp.addOnPageChangeListener(onPageChange);

自动轮播利用的是handler的postdelay方法。

private Runnable task = new Runnable() {

@Override

public void run() {

if(isAuto){

currentItem = currentItem%(mViews.size());

// Log.d("yu","runalbe "+currentItem);

if(currentItem==0){

vp.setCurrentItem(currentItem,false);

}else{

vp.setCurrentItem(currentItem);

}

currentItem++;

mHandle.postDelayed(task,delaytime);

}else{

mHandle.postDelayed(task,delaytime);

}

}

};

利用isAuto判断是否正在自动轮播 如果为false 不自动切换item。isAuto赋值操作位于OnPageChangeListener的onPageScrollStateChanged方法中:

public void onPageScrollStateChanged(int state) {

switch (state){

case ViewPager.SCROLL_STATE_IDLE://用户什么都没有操作

isAuto=true;

currentItem = vp.getCurrentItem();

// Log.d("yu","IDLE"+currentItem);

// if(vp.getCurrentItem()==mViews.size()){

// vp.setCurrentItem(0,false);

// }

break;

case ViewPager.SCROLL_STATE_DRAGGING://正在滑动

isAuto =false;

break;

case ViewPager.SCROLL_STATE_SETTLING://滑动结束

isAuto=true;

break;

}

}

当状态为SCROLL_STATE_DRAGGING时 说明用户正在操作 ,看下源码中的解释:

/**

* Indicates that the pager is in an idle, settled state. The current page

* is fully in view and no animation is in progress.

*/

public static final int SCROLL_STATE_IDLE = 0;

/**

* Indicates that the pager is currently being dragged by the user.

*/

public static final int SCROLL_STATE_DRAGGING = 1;

/**

* Indicates that the pager is in the process of settling to a final position.

*/

public static final int SCROLL_STATE_SETTLING = 2;

大致意思呢就是 0代码没有任何操作。1页面正在被用户拖动。2代表成功切换至下一页面。

源码地址:https://github.com/yudehai0204/autoBanner

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持phpstudy。相关阅读:

Win10开发版本10100曝光 团队正准备重大公开预览版

PHP迭代器实现斐波纳契数列的函数

asp.net微信开发(高级群发文本)

MSSQL附加数据库拒绝访问提示5120错误的处理方法

Win10预览版怎么关闭系统消息提醒?

Swift教程之方法详解

C语言合并排序及实例代码

Win10怎么删除资源管理器中的OneDrive图标?

升级完Windows 7/8/8.1用户之后何时需要输入系统密钥?

ASP.NET―001:GridView绑定List、页面返回值具体实现

针对JavaScript中this指向的简单理解

Java中的双重检查(Double-Check)详解

Javascript基础教程之关键字和保留字汇总

C语言求幂计算的高效解法

android首页图片轮播效果,Android_Android自动播放Banner图片轮播效果,先看一下效果图支持本地图 - phpStudy...相关推荐

  1. android 自动播放 幻灯片,Android自动播放Banner图片轮播效果

    本文实例为大家分享了Android自动播放Banner图片轮播的具体代码,供大家参考,具体内容如下 先看一下效果图 支持本地图片以及网络图片or本地网络混合. 使用方式: android:id=&qu ...

  2. js原生选项卡(自动播放无缝滚动轮播图)二

    今天分享一下自动播放轮播图,自动播放轮播图是在昨天分享的轮播图的基础上添加了定时器,用定时器控制图片的自动切换,函数中首先封装一个方向的自动播放工能的小函数,这个函数中添加定时器,定时器中可以放向右走 ...

  3. 谷歌play商店_如何在Android的Google Play商店中禁用自动播放视频

    谷歌play商店 Justin Duino 贾斯汀·杜伊诺(Justin Duino) Does anyone like autoplaying videos? I know I don't. Goo ...

  4. Vuetify Carouse轮播图 图片切换导致页面总是自动跳转到轮播图位置

    文章目录 begin !!! Solution1 Solution2 end begin vuetify carouse轮播图 的图片自动切换的时候, 会自动聚焦跳转到轮播图自身的位置. 这导致了一个 ...

  5. html5时间线图片自动轮播,js实现自动播放匀速轮播图

    本文实例为大家分享了js实现自动播放匀速轮播图的具体代码,供大家参考,具体内容如下 函数封装:( 匀速运动函数) function animate(obj,target,step,speed){ cl ...

  6. 用jQuery实现轮播图效果(自动播放,能手动切换)

    大家好,今天我和大家分享一下轮播图的实现,下面是我做的轮播图效果 首先我们看到,它是由背景图片.方向图标和指示器组成.**我们发现背景图片.方向图标和指示器是层叠在一起的,所以布局时我们要用绝对定位. ...

  7. html菜鸟教程轮播图自动播放,如何实现轮播图?

    1.背景介绍 轮播图,是由网页banner进化而来,通常放在屏幕最显眼的位置,以大图显示.随着互联网的发展,网页中需要推广的信息越来越多,宣传信息都欲占据黄金位置,最后相互妥协,轮播图应运而生.总而言 ...

  8. ViewFlipper实现带索引效果的自动播放也可手动滑动的广告栏

    前几天看到淘宝和易迅的客户端的广告栏做的不错,今天就尝试了一下,模仿着写了带指引的ViewFlipper.本文主要介绍指引栏的实现,论坛上关于ViewFlipper的使用和介绍很多,就不过多介绍. 效 ...

  9. 自定义ViewFlipper实现带索引效果的自动播放广告栏

    前几天看到淘宝和易迅的客户端的广告栏做的不错,今天就尝试了一下,模仿着写了带指引的ViewFlipper.本文主要介绍指引栏的实现,论坛上关于ViewFlipper的使用和介绍很多,就不过多介绍. 效 ...

最新文章

  1. 基于OpenStreetMap计算驾车距离(Java)
  2. mysql.info文件是什么_info 数据库
  3. O(n)算法得到数组中第k大的数字
  4. 使用Google Guava的订购API
  5. pytorch读取单通道图片
  6. 查询服务器硬件配置的命令
  7. easyui 改变单元格背景颜色
  8. KEIL软件安装教程
  9. 《致加西亚的信》读后感
  10. 测试计划及方案怎么写?
  11. 【QTdesigner】课时36.使用QTextEdit控件输入多行文本【pyqt5+QTdesigner模式】
  12. spring cloud在配置zuul访问后报错,微服务响应超时问题
  13. OpenHarmony通过元气派点亮LED灯
  14. Visual Studio Community 2017/2019下载链接
  15. 「敏捷架构」敏捷架构:规模化敏捷开发的策略
  16. wordpress插入bilibili视频
  17. transmission-daemon安装
  18. 《计算机图形学原理及实践》学习笔记之第十章
  19. Sqoop安装部署和数据的导入导出案例详解
  20. 再见,区块链 Rio会议和以太坊Sao Paolo活动。 你好,闪光时刻

热门文章

  1. 在Ubuntu 12.04 64bit上配置,安装和运行go程序
  2. 【Python之路】第二篇--初识Python
  3. MySql5.7环境搭建
  4. java 下载文件功能代码例子
  5. as3回调方法模拟事件监听
  6. 微软极品Sysinternals Suite工具包使用指南
  7. .NET中获取电脑名、IP及用户名方法
  8. Linux下nginx支持.htaccess文件实现伪静态的方法!
  9. linux的根文件系统中的proc文件夹详解
  10. ASP.NET中在线用户统计