首页图片的轮播

/**

* 广告图片自动轮播控件

*

*/

public class ImageCycleView extends LinearLayout {

/**

* 上下文

*/

private Context mContext;

/**

* 图片轮播视图

*/

private ViewPager mAdvPager = null;

/**

* 滚动图片视图适配

*/

private ImageCycleAdapter mAdvAdapter;

/**

* 图片轮播指示器控件

*/

private ViewGroup mGroup;

/**

* 图片轮播指示个图

*/

private ImageView mImageView = null;

/**

* 滚动图片指示视图列表

*/

private ImageView[] mImageViews = null;

/**

* 图片滚动当前图片下标

*/

private boolean isStop;

/**

* 游标是圆形还是长条,要是设置为0是长条,要是1就是圆形 默认是圆形

*/

public int stype=1;

/**

* @param context

*/

public ImageCycleView(Context context) {

super(context);

}

/**

* @param context

* @param attrs

*/

@SuppressLint("Recycle")

public ImageCycleView(Context context, AttributeSet attrs) {

super(context, attrs);

mContext = context;

LayoutInflater.from(context).inflate(R.layout.ad_cycle_view, this);

mAdvPager = (ViewPager) findViewById(R.id.adv_pager);

mAdvPager.setOnPageChangeListener(new GuidePageChangeListener());

// 滚动图片右下指示器视

mGroup = (ViewGroup) findViewById(R.id.viewGroup);

}

/**

* 触摸停止计时器,抬起启动计时器

*/

@Override

public boolean dispatchTouchEvent(MotionEvent event) {

if(event.getAction()==MotionEvent.ACTION_UP){

// 开始图片滚动

startImageTimerTask();

}else{

// 停止图片滚动

stopImageTimerTask();

}

return super.dispatchTouchEvent(event);

}

/**

* 装填图片数据

*

* @param imageUrlList

* @param imageCycleViewListener

*/

public void setImageResources(ArrayList imageUrlList ,ImageCycleViewListener imageCycleViewListener,int stype){

this.stype=stype;

// 清除

mGroup.removeAllViews();

// 图片广告数量

final int imageCount = imageUrlList.size();

mImageViews = new ImageView[imageCount];

for (int i = 0; i < imageCount; i++) {

mImageView = new ImageView(mContext);

LayoutParams params=new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);

params.leftMargin=30;

mImageView.setScaleType(ScaleType.CENTER_CROP);

mImageView.setLayoutParams(params);

mImageViews[i] = mImageView;

if (i == 0) {

if(this.stype==1)

// mImageViews[i].setBackgroundResource(R.drawable.banner_dian_focus);

mImageViews[i].setBackgroundResource(R.drawable.cicle_banner_dian_focus);//换点

else

mImageViews[i].setBackgroundResource(R.drawable.cicle_banner_dian_focus);

} else {

if(this.stype==1)

// mImageViews[i].setBackgroundResource(R.drawable.banner_dian_blur);

mImageViews[i].setBackgroundResource(R.drawable.cicle_banner_dian_blur);

else

mImageViews[i].setBackgroundResource(R.drawable.cicle_banner_dian_blur);

}

mGroup.addView(mImageViews[i]);

}

mAdvAdapter = new ImageCycleAdapter(mContext, imageUrlList ,imageCycleViewListener);

mAdvPager.setAdapter(mAdvAdapter);

mAdvPager.setCurrentItem(Integer.MAX_VALUE/2);

startImageTimerTask();

}

public void setImageResources2(ArrayList imageUrlList ,ImageCycleViewListener imageCycleViewListener,int stype){

this.stype=stype;

// 清除

mGroup.removeAllViews();

// 图片广告数量

final int imageCount = imageUrlList.size();

mImageViews = new ImageView[imageCount];

for (int i = 0; i < imageCount; i++) {

mImageView = new ImageView(mContext);

LayoutParams params=new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);

params.leftMargin=30;

mImageView.setScaleType(ScaleType.CENTER_CROP);

mImageView.setLayoutParams(params);

mImageViews[i] = mImageView;

if (i == 0) {

if(this.stype==1)

// mImageViews[i].setBackgroundResource(R.drawable.banner_dian_focus);

mImageViews[i].setBackgroundResource(R.drawable.cicle_banner_dian_focus);//换点

else

mImageViews[i].setBackgroundResource(R.drawable.cicle_banner_dian_focus);

} else {

if(this.stype==1)

// mImageViews[i].setBackgroundResource(R.drawable.banner_dian_blur);

mImageViews[i].setBackgroundResource(R.drawable.cicle_banner_dian_blur);

else

mImageViews[i].setBackgroundResource(R.drawable.cicle_banner_dian_blur);

}

mGroup.addView(mImageViews[i]);

}

