209.m1-banner的自动切换

本文介绍了一种使用Handler实现Banner图自动切换的方法,并通过优化ViewPager的触摸事件来提升用户体验。文章详细展示了如何设置无限循环的ViewPager,以及如何在用户触摸时暂停自动播放并在触摸结束后恢复播放。

banner的自动切换是利用hanndler,实现延迟执行,无线调用某个延迟执行的方法,实现一直循环执行延迟播放方法,同时,当点击的时候也需要把自动切换关闭,松开以后重新自动打开。需要注意的是ViewPager触摸时间的返回值是false,不拦截事件。

package com.ldw.market.holder;

import java.util.LinkedList;
import java.util.List;

import com.ldw.market.R;
import com.ldw.market.http.HttpHelper;
import com.ldw.market.utils.UiUtils;

import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.FrameLayout;
import android.view.ViewGroup.LayoutParams;
import android.widget.ImageView;

public class HomePictureHolder extends BaseHolder<List<String>> {

	//holder创建的时候调用下面的方法
	private ViewPager viewPager;
	private List<String> datas;
	@Override
	public View initView() {
		viewPager=new ViewPager(UiUtils.getContext());
		//给ViewPager设置布局的参数LayoutParames,宽度设置在res/values/demons.xml中
		viewPager.setLayoutParams(new AbsListView.LayoutParams(LayoutParams.MATCH_PARENT,UiUtils.getDimens(R.dimen.banner_picture_height)));
		return viewPager;
	}

	//holder中设置数据调用setData的掉用
	@Override
	public void refreshView(List<String> datas) {
		this.datas = datas;
		viewPager.setAdapter(new HomeAdapter());
		//当前条目的设置,实现“无限”滑动
		viewPager.setCurrentItem(1000*datas.size());
		/*
		runTask = new AuToRunTask();
		runTask.start();
		*/
		//当ViewPager按下的时候取消自动切换
		viewPager.setOnTouchListener(new OnTouchListener() {
			
			@Override
			public boolean onTouch(View v, MotionEvent event) {
				switch (event.getAction()) {
				case MotionEvent.ACTION_DOWN:
					runTask.stop();   
					break;
				case MotionEvent.ACTION_CANCEL:  // 事件的取消
				case MotionEvent.ACTION_UP:
					runTask.start();
					break;
				}
				
				return false; // viewPager 触摸事件 返回值要是false  
			}
		});
		runTask = new AuToRunTask();
		runTask.start();
	}
	
	
	boolean flag;
	private AuToRunTask runTask;
	//banner自动切换
	public class AuToRunTask implements Runnable{

		@Override
		public void run() {
			if(flag){
				//先取消之前的任务
				UiUtils.cancel(this);
				// 获取到ViewPager当前的条目
				int currentItem = viewPager.getCurrentItem();
				currentItem ++;
				viewPager.setCurrentItem(currentItem);
				// 延迟执行当前的任务
				UiUtils.postDelayed(this, 3000);
			}
			
		}
		//开始执行循环
		public void start(){
			//如果之前的停止的
			if(!flag){
				UiUtils.cancel(this);
				flag = true;
				//递归调用
				UiUtils.postDelayed(this, 3000);
			}
		}
		//停止
		public  void stop(){
			if(flag){
				flag=false;
				UiUtils.cancel(this);
			}
		}
		
	}
	
	class HomeAdapter extends PagerAdapter{
		//管理ImageView避免每次都new ImageView().LinkedList增删快速
		LinkedList<ImageView> convertView = new LinkedList<ImageView>();

		@Override
		public int getCount() {
			// 数目设置到最大,实现循环
			return Integer.MAX_VALUE;
		}

		@Override
		public boolean isViewFromObject(View arg0, Object arg1) {
			// TODO Auto-generated method stub
			return arg0==arg1;
		}
		
		@Override
		public void destroyItem(ViewGroup container, int position, Object object) {
			//uper.destroyItem(container, position, object);
			//移除的对象转化成ImageView对象
			ImageView view = (ImageView) object;
			//把移除的对象添加到缓存的集合中
			convertView.add(view);
			container.removeView((View)object);
		}

		@Override
		public Object instantiateItem(ViewGroup container, int position) {
			int index = position%datas.size();
			ImageView view;
			//如果缓存的集合不是空的就从集合中获取
			if(convertView.size() > 0){
				//获取到集合的第一个元素
				view = convertView.remove(0);
			}else{
				view = new ImageView(UiUtils.getContext());
			}
			//初始化imageView
			bitmapUtils.display(view, HttpHelper.URL+"image?name="+datas.get(index));
			container.addView(view);  //加载的view对象
			return view; // 返回的对象
		}
		
	}

}

UiUtils.java

package com.ldw.market.utils;

import android.content.Context;
import android.content.res.Resources;
import android.graphics.drawable.Drawable;
import android.view.View;

import com.ldw.market.BaseApplication;

/*
 * 工具类,加载字符串
 */
public class UiUtils {

	/*
	 * 获取到字符数组 ,加载XML文件中的字符数组
	 * @param tabNames  字符数组的id
	 */
	public static String[] getStringArray(int tabNames) {
		return getResource().getStringArray(tabNames);
	}
	
