<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;</p><p>import android.app.Activity;<br />import android.graphics.Bitmap;<br />import android.graphics.BitmapFactory;<br />import android.graphics.drawable.BitmapDrawable;<br />import android.graphics.drawable.Drawable;<br />import android.media.ThumbnailUtils;<br />import android.os.Bundle;<br />import android.widget.ImageView;</p><p>public class ThumbnailActivity extends Activity { </p><p>private Bitmap bitmap = null;<br />private ImageView image;<br /> @Override<br /> public void onCreate(Bundle savedInstanceState) {<br /> super.onCreate(savedInstanceState);<br /> setContentView(R.layout.main);<br /> image = (ImageView) findViewById(R.id.image);<br /> //得到原圖片<br /> bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.v);<br /> //得到縮圖<br /> bitmap = ThumbnailUtils.extractThumbnail(bitmap, 100, 100);<br /> image.setImageBitmap(bitmap);<br /> }<br />}<br />
main.xml
<?xml version="1.0" encoding="utf-8"?><br /> <LinearLayout<br /> xmlns:android="http://schemas.android.com/apk/res/android"<br /> android:orientation="vertical"<br /> android:background="#999999"<br /> android:layout_width="fill_parent"<br /> android:layout_height="fill_parent"><br /> <ImageView<br /> android:layout_width="wrap_content"<br /> android:layout_height="wrap_content"<br /> android:src="@drawable/v"<br /> android:layout_marginLeft="10dip"/><br /> <TextView<br /> android:layout_width="wrap_content"<br /> android:layout_height="wrap_content"<br /> android:text="縮圖:"<br /> android:textColor="#000000"/><br /> <ImageView android:id="@+id/image"<br /> android:layout_width="wrap_content"<br /> android:layout_height="wrap_content"<br /> android:layout_marginLeft="10dip"/><br /> </LinearLayout>