mAdvAdapter = new ImageCycleAdapter(mContext, imageUrlList ,imageCycleViewListener);

mAdvPager.setAdapter(mAdvAdapter);

mAdvPager.setCurrentItem(Integer.MAX_VALUE/2);

startImageTimerTask();

}

/**

* 图片轮播(手动控制自动轮播与否,便于资源控件)

*/

public void startImageCycle() {

startImageTimerTask();

}

/**

* 暂停轮播—用于节省资源

*/

public void pushImageCycle() {

stopImageTimerTask();

}

/**

* 图片滚动任务

*/

private void startImageTimerTask() {

stopImageTimerTask();

// 图片滚动

mHandler.postDelayed(mImageTimerTask, 5000);

}

/**

* 停止图片滚动任务

*/

private void stopImageTimerTask() {

isStop=true;

mHandler.removeCallbacks(mImageTimerTask);

}

private Handler mHandler = new Handler();

/**

* 图片自动轮播Task

*/

private Runnable mImageTimerTask = new Runnable() {

@Override

public void run() {

if (mImageViews != null) {

mAdvPager.setCurrentItem(mAdvPager.getCurrentItem()+1);

if(!isStop){ //if isStop=true //当你退出后 要把这个给停下来 不然 这个一直存在 就一直在后台循环

mHandler.postDelayed(mImageTimerTask, 5000);

}

}

}

};

/**

* 轮播图片监听

*

* @author minking

*/

private final class GuidePageChangeListener implements OnPageChangeListener {

@Override

public void onPageScrollStateChanged(int state) {

if (state == ViewPager.SCROLL_STATE_IDLE)

startImageTimerTask();

}

@Override

public void onPageScrolled(int arg0, float arg1, int arg2) {

}

@Override

public void onPageSelected(int index) {

index=index%mImageViews.length;

// 设置当前显示的图片

// 设置图片滚动指示器背

if(stype!=1)

mImageViews[index].setBackgroundResource(R.drawable.cicle_banner_dian_focus);

else

mImageViews[index].setBackgroundResource(R.drawable.cicle_banner_dian_focus);

for (int i = 0; i < mImageViews.length; i++) {

if (index != i) {

if(stype!=1)

mImageViews[i].setBackgroundResource(R.drawable.cicle_banner_dian_blur);

else

mImageViews[i].setBackgroundResource(R.drawable.cicle_banner_dian_blur);

}

}

}

}

private class ImageCycleAdapter extends PagerAdapter {

/**

* 图片视图缓存列表

*/

private ArrayList mImageViewCacheList;

/**

* 图片资源列表

*/

//private ArrayList mAdList = new ArrayList();

private ArrayList mAdList = new ArrayList();

/**

* 广告图片点击监听

*/

private ImageCycleViewListener mImageCycleViewListener;

private Context mContext;

// public ImageCycleAdapter(Context context, ArrayList adList , ImageCycleViewListener imageCycleViewListener) {

// this.mContext = context;

// this.mAdList = adList;

// mImageCycleViewListener = imageCycleViewListener;

// mImageViewCacheList = new ArrayList();

// }

public ImageCycleAdapter(Context context, ArrayList adList , ImageCycleViewListener imageCycleViewListener) {

this.mContext = context;

this.mAdList = adList;

mImageCycleViewListener = imageCycleViewListener;

mImageViewCacheList = new ArrayList();

}

@Override

public int getCount() {

return Integer.MAX_VALUE;

}

@Override

public boolean isViewFromObject(View view, Object obj) {

return view == obj;

}

@Override

public Object instantiateItem(ViewGroup container, final int position) {

int imageUrl = mAdList.get(position%mAdList.size());

Log.e("imageUrl:",position%mAdList.size()+"--"+imageUrl+"");

SmartImageView imageView = null;

if (mImageViewCacheList.isEmpty()) {

imageView = new SmartImageView(mContext);

imageView.setLayoutParams(new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));

//test

imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);

}

else {

imageView = mImageViewCacheList.remove(0);

}

imageView.setTag(imageUrl);

container.addView(imageView);

//imageView.setImageUrl(imageUrl);

imageView.setBackgroundResource(imageUrl);

// 设置图片点击监听

imageView.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

mImageCycleViewListener.onImageClick(position%mAdList.size(), v);

}

});

return imageView;

}

@Override

public void destroyItem(ViewGroup container, int position, Object object) {

SmartImageView view = (SmartImageView) object;

mAdvPager.removeView(view);

mImageViewCacheList.add(view);

}

}

/**

* 轮播控件的监听事件

*

* @author minking

*/

