实现异步加载本地图片,防止oom错误

本文详细介绍了异步加载SD卡图片与网络图片的方法,包括缓存机制、线程池应用、视图复用等关键步骤,以及如何优化图片加载效率。
package com.su.doubanrise.widget;

import java.io.File;
import java.lang.ref.SoftReference;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.WeakHashMap;

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;

import android.os.Handler;
import android.os.Message;
import android.widget.ImageView;

import com.su.doubanrise.DoubanApp;
import com.su.doubanrise.R;
import com.su.doubanrise.overall.Constant;
import com.su.doubanrise.util.FileDownLoader;
import com.su.doubanrise.util.Str;

public class AsyncImageLoader {
	//TODO Remove the callback ,set imageView in function.
	//TODO Add Thread Pool Reference:OscChina BitmapManager
	//TODO Adapter convertview reuse 
	private Context mcontext;
	private HashMap<String, SoftReference<Bitmap>> imageCache = new HashMap<String, SoftReference<Bitmap>>();
	private static Map<ImageView, String> imageViews;
	private Bitmap defbitmap;;

	public AsyncImageLoader() {
		this.mcontext = DoubanApp.getContext();
		defbitmap = BitmapFactory.decodeResource(mcontext.getResources(),
				R.drawable.ic_launcher);
		imageViews = Collections
				.synchronizedMap(new WeakHashMap<ImageView, String>());
	}

	/**
	 * 异步加载sd卡的图片 ,
	 * 
	 * @param uri
	 * @param imageView
	 * @param imageCallback
	 * @return
	 */
	private Bitmap loadBitmapFromSD(final String uri,
			final ImageView imageView, final ImageCallback imageCallback) {

		if (imageCache.containsKey(uri)) {
			SoftReference<Bitmap> SoftReference = imageCache.get(uri);
			Bitmap bitmap = SoftReference.get();
			if (bitmap != null) {
				return bitmap;
			}
		}

		final Handler handler = new Handler() {
			public void handleMessage(Message msg) {
				imageCallback.imageLoaded((Bitmap) msg.obj, imageView, uri);
			}
		};
		new Thread() {
			public void run() {
				Bitmap bitmap = null;
				bitmap = getBitmapFromFile(uri);
				imageCache.put(uri, new SoftReference<Bitmap>(bitmap));
				if (!new File(uri).isFile()) {
					bitmap = BitmapFactory.decodeResource(
							mcontext.getResources(), R.drawable.ic_launcher);
				}
				Message msg = handler.obtainMessage(0, bitmap);
				handler.sendMessage(msg);
				bitmap = null;
			}
		}.start();
		return defbitmap;
	}

	/**
	 * 异步加载Net上的图片 ,
	 * 
	 * @param url
	 * @param imageView
	 * @param imageCallback
	 * @return
	 */
	private Bitmap loadBitmapFromNet(final String url,
			final ImageView imageView, final int opsize,
			final ImageCallback imageCallback) {
		imageViews.put(imageView, url);
		final String savePath = Constant.PICPATH + Str.md5(url);

		if (imageCache.containsKey(url)) {
			Bitmap bitmap = imageCache.get(url).get();
			if (bitmap != null) {
				return bitmap;
			}
		}

		final Handler handler = new Handler() {
			public void handleMessage(Message msg) {
				String tag = imageViews.get(imageView);
				if (tag != null && tag.equals(url)) {
					imageCallback.imageLoaded((Bitmap) msg.obj, imageView, url);
				}

			}
		};
		new Thread() {
			public void run() {
				try {
					FileDownLoader.downloadImg(url, savePath);

				} catch (Exception e) {
					e.printStackTrace();
				}
				Bitmap bitmap = null;
				bitmap = getBitmapFromFile(savePath, opsize);
				imageCache.put(url, new SoftReference<Bitmap>(bitmap));
				if (bitmap != null) {
					Message msg = handler.obtainMessage(0, bitmap);
					handler.sendMessage(msg);
				}

			}
		}.start();
		return defbitmap;
	}

