Skip to main content

Drawables in Android - Layer drawable

Let us see how to use layer drawable. You can have two or more bitmaps on different layers to create such a drawable

Using xml:

You should use layer-list in your xml file to create layerdrawable. Here is layer.xml
 <?xml version="1.0" encoding="utf-8"?>  
 <layer-list xmlns:android="http://schemas.android.com/apk/res/android">  
 <item>  
 <bitmap android:src="@drawable/whiteicon"  
 android:gravity="top|left"/>  
 </item>  
 <item>  
 <bitmap android:src="@drawable/blueicon"  
 android:gravity="top|left"/>  
 </item>  
 <item>  
 <bitmap android:src="@drawable/redicon"  
 android:gravity="top|left"/>  
 </item>  
 </layer-list>  

We are using three different bitmaps whiteicon.png, redicon.png and blueicon.png which are present in /res/drawable/mdpi folder. All these are of different sizes and aligned to top left. This drawable can be used as a background to any widget in your program.

Button b = (Button)findViewById(R.id.button1);
b.setBackgroundResource(R.drawable.layer);

Now the button would look like this




Using code:

Next let us see how to create layerdrawable using the code.
  private LayerDrawable createBmp(){  
     BitmapDrawable d1 = (BitmapDrawable) getResources().getDrawable(R.drawable.blueicon);  
     d1.setGravity(Gravity.LEFT);  
     BitmapDrawable d2 = (BitmapDrawable) getResources().getDrawable(R.drawable.redicon);  
     d1.setGravity(Gravity.LEFT);  
     BitmapDrawable d3 = (BitmapDrawable) getResources().getDrawable(R.drawable.blueicon);  
     d3.setGravity(Gravity.LEFT);  
     Drawable drawableArray[]= new Drawable[]{d3,d2,d1};  
     LayerDrawable layerDraw = new LayerDrawable(drawableArray);  
     layerDraw.setLayerInset(1, 15, 15, 0, 0);//set offset of 2 layer  
     layerDraw.setLayerInset(2,40,40,0,0);//set offset for third layer  
     return layerDraw;  
   }  


 
It is important to arrange your bitmaps properly and give offsets so that bigger bitmap does not overlap smaller one completely.


And in code add this drawable as a background to some widget.

LayerDrawable ld = createBmp();
b.setBackgroundDrawable(ld);


Now here is our layer drawable image


Comments

  1. Heya i'm for the fіrst time here. I found thiѕ
    board and I find It reɑlly useful & іt hslped mе out
    a lot. I hope too givee ѕomething back and helρ others like ʏou aided
    me.

    ReplyDelete

Post a Comment

Popular posts from this blog

Copy to clipboard

In my upcoming app, I have codes which I display. These are some times lengthy, and I want the app to be able to copy this to clipboard. Once it is in clipboard, users can paste it anywhere. So how do you copy some text from your app to clipboard. You need to use clipboard manager. Clipboard Manager This class sets and gets data for the clipboard using Clipdata objects.  You can get the object of this class using system service.  - using statement context.getSystemService(Context.CLIPBOARD_SERVICE) Example I have a dummy project with a button, onclick of which copies content to clipboard. Here is my activity file package com . hegdeapps . testapp ; import android.content.ClipData ; import android.content.ClipboardManager ; import android.support.v7.app.AppCompatActivity ; import android.os.Bundle ; import android.view.View ; import android.widget.Button ; import android.widget.TextView ; public class MainActivity extends AppCompa

Simple ListView Adapter and list item select

When you are using a listview in your applications many a times you will write your own adapter to display item. But if your list is very simple showing a list of strings, you can use inbuilt adapters like ArrayAdapter, SimpleCursorAdapter etc. ArrayAdapter Let us look at an example <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <ListView android:layout_height="wrap_content" android:id="@+id/listView1" android:layout_width="match_parent" android:layout_margin="20dp"> </ListView> </LinearLayout> And add these lines to the onCreate method of the activity. super.onCreate(savedInstanc