public static interface ImageCycleViewListener {

/**

* 单击图片事件

*

* @param position

* @param imageView

*/

public void onImageClick(int position, View imageView);

}

}

我们再来看个基于安卓ViewPager的图片轮播控件

package me.lanfog.myandroid.widget;

import java.util.ArrayList;

import java.util.List;

import android.content.Context;

import android.os.Handler;

import android.os.Message;

import android.support.v4.view.PagerAdapter;

import android.support.v4.view.ViewPager;

import android.util.AttributeSet;

import android.util.Log;

import android.view.View;

import android.view.ViewGroup;

import android.widget.ImageView;

public class PageFlipper extends ViewPager {

private String TAG = PageFlipper.class.getSimpleName();

private List views;

private PagerAdapter adapter = new PagerAdapter() {

@Override

public Object instantiateItem(ViewGroup container, int position) {

View v = views.get(position);

container.addView(v);

return v;

}

@Override

public boolean isViewFromObject(View arg0, Object arg1) {

return arg0 == arg1;

}

@Override

public int getItemPosition(Object object) {

return views.indexOf(object);

}

@Override

public void destroyItem(ViewGroup container, int position, Object object) {

container.removeView((View)object);

}

@Override

public int getCount() {

return views == null ? 0 : views.size();

}

};

private OnPageChangeListener listener = new OnPageChangeListener() {

/**

* 将控件位置转化为数据集中的位置

*/

public int convert(int position){

return position == 0 ? views.size()-1 : ( position > views.size() ? 0 : position-1 );

}

@Override

public void onPageSelected(int position) {

if(listener2 != null){

listener2.onPageSelected(convert(position));

}

}

@Override

public void onPageScrolled(int position, float percent, int offset) {

if(listener2 != null){

listener2.onPageScrolled(convert(position), percent, offset);

}

if(percent == 0){

if(position == 0) // 切换到倒数第二页

setCurrentItem(( views.size() - 2 ) % views.size(), false);

else if(position == views.size() - 1) // 切换到正数第二页

setCurrentItem(1, false);

}

}

@Override

public void onPageScrollStateChanged(int state) {

if(listener2 != null){

listener2.onPageScrollStateChanged(state);

}

switch (state) {

case SCROLL_STATE_IDLE: // 闲置

if(!handler.hasMessages(START_FLIPPING))

handler.sendEmptyMessageDelayed(START_FLIPPING, 3000); // 延时滚动

break;

case SCROLL_STATE_DRAGGING: // 拖动中

handler.sendEmptyMessage(STOP_FLIPPING); // 取消滚动

break;

case SCROLL_STATE_SETTLING: // 拖动结束

break;

}

}

}, listener2;

private final int START_FLIPPING = 0;

private final int STOP_FLIPPING = 1;

private Handler handler = new Handler(){

public void handleMessage(Message msg) {

switch (msg.what) {

case START_FLIPPING:

if(views.size() > 3) // 因为前后页是辅助页,所以此处3也就是只有1页

setCurrentItem((getCurrentItem() + 1) % views.size());

handler.sendEmptyMessageDelayed(START_FLIPPING, 3000); // 延时滚动

break;

case STOP_FLIPPING:

handler.removeMessages(START_FLIPPING);

break;

}

}

};

public PageFlipper(Context context, AttributeSet attrs) {

super(context, attrs);

init();

}

public PageFlipper(Context context) {

super(context);

init();

}

private void init(){

setOffscreenPageLimit(1); // 最大页面缓存数量

setAdapter(adapter); // 适配器

super.setOnPageChangeListener(listener); // 监听器

handler.sendEmptyMessageDelayed(START_FLIPPING, 3000); // 延时滚动

}

public void setViews(int[] ids){

this.views = new ArrayList();

for(int i=0;i

ImageView iv = new ImageView(getContext());

iv.setImageResource(ids[i == 0 ? ids.length-1 : ( i > ids.length ? 0 : i-1 )]);

iv.setScaleType(ImageView.ScaleType.FIT_XY);

this.views.add(iv);

}

setCurrentItem(1); // 首页

this.adapter.notifyDataSetChanged();

}

@Override

public void setOnPageChangeListener(OnPageChangeListener listener) {

this.listener2 = listener;

}

}

