Ivano Donadi
Ivano Donadi

Reputation: 377

Changing Search View back icon?

I am using AppCompat action bar and i want to change the back icon of the searchview I use in the action bar. I searched but i couldn't find a solution.

I have tried setting the icon in the style :

<item name="homeAsUpIndicator">@drawable/myBackButton</item>

but I want to set another one programmatically when the user selects the search view. Any ideas on how I can do it?

Upvotes: 4

Views: 2323

Answers (3)

Solkin
Solkin

Reputation: 916

To customize SearchView "up" icon, you can use style attribute:

collapseIcon="@drawable/ic_discard_icon"

in your Toolbar layout:

<android.support.v7.widget.Toolbar
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:collapseIcon="@drawable/ic_discard_icon"/>

Or you can move this attribute into Toolbar style. As you wish.

Upvotes: 5

MrJM
MrJM

Reputation: 1214

You can change the background of the back icon like this

Toolbar toolbar;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    initToolbar();
}

private void initToolbar() {
    toolbar = (Toolbar) findViewById(R.id.tbMaster);
    setSupportActionBar(toolbar);
    if (toolbar != null) {
        toolbar.setBackgroundColor(getResources().getColor(R.color.base_color));
        getSupportActionBar().setTitle("Title");
        getSupportActionBar().setDisplayHomeAsUpEnabled(true);
        getSupportActionBar().setHomeAsUpIndicator(R.drawable.image);
    }
}

Upvotes: 0

Danila Grigorenko
Danila Grigorenko

Reputation: 423

Try this code snippet:

if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.ICE_CREAM_SANDWICH) {
    // get the parent view of home (app icon) imageview
    ViewGroup home = (ViewGroup) findViewById(android.R.id.home).getParent();
    // get the first child (up imageview)
    ( (ImageView) home.getChildAt(0) )
        // change the icon according to your needs
        .setImageDrawable(getResources().getDrawable(R.drawable.custom_icon_up));
} else {
    // get the up imageview directly with R.id.up
    ( (ImageView) findViewById(R.id.up) )
        .setImageDrawable(getResources().getDrawable(R.drawable.custom_icon_up));
} 

Upvotes: 0

Related Questions