	public static Resources getResource() {
		//获取资源
		return BaseApplication.getApplication().getResources();
	}
	
	public static Context getContext(){
		//获取到上下文
		return BaseApplication.getApplication();
	}
	
	/** dip转换px */
	public static int dip2px(int dip) {
		final float scale = getResource().getDisplayMetrics().density;
		return (int) (dip * scale + 0.5f);
	}

	/** pxz转换dip */

	public static int px2dip(int px) {
		final float scale = getResource().getDisplayMetrics().density;
		return (int) (px / scale + 0.5f);
	}
	
	//获取到res/values/demons.xml的配置参数
	public static int getDimens(int homePictureHeight) {
		return (int) getResource().getDimension(homePictureHeight);
	}
	
	/**
	 * 把Runnable 方法提交到主线程运行
	 * @param runnable
	 */
	public static void runOnUiThread(Runnable runnable) {
		// 在主线程运行
		if(android.os.Process.myTid()==BaseApplication.getMainTid()){
			runnable.run();
		}else{
			//获取主线程的handler  
			BaseApplication.getHandler().post(runnable);
		}
	}
	
	public static View inflate(int id) {
		return View.inflate(getContext(), id, null);
	}

	public static Drawable getDrawalbe(int id) {
		return getResource().getDrawable(id);
	}

	//延迟time时间执行task
	public static void postDelayed(Runnable run, int time) {
		// 获取到主线程的handler
		BaseApplication.getHandler().postDelayed(run, time);//调用runnable中的run方法
	}

	//取消一个任务
	public static void cancel(Runnable run) {
		// 获取到主线程的handler
		BaseApplication.getHandler().removeCallbacks(run);
		
	}


}


具有多种最大功率点跟踪(MPPT)方法的光伏发电系统(P&O-增量法-人工神经网络-模糊逻辑控制-粒子群优化)之使用粒子群算法的最大功率点追踪(MPPT)(Simulink仿真实现)内容概要:本文介绍了一个涵盖多个科研领域的综合性MATLAB仿真资源集合,重点聚焦于光伏发电系统中基于粒子群优化(PSO)算法的最大功率点追踪(MPPT)技术的Simulink仿真实现。文档还列举了多种MPPT方法(如P&O、增量电导法、神经网络、模糊逻辑控制等),并展示了该团队在电力系统、智能优化算法、机器学习、路径规划、无人机控制、信号处理等多个方向的技术服务能力与代码实现案例。整体内容以科研仿真为核心,提供大量可复现的Matlab/Simulink模型和优化算法应用实例。; 适合人群:具备一定电力电子、自动控制或新能源背景,熟悉MATLAB/Simulink环境,从事科研或工程仿真的研究生、科研人员及技术人员。; 使用场景及目标:①学习并实现光伏系统中基于粒子群算法的MPPT控制策略;②掌握多种智能优化算法在电力系统与自动化领域的建模与仿真方法;③获取可用于论文复现、项目开发和技术攻关的高质量仿真资源。; 阅读建议:建议结合提供的网盘资料,按照研究方向选取对应模块进行实践,重点关注Simulink模型结构与算法代码逻辑的结合,注重从原理到仿真实现的全过程理解,提升科研建模能力。
热成像人物检测数据集 一、基础信息 数据集名称:热成像人物检测数据集 图片数量: 训练集:424张图片 验证集:121张图片 测试集:61张图片 总计:606张热成像图片 分类类别: - 热成像人物:在热成像图像中的人物实例 - 非热成像人物:在非热成像或普通图像中的人物实例,用于对比分析 标注格式: YOLO格式,包含边界框和类别标签,适用于目标检测任务。数据来源于热成像和视觉图像,覆盖多种场景条件。 二、适用场景 热成像监控与安防系统开发: 数据集支持目标检测任务,帮助构建能够在低光、夜间或恶劣环境下自动检测和定位人物的AI模型,提升监控系统的可靠性和实时响应能力。 红外视觉应用研发: 集成至红外摄像头或热成像设备中,实现实时人物检测功能,应用于安防、军事、救援和工业检测等领域。 学术研究与创新: 支持计算机视觉与热成像技术的交叉研究,助力开发新算法用于人物行为分析或环境适应型检测模型。 教育与培训: 可用于高校或培训机构,作为学习热成像人物检测和AI模型开发的教学资源,提升实践技能。 三、数据集优势 精准标注与多样性: 每张图片均由专业标注员标注,确保边界框定位准确,类别分类清晰。包含热成像和非热成像类别,提供对比数据,增强模型的泛化能力和鲁棒性。 场景实用性强: 数据覆盖多种环境条件,如不同光照和天气,模拟真实世界应用,适用于复杂场景下的人物检测任务。 任务适配性高: YOLO标注格式兼容主流深度学习框架(如YOLOv5、YOLOv8等),可直接加载使用,支持快速模型开发和评估。 应用价值突出: 专注于热成像人物检测,在安防、监控和特殊环境检测中具有重要价值,支持早期预警和高效决策。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值