1 imageView.setScaleType(ImageView.ScaleType.FIT_XY );
這裏咱們重點理解ImageView的屬性android:scaleType,即ImageView.setScaleType(ImageView.ScaleType)。 android:scaleType是控制圖片如何resized/moved來匹對ImageView的size。 ImageView.ScaleType / android:scaleType值的意義區別: CENTER /center 按圖片的原來size居中顯示,當圖片長/寬超過View的長/寬,則截取圖片的居中部分顯示 CENTER_CROP / centerCrop 按比例擴大圖片的size居中顯示,使得圖片長(寬)等於或大於View的長(寬) CENTER_INSIDE / centerInside 將圖片的內容完整居中顯示,經過按比例縮小或原來的size使得圖片長/寬等於或小於 View的長/寬 FIT_CENTER / fitCenter 把圖片按比例擴大/縮小到View的寬度,居中顯示 FIT_END / fitEnd 把圖片按比例擴大/縮小到View的寬度,顯示在View的下部分位置 FIT_START / fitStart 把圖片按比例擴大/縮小到View的寬度,顯示在View的上部分位置 FIT_XY / fitXY 把圖片 不按比例 擴大/縮小到View的大小顯示 MATRIX / matrix 用矩陣來繪製
一開始我不明白MATRIX矩陣,網上搜索後發現原來MATRIX矩陣能夠動態縮小放大圖片來顯示,這裏不展開深刻的瞭解,只是貼出相關語句,縮小圖片:html
bmpWidth=bmp.getWidth(); bmpHeight=bmp.getHeight(); scale=0.8; scaleWidth=()(scaleWidth*scale); scaleHeight=()(scaleHeight*scale); Matrix matrix= Matrix(); matrix.postScale(scaleWidth, scaleHeight); Bitmap resizeBmp=Bitmap.createBitmap(bmp, 0, 0, bmpWidth, bmpHeight, matrix, );
1 <ImageView
2 android:id="@+id/image"
3 android:layout_width="fill_parent"
4 android:layout_height="fill_parent"
5 android:scaleType="center"
6 android:src="@drawable/candle"
7 />