Android App開發(fā)中將View或Drawable轉(zhuǎn)為Bitmap的方法
View轉(zhuǎn)換為Bitmap
Android中經(jīng)常會遇到把View轉(zhuǎn)換為Bitmap的情形,比如,對整個屏幕視圖進行截屏并生成圖片;Coverflow中需要把一頁一頁的view轉(zhuǎn)換為Bitmap、以便實現(xiàn)復(fù)雜的圖形效果(陰影、倒影效果等);再比如一些動態(tài)的實時View為便于觀察和記錄數(shù)據(jù)、需要臨時生成靜態(tài)的Bitmap。
實現(xiàn)方法:
1)下面是筆者經(jīng)常用的一個轉(zhuǎn)換方法
public static Bitmap convertViewToBitmap(View view, int bitmapWidth, int bitmapHeight){
Bitmap bitmap = Bitmap.createBitmap(bitmapWidth, bitmapHeight, Bitmap.Config.ARGB_8888);
view.draw(new Canvas(bitmap));
return bitmap;
}
或者用如下方法:
public static Bitmap convertViewToBitmap(View view){
view.buildDrawingCache();
Bitmap bitmap = view.getDrawingCache();
return bitmap;
}
一般情況下,這個方法能夠正常的工作。但有時候,生成Bitmap會出現(xiàn)問題(Bitmap全黑色)。主要原因是drawingCache的值大于系統(tǒng)給定的值。我們可以看一下buildDrawingCache()方法中的一段代碼:
if (width <= 0 || height <= 0 ||(width * height * (opaque && !translucentWindow ? 2 : 4) > ViewConfiguration.get(mContext).getScaledMaximumDrawingCacheSize())) {
destroyDrawingCache();
return;
}
上面的代碼中,width和height是所要cache的view繪制的寬度和高度,所以(width * height * (opaque && !translucentWindow ? 2 : 4) 計算的是當(dāng)前所需要的cache大小。ViewConfiguration.get(mContext).getScaledMaximumDrawingCacheSize()得到的是系統(tǒng)所提供的最大的DrawingCache的值。當(dāng)所需要的drawingCache >系統(tǒng)所提供的最大DrawingCache值時,生成Bitmap就會出現(xiàn)問題,此時獲取的Bitmap就為null。
所以在只需要修改所需的cache值就可以解決問題了。于是我們引入第二種方法:
2)完美的解決方案
public static Bitmap convertViewToBitmap(View view){
view.measure(MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED), MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
view.layout(0, 0, view.getMeasuredWidth(), view.getMeasuredHeight());
view.buildDrawingCache();
Bitmap bitmap = view.getDrawingCache();
return bitmap;
}
view 使用 "getMeasuredWidth()" and "getMeasuredHeight()"方法計算長寬。此時,Bitmap就能正確獲取了。
轉(zhuǎn)換Drawable為Bitmap
這個相對沒那么復(fù)雜,直接來看代碼:
/**
* Bitmap轉(zhuǎn)化為drawable
* @param bitmap
* @return
*/
public static Drawable bitmap2Drawable(Bitmap bitmap){
return new BitmapDrawable(bitmap) ;
}
/**
* Drawable 轉(zhuǎn) bitmap
* @param drawable
* @return
*/
public static Bitmap drawable2Bitmap(Drawable drawable){
if(drawable instanceof BitmapDrawable){
return ((BitmapDrawable)drawable).getBitmap() ;
}else if(drawable instanceof NinePatchDrawable){
Bitmap bitmap = Bitmap
.createBitmap(
drawable.getIntrinsicWidth(),
drawable.getIntrinsicHeight(),
drawable.getOpacity() != PixelFormat.OPAQUE ? Bitmap.Config.ARGB_8888
: Bitmap.Config.RGB_565);
Canvas canvas = new Canvas(bitmap);
drawable.setBounds(0, 0, drawable.getIntrinsicWidth(),
drawable.getIntrinsicHeight());
drawable.draw(canvas);
return bitmap;
}else{
return null ;
}
}
相關(guān)文章
android在連拍菜單中增加連拍張數(shù)選項功能實現(xiàn)代碼
想要增加連拍張數(shù)選項需要在entries, entryvalues中添加兩項,同時在mtk_strings.xml中添加相應(yīng)的字符串,具體如下,感興趣的朋友可以參考下哈2013-06-06
Android?APP瘦身shrinkResources使用問題詳解
這篇文章主要為大家介紹了Android?APP瘦身shrinkResources使用問題詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
Android 監(jiān)聽?wèi)?yīng)用前/后臺切換實例代碼
本篇文章主要介紹了Android 監(jiān)聽?wèi)?yīng)用前/后臺切換實例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06
札記:android手勢識別功能實現(xiàn)(利用MotionEvent)
現(xiàn)在手勢識別的應(yīng)用已經(jīng)很廣泛了。本篇文章主要介紹了android手勢識別功能實現(xiàn),具有一定的參考價值,有興趣的可以了解一下。2016-11-11
Android實現(xiàn)Reveal圓形Activity轉(zhuǎn)場動畫的完整步驟
這篇文章主要給大家介紹了關(guān)于Android Reveal圓形Activity轉(zhuǎn)場動畫的實現(xiàn)過程,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11
使用ViewPager實現(xiàn)android軟件使用向?qū)Чδ軐崿F(xiàn)步驟
現(xiàn)在的大部分android軟件,都是使用說明,就是第一次使用該軟件時,會出現(xiàn)向?qū)?,可以左右滑動,然后就進入應(yīng)用的主界面了,下面我們就實現(xiàn)這個功能2013-11-11
Android編程之創(chuàng)建自己的內(nèi)容提供器實現(xiàn)方法
這篇文章主要介紹了Android編程之創(chuàng)建自己的內(nèi)容提供器實現(xiàn)方法,結(jié)合具體實例形式分析了Android創(chuàng)建內(nèi)容提供器的原理、步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-08-08
Android菜單操作之創(chuàng)建并響應(yīng)菜單
這篇文章主要介紹了Android菜單操作之創(chuàng)建并響應(yīng)菜單的相關(guān)資料,如何使用代碼創(chuàng)建菜單項,給菜單項分組,及各種響應(yīng)菜單事件的方法,需要的朋友可以參考下2016-04-04

