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

本文详细介绍了如何在Android中实现自动播放的Banner图片轮播效果,包括支持本地和网络图片的加载,使用ViewPager和Handler进行轮播,并在用户滑动时暂停和恢复轮播。通过设置OnPageChangeListener监听状态变化来控制自动切换。同时提供了源码链接供读者参考。
摘要由CSDN通过智能技术生成

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语言求幂计算的高效解法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值