Skip to main content

Create drop-down menu with image icons in Android

Hello devs!
In this tutorial, we will be creating a drop-down menu on clicking a button in Android studio.




Here is an image of how our menu is going to look:


On clicking the hamburger icon, a vertical menu will appear with image icons of your choice. Above image is just to get an idea of what we are going to develop.

Let's get started.

Step 1:
Open the layout file where you want the menu. Add the hamburger icon on an image button.

<ImageButton    android:layout_width="50dp"    android:layout_height="50dp"    android:src="@drawable/ham"    android:id="@+id/ham"    android:background="#00000000"/>

 Note: #00000000 specifies 'transparent' background.

Step 2:
Add a vertical linear layout for the menu. Inside that, add nested linear layouts for horizontal rows.
<LinearLayout    android:layout_width="wrap_content"    android:layout_height="wrap_content"    android:orientation="vertical"    android:layout_below="@id/ham"    android:id="@+id/dropdown"    android:visibility="invisible"
    android:padding="2dp"    >

    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:orientation="horizontal"
      >        <ImageButton            android:layout_width="100dp"            android:layout_height="100dp"            android:src="@drawable/img1"            android:scaleType="centerCrop"/>
          <ImageButton            android:layout_width="100dp"            android:layout_height="100dp"            android:src="@drawable/img2"            android:scaleType="centerCrop"/>

        
    </LinearLayout>    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:orientation="horizontal"
      >        <ImageButton            android:layout_width="100dp"            android:layout_height="100dp"            android:src="@drawable/img3"            android:scaleType="centerCrop"/> 
         <ImageButton            android:layout_width="100dp"            android:layout_height="100dp"            android:src="@drawable/img4"            android:scaleType="centerCrop"/>
        
    </LinearLayout>
</LinearLayout>
And so on..

Note: The visibility is "invisible" so that it will be visible after clicking the hamburger icon.

Step 3:
Surround this inside a scroll view.
 <ScrollView    android:layout_width="wrap_content"    android:layout_height="wrap_content"    android:layout_below="@id/ham">
<LinearLayout    android:layout_width="wrap_content"    android:layout_height="wrap_content"    android:orientation="vertical"    android:layout_below="@id/ham"    android:id="@+id/dropdown"    android:visibility="invisible"
    android:padding="2dp"    >

    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:orientation="horizontal"
      >        <ImageButton            android:layout_width="100dp"            android:layout_height="100dp"            android:src="@drawable/img1"            android:scaleType="centerCrop"/>
          <ImageButton            android:layout_width="100dp"            android:layout_height="100dp"            android:src="@drawable/img2"            android:scaleType="centerCrop"/>

        
    </LinearLayout>    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:orientation="horizontal"
      >        <ImageButton            android:layout_width="100dp"            android:layout_height="100dp"            android:src="@drawable/img3"            android:scaleType="centerCrop"/> 
         <ImageButton            android:layout_width="100dp"            android:layout_height="100dp"            android:src="@drawable/img4"            android:scaleType="centerCrop"/>
        
    </LinearLayout>
</LinearLayout>
</ScrollView>

Note: The layout of the menu should be added in the XML after the other contents of the layout so that menu is above the content and not below it.

Also, the layout_below is set to the ham.

Step 4:
Let's move on to the JAVA part.

Inside the Activity class declare the ImageButtons(all including ham icon) and LinearLayout(vertical) and in the onCreate method initialize it using its IDs (findViewById method).



Step 5:
Now we need to make the menu visible on clicking the ham icon and invisible on clicking it again. For that, refer the following code.


hambtn.setOnClickListener(new View.OnClickListener() {
    @Override    public void onClick(View view) {
        if(dropmenu.getVisibility()==View.VISIBLE)
        {   
            dropmenu.setVisibility(View.GONE);        }
        else {          
            dropmenu.setVisibility(View.VISIBLE);        }
    }
});

Step 6:
Set onClickListener for every ImageButton and specify an action for each. It may be opening an activity or simply making a Toast.

That's all folks! Hope you find this tutorial helpful.


This idea is inspired from :https://www.viralandroid.com/2016/01/android-custom-vertical-dropdown-icons-menu.html





T

Comments

Popular posts from this blog

Shake a view(edit text) on incorrect input at OTP,passwords,etc (Android)

Hello devs! This is another short tutorial to show how to shake an Edit text view if the input is incorrect. Note : The tutorial assumes that you have the basic knowledge about android development. It involves the following steps : 1. Create the Edit text and cast it inside the onCreate. EditText edittext=findViewById(R.id.edit_text); Recommended : https://github.com/GoodieBag/Pinview Optional - Put the edit text inside a dialog to take an input from the dialog. 2. Write an animation XML. Here is an example: ( shake.xml ) Courtesy : https://gist.github.com/simon-heinen/9795036 <? xml version = " 1.0 " encoding = " utf-8 " ?> < set xmlns : android = " http://schemas.android.com/apk/res/android " > < rotate android : duration = " 70 " android : fromDegrees = " -5 " androi...

Fix for eclipse oxygen icon not displaying in ubuntu.

There is a bug in the latest version of eclipse IDE. The icon is not displayed. If you are facing the same problem then I might have a fix for you. There are various reasons why this may occur. One of the problems is caused because icon of eclipse is not present in pixmaps folder. To add it simply copy the icon of eclipse into /use/share/pixmaps folder. Note: You need to have root access to do that.  Also, make sure the name of the icon is eclipse.xpm  For this, use the terminal to fire the command: sudo cp /eclipse_path/icon.xpm /usr/share/pixmaps/eclipse.xpm Here replace the eclipse_path with your eclipse folder path. E.g. /home/leena/eclipse/java-oxygen/eclipse/icon.xpm

Fix 'UNEXPECTED INCONSISTENCY; Run fsck manually' on Ubuntu

If you have the following Ubuntu error, I might have a fix for it. fsck from util-linux 2.26.2 /dev/sda1 contains a file system with errors, check forced. /dev/sda1: Inodes that were part of a corrupted orphan linked list found. /dev/sda1: UNEXPECTED INCONSISTENCY; RUN fsck MANUALLY.         (i.e., without -a or -p options) fsck exited with status code 4 The root filesystem on /dev/sda1 requires a manual fsck Busybox v1.22.1 (Ubuntu 1:1.22.0-15ubuntu1) built in shell (ash) Enter 'help' for a list of built-in commands. (initramfs) _ And believe me help command does nothing. Solution: Just fire a simple command to execute  fsck manually. fsck /dev/sda1 If some other filesystem is causing the error then mention that name after fsck. It will show some processing. If it asks any questions like Fix(y/n)? always enter y . In the end when (initramfs) reappears enter: reboot Well, that's all! It worked for me. Hope it works for ...