	private interface ImageCallback {
		public void imageLoaded(Bitmap imageBitmap, ImageView imageView,
				String uri);
	}

	/**
	 * 从本读读取图片
	 * 
	 * @param uri
	 * @return
	 */
	private Bitmap getBitmapFromFile(String uri) {
		BitmapFactory.Options options = new BitmapFactory.Options();
		options.inSampleSize = 8;
		Bitmap bitmap = BitmapFactory.decodeFile(uri, options);
		return bitmap;
	}

	/**
	 * 从本读读取图片 添加opt参数
	 * 
	 * @param uri
	 * @return
	 */
	private Bitmap getBitmapFromFile(String uri, int opsize) {
		BitmapFactory.Options options = new BitmapFactory.Options();
		options.inSampleSize = opsize;
		options.inPurgeable = true;
		Bitmap bitmap = BitmapFactory.decodeFile(uri, options);// 这里还是会出现oom??
		return bitmap;
	}

	/**
	 * 最终暴露给用户的接口
	 * 
	 * @param url
	 * @param imageView
	 */

	public void setAsyncBitmapFromNet(String url, ImageView imageView) {
		if (url == null) {
			return;
		}
		imageView.setImageBitmap(loadBitmapFromNet(url, imageView, 1,
				new ImageCallback() {

					public void imageLoaded(Bitmap imageBitmap,
							ImageView imageView, String imageUrl) {

						imageView.setImageBitmap(imageBitmap);

					}
				}));
	}

	/**
	 * 异步加载本地图片
	 * 
	 * @param uri
	 * @param imageView
	 */
	public void setAsyncBitmapFromSD(String uri, ImageView imageView) {
		if (uri == null) {
			return;
		}

		imageView.setImageBitmap(loadBitmapFromSD(uri, imageView,
				new ImageCallback() {
					public void imageLoaded(Bitmap imageBitmap,
							ImageView imageView, String imageUrl) {
						imageView.setImageBitmap(imageBitmap);
					}
				}));
	}

	/**
	 * 由于加载本地图片时间较短 ,其实可以使用这个方法减小线程的开销
	 * 
	 * @param uri
	 * @param imageView
	 */
	public void setBitmapFromSD(String uri, ImageView imageView) {
		if (uri == null) {
			return;
		}
		imageView.setImageBitmap(getBitmapFromFile(uri));
	}
}

内容概要:本文介绍了一个基于Simulink的混合储能驱动永磁同步电机全系统仿真模型,涵盖了系统整体架构与关键控制策略,重点实现了电流环的二阶滑模控制(STSMC)、有限集模型预测控制(FCS-MPC)和PI控制等多种先进控制方法。该模型集成了混合储能系统与永磁同步电机驱动系统,能够模拟复杂工况下的动态响应、能量管理过程及多变量耦合特性,适用于高性能电机控制系统的设计、分析与验证,尤其在新能源汽车、电动驱动系统和工业自动化等领域具有重要应用价值。; 适合人群:具备Simulink仿真基础、电力电子与电机控制背景的高校研究生、科研人员及自动化、电气工程领域的研发工程师。; 使用场景及目标:①用于研究和对比不同电流控制策略(如STSMC、FCS-MPC、PI)在永磁同步电机系统中的动态性能、鲁棒性与抗干扰能力;②支撑混合储能系统在电动驱动、新能源汽车、智能电网等领域的系统级仿真与优化设计;③为先进控制算法的开发与工程化落地提供高保真、模块化的仿真平台。; 阅读建议:建议结合Simulink模型与相关控制理论进行对照学习,重点关注各功能模块之间的信号交互、控制逻辑设计及参数整定方法,可通过修改负载条件、切换控制模式等方式开展对比实验,深入理解系统动态行为与控制效果差异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值