<1>簡介
之前往往是通過Bitmap、Drawable和Canvas配合完成,需要寫一系列繁雜的邏輯去縮小原有圖片,從而得到縮略圖。
現在我給大家介紹一種比較簡單的方法:(網上有)
在Android 2.2版本中,新增了一個ThumbnailUtils工具類來是實現縮略圖,此工具類的功能是強大的,使用是簡單,它提供了一個常量和三個方法。利用這些常數和方法,可以輕鬆快捷的實現圖片和視頻的縮略圖功能。
<2>ThumbnailUtils工具類
常量:
OPTIONS_RECYCLE_INPUT
從此常量用於表示應該回收extractThumbnail(Bitmap,
int, int, int)
輸入源圖片(第一個參數),除非輸出圖片就是輸入圖片。
方法:
Bitmap createVideoThumbnail(String filePath, int kind)
創建一張視頻的縮略圖。如果視頻已損壞或者格式不支持可能返回null。
參數:
filePath: 視頻文件路徑
kind: 文件種類,可以是 MINI_KIND 或 MICRO_KIND
Bitmap extractThumbnail(Bitmap source, int width, int height, int options)
創建所需尺寸居中縮放的位圖。
參數:
source: 需要被創造縮略圖的源位圖對象
width: 生成目標的寬度
height: 生成目標的高度
options:在縮略圖抽取時提供的選項
Bitmap extractThumbnail(Bitmap source, int width, int height)
創建所需尺寸居中縮放的位圖。
參數:
source: 需要被創造縮略圖的源位圖對象
width: 生成目標的寬度
height: 生成目標的高度
<3>具體實現:
主代碼:
package xiaosi.thumbnail;
import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable;
import android.media.ThumbnailUtils;
import android.os.Bundle;
import android.widget.ImageView;
public class ThumbnailActivity extends Activity {
private Bitmap bitmap = null;
private ImageView image;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
image = (ImageView) findViewById(R.id.image);
//得到原圖片
bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.v);
//得到縮略圖
bitmap = ThumbnailUtils.extractThumbnail(bitmap, 100, 100);
image.setImageBitmap(bitmap);
}
}
佈局文件main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:background="#999999"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/v"
android:layout_marginLeft="10dip"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="縮略圖:"
android:textColor="#000000"/>
<ImageView android:id="@+id/image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dip"/>
</LinearLayout>