Android實(shí)現(xiàn)圖片疊加效果的兩種方法
本文實(shí)例講述了Android實(shí)現(xiàn)圖片疊加效果的兩種方法。分享給大家供大家參考,具體如下:
效果圖:
第一種:
第二種:
第一種是通過(guò)canvas畫(huà)出來(lái)的效果:
public void first(View v) { // 防止出現(xiàn)Immutable bitmap passed to Canvas constructor錯(cuò)誤 Bitmap bitmap1 = BitmapFactory.decodeResource(getResources(), R.drawable.apple).copy(Bitmap.Config.ARGB_8888, true); Bitmap bitmap2 = ((BitmapDrawable) getResources().getDrawable( R.drawable.go)).getBitmap(); Bitmap newBitmap = null; newBitmap = Bitmap.createBitmap(bitmap1); Canvas canvas = new Canvas(newBitmap); Paint paint = new Paint(); int w = bitmap1.getWidth(); int h = bitmap1.getHeight(); int w_2 = bitmap2.getWidth(); int h_2 = bitmap2.getHeight(); paint.setColor(Color.GRAY); paint.setAlpha(125); canvas.drawRect(0, 0, bitmap1.getWidth(), bitmap1.getHeight(), paint); paint = new Paint(); canvas.drawBitmap(bitmap2, Math.abs(w - w_2) / 2, Math.abs(h - h_2) / 2, paint); canvas.save(Canvas.ALL_SAVE_FLAG); // 存儲(chǔ)新合成的圖片 canvas.restore(); image.setImageBitmap(newBitmap); }
Canvas canvas = new Canvas(newBitmap); 當(dāng)以newBitmap創(chuàng)建Canvas時(shí),所以操作都已經(jīng)在該圖上實(shí)現(xiàn)了。
該例子可以想做是播放器開(kāi)始播放的效果,計(jì)算好中間位置,先覆蓋一層透明灰色的正方形,然后在中間畫(huà)上自己播放的按鈕。
第二種是使用系統(tǒng)的LayerDrawable類,該類主要用來(lái)控制多個(gè)圖片的結(jié)合:
public void second(View v) { Bitmap bitmap1 = ((BitmapDrawable) getResources().getDrawable( R.drawable.apple)).getBitmap(); Bitmap bitmap2 = ((BitmapDrawable) getResources().getDrawable( R.drawable.go)).getBitmap(); Drawable[] array = new Drawable[2]; array[0] = new BitmapDrawable(bitmap1); array[1] = new BitmapDrawable(bitmap2); LayerDrawable la = new LayerDrawable(array); // 其中第一個(gè)參數(shù)為層的索引號(hào),后面的四個(gè)參數(shù)分別為left、top、right和bottom la.setLayerInset(0, 0, 0, 0, 0); la.setLayerInset(1, 20, 20, 20, 20); image.setImageDrawable(la); }
關(guān)聯(lián)數(shù)組array,控制每一層的位置
注意:上面防止出現(xiàn)Immutable bitmap passed to Canvas constructor錯(cuò)誤
原因是如果不用copy的方法,直接引用會(huì)對(duì)資源文件進(jìn)行修改,而Android是不允許在代碼里修改res文件里的圖片
layer-list可以將多個(gè)圖片按照順序?qū)盈B起來(lái)。
語(yǔ)法:在drawalbe/drawable-layer.xml中
<layer-list xmlns:Android="http://schemas.android.com/apk/res/android"> <item Android:drawable="@android:color/white" /> <item Android:drawable="@drawable/logo_overlay" /> </layer-list>
使用方式像其他圖片一樣:
如在樣式中引用:
<resources> <style name="LookupTheme" parent="@Android:style/Theme.Light.NoTitleBar"> <item name="Android:windowBackground">@drawable/drawable-layer</item> </style> </resources>
在java代碼中引用:
在代碼中實(shí)現(xiàn):
Resources resources = getResources(); Drawable[] layers = new Drawable[2]; layers[0] = r.getDrawable(R.drawable.white); layers[1] = r.getDrawable(R.drawable.logo_overlay); LayerDrawable layerDrawable = new LayerDrawable(layers) ((ImageView) findViewById(R.id.imageview)).setImageDrawable(layerDrawable);
再舉一個(gè)例子:
要用2張圖片疊加起來(lái),看上去形成一張圖片
首先創(chuàng)建一個(gè)drawalbe/login_head.xml的文件,內(nèi)容如下:
<?xml version="1.0" encoding="UTF-8"?> <layer-list xmlns:Android="http://schemas.android.com/apk/res/android"> <item Android:id="@+id/user_faceback_drawable" android:drawable="@drawable/faceback" /> <item Android:id="@+id/user_face_drawable" android:drawable="@drawable/h001" android:left="10.0dip" android:top="18.0dip" android:right="25.0dip" android:bottom="35.0dip" /> </layer-list>
然后就可以使用這個(gè)組合的圖片了,比如在ImageView中顯示:
<ImageView Android:id="@+id/faceImg" android:background="@drawable/login_head" Android:layout_width="wrap_content" android:layout_height="wrap_content" />
使用java代碼:
如何使多個(gè)Drawable疊加(合成圖片)?
大家可能知道Bitmap的疊加處理在Android平臺(tái)中可以通過(guò)Canvas一層一層的畫(huà)就行了,而Drawable中如何處理呢? 除了使用BitmapDrawable的getBitmap方法將Drawable轉(zhuǎn)換為Bitmap外,今天Android123給大家說(shuō)下好用簡(jiǎn)單的LayerDrawable類,LayerDrawable顧名思義就是層圖形對(duì)象。下面直接用一個(gè)簡(jiǎn)單的代碼表示:
Bitmap bm = BitmapFactory.decodeResource(getResources(),R.drawable.cwj); Drawable[] array = new Drawable[3]; array[0] = new PaintDrawable(Color.BLACK); //黑色 array[1] = new PaintDrawable(Color.WHITE); //白色 array[2] = new BitmapDrawable(bm); //位圖資源 LayerDrawable ld = new LayerDrawable(array); //參數(shù)為上面的Drawable數(shù)組 ld.setLayerInset(1, 1, 1, 1, 1); //第一個(gè)參數(shù)1代表數(shù)組的第二個(gè)元素,為白色 ld.setLayerInset(2, 2, 2, 2, 2); //第一個(gè)參數(shù)2代表數(shù)組的第三個(gè)元素,為位圖資源 mImageView.setImageDrawable(ld);
上面的方法中LayerDrawable是關(guān)鍵,Android開(kāi)發(fā)網(wǎng)提示setLayerInset方法原型為public void setLayerInset (int index, int l, int t, int r, int b) 其中第一個(gè)參數(shù)為層的索引號(hào),后面的四個(gè)參數(shù)分別為left、top、right和bottom。對(duì)于簡(jiǎn)單的圖片合成我們可以將第一和第二層的PaintDrawable換成BitmapDrawable即可實(shí)現(xiàn)簡(jiǎn)單的圖片合成。
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android圖形與圖像處理技巧總結(jié)》、《Android開(kāi)發(fā)入門(mén)與進(jìn)階教程》、《Android調(diào)試技巧與常見(jiàn)問(wèn)題解決方法匯總》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。
相關(guān)文章
Android入門(mén)之RelativeLayout、FrameLayout用法分析
這篇文章主要介紹了Android入門(mén)之RelativeLayout、FrameLayout用法分析,需要的朋友可以參考下2014-08-08Android仿抖音右滑清屏左滑列表功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了Android仿抖音右滑清屏左滑列表功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06Qt for Android開(kāi)發(fā)實(shí)例教程
這篇文章主要介紹了Qt for Android開(kāi)發(fā)的方法,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-08-08詳解如何使用VisualStudio高效開(kāi)發(fā)調(diào)試AndroidNDK
這篇文章主要介紹了詳解如何使用VisualStudio高效開(kāi)發(fā)調(diào)試AndroidNDK,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-12-12解決Android ListView數(shù)據(jù)為空及加載錯(cuò)誤的方法
這篇文章主要為大家提供了一個(gè)解決Android ListView數(shù)據(jù)為空及加載錯(cuò)誤的方法,感興趣的小伙伴們可以參考一下2016-02-02Android Activity啟動(dòng)模式之singleTop實(shí)例詳解
這篇文章主要介紹了Android Activity啟動(dòng)模式之singleTop,結(jié)合實(shí)例形式較為詳細(xì)的分析了singleTop模式的功能、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2016-01-01Android之利用EventBus發(fā)送消息傳遞示例
本篇文章主要介紹了Android之利用EventBus進(jìn)行消息傳遞示例。EventBus是一款針對(duì)Android優(yōu)化的發(fā)布/訂閱事件總線,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。2017-02-02