Change ActionBarDrawerToggle icon android in toolbar?
Asked Answered
K

4

13

I have an activity with navigation drawer and toolbar

Activity

public class MainActivity extends AppCompatActivity {
private Toolbar toolbar;
private CustomTextViewMondaRegular tvTitle;
private ListView mDrawerList;
private DrawerLayout mDrawerLayout;
private ActionBarDrawerToggle mDrawerToggle;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    toolbar = (Toolbar) findViewById(R.id.tool_bar);
    setSupportActionBar(toolbar);

    mDrawerList = (ListView) findViewById(R.id.left_drawer);
    tvTitle = (CustomTextViewMondaRegular) findViewById(R.id.actionTitle);
    tvTitle.setText(getIntent().getStringExtra("title"));
    mDrawerList.setAdapter(new NavAdapter(getApplicationContext()));
    mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
    mDrawerList.setOnItemClickListener(new DrawerItemClickListener());

    mDrawerToggle = new ActionBarDrawerToggle(this, mDrawerLayout,toolbar,
            R.string.title_activity_main, R.string.title_activity_main) {
        @Override
        public void onDrawerClosed(View view) {
            super.onDrawerClosed(view);
            invalidateOptionsMenu(); // creates call to onPrepareOptionsMenu()
        }

        @Override
        public void onDrawerOpened(View drawerView) {
            super.onDrawerOpened(drawerView);
            invalidateOptionsMenu();
            // creates call to onPrepareOptionsMenu()
        }
    };
    mDrawerLayout.setDrawerListener(mDrawerToggle);
    if (savedInstanceState == null) {

    }
}

@Override
protected void onPostCreate(Bundle savedInstanceState) {
    super.onPostCreate(savedInstanceState);
    mDrawerToggle.syncState();
}

public void onConfigurationChanged(Configuration newConfig) {
    super.onConfigurationChanged(newConfig);
    mDrawerToggle.onConfigurationChanged(newConfig);
}

private class DrawerItemClickListener implements ListView.OnItemClickListener {
    @Override
    public void onItemClick(AdapterView parent, View view, int position, long id) {
        Logger.e("pos", position + "");
    }
}

}

Activity XML

<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="com.vf.MainActivity">

<FrameLayout
    android:id="@+id/frame_container"
    android:layout_width="match_parent"
    android:layout_height="match_parent">



    <android.support.v7.widget.Toolbar
        android:id="@+id/tool_bar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="@android:color/white"
        android:elevation="3dp"
        android:minHeight="?attr/actionBarSize"
        android:theme="@style/MyDarkToolbarStyle">

        <TextView
            android:id="@+id/actionTitle"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginEnd="5dp"
            android:layout_marginRight="5dp"
            android:drawableEnd="@drawable/logo"
            android:drawableRight="@drawable/logo"
            android:gravity="center"
            android:text="XXXXXX"
            android:textColor="#000000"
            android:textSize="18sp" />

    </android.support.v7.widget.Toolbar>
</FrameLayout>

<ListView
    android:id="@+id/left_drawer"
    android:layout_width="240dp"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    android:background="@android:color/white"
    android:choiceMode="singleChoice"
    android:divider="#D8D8D8" />

The toggle icon currently shows the default icon. I need to change that icon. How can I do that?

Kenn answered 6/7, 2015 at 5:37 Comment(0)
L
40

For people who come across this SO question in future,

We have to disable drawer indicator

mDrawerToggle.setDrawerIndicatorEnabled(false);

and then set ToolBar's navigation button

 mToolbar.setNavigationIcon(R.drawable.navIcon);

P.S. after that we have to set Navigation click listner on toolbar and open NavigationDrawer manualy. like mToolbar.setNavigationOnClickListener :D

Livvi answered 21/9, 2015 at 13:2 Comment(0)
J
13

Try the code below:

getSupportActionBar().setHomeButtonEnabled(true);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);       
getSupportActionBar().setHomeAsUpIndicator(R.drawable.ic_menu_drawer);
Jingoism answered 19/8, 2016 at 15:51 Comment(2)
Cool. This working without worrying about setting listeners to open manually. ThanksQuail
simple answer , and no need to add listener thank youLeontina
L
4
mDrawerToggle.setDrawerIndicatorEnabled(false);

and open the drawer with

mImageView.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            DrawerLayout drawer = findViewById(R.id.drawer_layout);
            drawer.openDrawer(Gravity.START);

        }
    });
Last answered 8/4, 2018 at 19:27 Comment(0)
J
2

You can set the menu icon using setHomeAsUpIndicator, pass a drawable to this method.

See code below:

    ActionBar ab = getSupportActionBar();
    ab.setHomeAsUpIndicator(R.drawable.ic_menu);
    ab.setDisplayHomeAsUpEnabled(true);
Jacquie answered 6/7, 2015 at 5:40 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.