java图片轮播_java制作广告图片自动轮播控件相关推荐

  1. matlab jpg合成gif,用MATLAB将照片合成视频或者GIF图片、以及Photoshop制作GIF图片

    用MATLAB将照片合成视频或者GIF图片.以及Photoshop制作GIF图片 一.用MATLAB将照片合成视频(我使用的MATLAB是2015版本的) (1).你需要需要合成视频的图片. 所有照片 ...

  2. php怎么banner指定超链接,巧用图片链接模块做banner广告图片,后台可更换图片

    banner广告图片客户要自己更换怎么办,我们可以巧用图片链接模块做banner广告图片,让客户自己来更换banner广告图片.之前我 做过一个简单实现广告图片后台更换教程,是用产品模块来实现的,拖拖 ...

  3. WPF 把图片分割成两份自动翻页 WpfFlipPageControl:CtrlBook 书控件

    原文:WPF 把图片分割成两份自动翻页 WpfFlipPageControl:CtrlBook 书控件 版权声明:本文为博主原创文章,需要转载尽管转载. https://blog.csdn.net/z ...

  4. 使用jQuery快速高效制作网页交互特效 第五章 上机练习四 制作广告图片轮播切换效果

    轮播应有的功能大致都有,分享给一些在学的朋友参考学习. <!DOCTYPE html> <html> <head lang="en"><m ...

  5. java发送html附件_Java发送邮件(图片、附件、HTML)

    一.简介 要在网络上实现邮件功能,必须要有专门的邮件服务器.这些邮件服务器类似于现实生活中的邮局,它主要负责接收用户投递过来的邮件,并把邮件投递到邮件接收者的电子邮箱中. SMTP服务器地址: 一般是 ...

  6. java给图片加水印_java如何给图片加水印

    最近研究一下java如何给上传的图片加上水印,专门为这个功能写了一个方法类,然后再进行调用,代码如下:package WaterMark; import java.awt.AlphaComposite ...

  7. 定时器轮播图---(功能:自动轮播,左右箭头点击切换,点击圆点跳转图片)

    定时器轮播图 几个部分: 封装重复函数 左右箭头点击切换效果 自动轮播-定时器控制(模拟左箭头点击效果以显示出自动轮播的效果).鼠标移入停止,移出继续效果 点击圆点跳转相应页面(解决了点击后不继续轮播 ...

  8. java 显示多行歌词_Java Swing制作多行滚动歌词显示控件 | 学步园

    首先上图一张,为最终制作的效果图,不喜欢或感到失望的朋友可以先行离开 大家已经看到效果图了.那么下面就介绍设计思路和源代码 首先要想显示歌词,就要对歌词文件进行抽象.下面这个类是对某一行歌词文件进行了 ...

  9. python显示gif图片_利用Python制作GIF图片

    #Python制作GIF图片 import imageio def create_gif(image_list, gif_name, duration = 0.1): ''' :param image ...

最新文章

  1. 实验-思科设备划VLAN做单臂路由
  2. linux 12541 重启监听器,ORA-12541:ORA-12541:TNS:没有监听器 解决方法
  3. 关于React面试题汇总
  4. java 点允许没有反应 程序有main_我的java程序点击相应的button键没有反应?我想要实现的功能是点击“左齐”键,按钮左对齐,依此类推;...
  5. IDEA 实用功能Auto Import:自动优化导包(自动删除、导入包)
  6. Cocos Creator教程 ——(二)UI系统介绍(上)
  7. 大专适合学习php么_学好php能做什么?哪些人群适合学习php?
  8. 程序员面试金典——1.6像素翻转
  9. Oracle RAC tns 00505,Alert Log Errors: 12170 TNS-12535/TNS-00505: Operation Timed Out
  10. 淘宝生成器在线制作,淘宝全屏代码装修店招导航教程
  11. 五种常用的3D建模方式,各有什么优缺点?
  12. 一打卡作弊软件CEO被判5年6个月,网友:这也太...
  13. CRMEB二次开发基础接口
  14. 机械制图及计算机绘图试题库,机械制图及计算机绘图试题库版(90页)-原创力文档...
  15. 四级英语词汇加词组(超全)
  16. w3wp ash oracle,Oracle session简介
  17. 热烈欢迎茂名高级技工学校毕业生参加我司技术工程师岗前实训
  18. 基于Web SCADA平台构建实时数字化产线 - 初篇
  19. 李峋同款爱心代码 python版
  20. Eclipse is not responding

热门文章

  1. Oracle通过定时任务+dblink+存储过程传数据到中间库
  2. (测试)Openbravo如何编写一个测试用例
  3. Ubuntu 安装PostgreSQL
  4. 内行看门道:看似“佛系”的《QQ炫舞手游》,背后的音频技术一点都不简单...
  5. c语言藏头诗编程题,Res - 2009夏学期C语言上机练习参考答案汇总
  6. date java 格式化 sss_java DateFormat 格式化格式参考
  7. 解决 使用Xftp传输文件状态错误
  8. 最小生成树:克鲁斯卡尔算法+普里姆算法
  9. 广东计算机专业软件排名前十大学,广东计算机专业综合实力排名出炉,这所高校位居第一...
  10. 辅助工具之Zoomit