android首页图片轮播效果,Android_Android自动播放Banner图片轮播效果,先看一下效果图支持本地图 - phpStudy...
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...相关推荐
- android 自动播放 幻灯片,Android自动播放Banner图片轮播效果
本文实例为大家分享了Android自动播放Banner图片轮播的具体代码,供大家参考,具体内容如下 先看一下效果图 支持本地图片以及网络图片or本地网络混合. 使用方式: android:id=&qu ...
- js原生选项卡(自动播放无缝滚动轮播图)二
今天分享一下自动播放轮播图,自动播放轮播图是在昨天分享的轮播图的基础上添加了定时器,用定时器控制图片的自动切换,函数中首先封装一个方向的自动播放工能的小函数,这个函数中添加定时器,定时器中可以放向右走 ...
- 谷歌play商店_如何在Android的Google Play商店中禁用自动播放视频
谷歌play商店 Justin Duino 贾斯汀·杜伊诺(Justin Duino) Does anyone like autoplaying videos? I know I don't. Goo ...
- Vuetify Carouse轮播图 图片切换导致页面总是自动跳转到轮播图位置
文章目录 begin !!! Solution1 Solution2 end begin vuetify carouse轮播图 的图片自动切换的时候, 会自动聚焦跳转到轮播图自身的位置. 这导致了一个 ...
- html5时间线图片自动轮播,js实现自动播放匀速轮播图
本文实例为大家分享了js实现自动播放匀速轮播图的具体代码,供大家参考,具体内容如下 函数封装:( 匀速运动函数) function animate(obj,target,step,speed){ cl ...
- 用jQuery实现轮播图效果(自动播放,能手动切换)
大家好,今天我和大家分享一下轮播图的实现,下面是我做的轮播图效果 首先我们看到,它是由背景图片.方向图标和指示器组成.**我们发现背景图片.方向图标和指示器是层叠在一起的,所以布局时我们要用绝对定位. ...
- html菜鸟教程轮播图自动播放,如何实现轮播图?
1.背景介绍 轮播图,是由网页banner进化而来,通常放在屏幕最显眼的位置,以大图显示.随着互联网的发展,网页中需要推广的信息越来越多,宣传信息都欲占据黄金位置,最后相互妥协,轮播图应运而生.总而言 ...
- ViewFlipper实现带索引效果的自动播放也可手动滑动的广告栏
前几天看到淘宝和易迅的客户端的广告栏做的不错,今天就尝试了一下,模仿着写了带指引的ViewFlipper.本文主要介绍指引栏的实现,论坛上关于ViewFlipper的使用和介绍很多,就不过多介绍. 效 ...
- 自定义ViewFlipper实现带索引效果的自动播放广告栏
前几天看到淘宝和易迅的客户端的广告栏做的不错,今天就尝试了一下,模仿着写了带指引的ViewFlipper.本文主要介绍指引栏的实现,论坛上关于ViewFlipper的使用和介绍很多,就不过多介绍. 效 ...
最新文章
- 基于OpenStreetMap计算驾车距离(Java)
- mysql.info文件是什么_info 数据库
- O(n)算法得到数组中第k大的数字
- 使用Google Guava的订购API
- pytorch读取单通道图片
- 查询服务器硬件配置的命令
- easyui 改变单元格背景颜色
- KEIL软件安装教程
- 《致加西亚的信》读后感
- 测试计划及方案怎么写?
- 【QTdesigner】课时36.使用QTextEdit控件输入多行文本【pyqt5+QTdesigner模式】
- spring cloud在配置zuul访问后报错,微服务响应超时问题
- OpenHarmony通过元气派点亮LED灯
- Visual Studio Community 2017/2019下载链接
- 「敏捷架构」敏捷架构:规模化敏捷开发的策略
- wordpress插入bilibili视频
- transmission-daemon安装
- 《计算机图形学原理及实践》学习笔记之第十章
- Sqoop安装部署和数据的导入导出案例详解
- 再见,区块链 Rio会议和以太坊Sao Paolo活动。 你好,闪光时刻