編輯:關於Android編程
HashMap<String, SoftReference<Drawable>> imageCache 關於SoftReference這個類多少知道些機制,會用就ok了。
機制:簡單來說,她會幫助我們管理內存,防止內存溢出,另外一點也就相當於map,臨時緩存些圖片drawable讓我們可以直接引用,很好了解決了OOM異常.
實現代碼片段:
[java]
package com.Tianyou.Mobile.Common;
import java.io.IOException;
import java.io.InputStream;
import java.lang.ref.SoftReference;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.HashMap;
import com.Tianyou.Mobile.Util.MyUtil;
import android.graphics.Bitmap;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable;
import android.os.Handler;
import android.os.Message;
/***
* 異步加載圖片 緩存的實現
*
* @author jia
*
*/
public class AsyncImageLoader {
// 軟引用
private HashMap<String, SoftReference<Drawable>> imageCache;
public AsyncImageLoader() {
imageCache = new HashMap<String, SoftReference<Drawable>>();
}
/***
* 下載圖片
*
* @param imageUrl
* 圖片地址
* @param imageCallback
* 回調接口
* @return
*/
public Drawable loadDrawable(final String imageUrl,
final ImageCallback imageCallback) {
if (imageCache.containsKey(imageUrl)) {
SoftReference<Drawable> softReference = imageCache.get(imageUrl);
Drawable drawable = softReference.get();
if (drawable != null) {
return drawable;
}
}
final Handler handler = new Handler() {
public void handleMessage(Message message) {
imageCallback.imageLoaded((Drawable) message.obj, imageUrl);
}
};
// 開啟線程下載圖片
new Thread() {
@Override
public void run() {
Drawable drawable = loadImageFromUrl(imageUrl);
// 將下載的圖片保存至緩存中
imageCache.put(imageUrl, new SoftReference<Drawable>(drawable));
Message message = handler.obtainMessage(0, drawable);
handler.sendMessage(message);
}
}.start();
return null;
}
/***
* 根據URL下載圖片(這裡要進行判斷,先去本地sd中查找,沒有則根據URL下載,有則返回該drawable)
*
* @param url
* @return
*/
public static Drawable loadImageFromUrl(String imageURL) {
Bitmap bitmap = MyUtil.GetBitmap(imageURL, 100);
Drawable drawable = new BitmapDrawable(bitmap);
return drawable;
}
// 回調接口
public interface ImageCallback {
public void imageLoaded(Drawable imageDrawable, String imageUrl);
}
}
上面這個類斯通見慣了,大部分都是這樣實現的,我現在要講一點,也是迷惑我很久了一點(回調接口運用)本人基礎不好,所以卡在這裡了,
在listview中的getview方法中要調用這個方法:
代碼片段:
[java]
public Drawable getDrawable(AsyncImageLoader asyncImageLoader,
String imageUrl, final ImageView imageView) {
Drawable drawable = asyncImageLoader.loadDrawable(imageUrl,
new ImageCallback() {
@Override
public void imageLoaded(Drawable imageDrawable,
String imageUrl) {
if (imageDrawable != null)
imageView.setImageDrawable(imageDrawable);
else
imageView.setImageResource(R.drawable.u6_normal);
}
});
return drawable;
}
這個方法作用:獲取軟用中的圖片,其實在我們首次進入listview中的時候,軟應用是不起作用的,只是用來下載圖片保存至sd卡和軟引用中.這個方法就是執行了這些操作,對於參數imageView 就是在要把獲取的drawable設置進去.
執行的順利:首先我們調用的是loadDrawable這個方法,然後查找軟引用中有沒有該drawable,沒有的話則線程下載,下載ok後會執行handleMessage中imageCallback.imageLoaded((Drawable) message.obj, imageUrl);然後執行我們已經實現了這個接口.
在getiview 中執行代碼片段:
[java]
Drawable drawable = getDrawable(asyncImageLoader, Image_L,
holder.iv_image);
if(drawable!=null)
holder.iv_image.setImageDrawable(drawable);
當我們下滑動後,然後在上滑動的時候軟應用起到了效果,效率很快哦,可以和新浪聘美了,呵呵,玩笑,要優化的地方還很多.
作者:jj120522
介紹Action Bar是一種新増的導航欄功能,在Android 3.0之後加入到系統的API當中,它標識了用戶當前操作界面的位置,並提供了額外的用戶動作、界面導航等功能
ZXing是谷歌的一個開源庫,可以用來生成二維碼、掃描二維碼。本文所介紹的是第一部分。首先上效果圖:ZXing相關各種文件官方下載地址:https://github.co
Android上的界面展示都是通過Activity實現的,Activity實在是太常用了,我相信大家都已經非常熟悉了,這裡就不再贅述。 但是Activity也有它的局限性
Volley 是一個 HTTP 庫,它能夠幫助 Android app 更方便地執行網絡操作,最重要的是,它更快速高效。我們可以通過開源的 AOSP 倉庫獲取到 Voll