web-dev-qa-db-ja.com

アクションバーの右側に画像ビューを追加する方法は?

アクションバーの右側に画像ビューを追加したいのですが、それを試みましたが、できませんでした。誰も私を助けることができますか?

これは私の画像ビューxmlです

 <ImageView
        Android:id="@+id/imageView4"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_alignParentRight="true"
        Android:layout_alignParentTop="true"
        Android:src="@drawable/adnace_search_i" />

これは、作成するアクションバーの画像です。

enter image description here

25
anuruddhika

これを試して...

    ActionBar actionBar = getActionBar();
    actionBar.setDisplayOptions(actionBar.getDisplayOptions()
            | ActionBar.DISPLAY_SHOW_CUSTOM);
    ImageView imageView = new ImageView(actionBar.getThemedContext());
    imageView.setScaleType(ImageView.ScaleType.CENTER);
    imageView.setImageResource(R.drawable.adnace_search_i);
    ActionBar.LayoutParams layoutParams = new ActionBar.LayoutParams(
            ActionBar.LayoutParams.WRAP_CONTENT,
            ActionBar.LayoutParams.WRAP_CONTENT, Gravity.RIGHT
                    | Gravity.CENTER_VERTICAL);
    layoutParams.rightMargin = 40;
    imageView.setLayoutParams(layoutParams);
    actionBar.setCustomView(imageView);
58
Gopal Gopi

つかいます

ActionBar actionBar = getSupportActionBar();
actionBar.setDisplayShowCustomEnabled(true);

LayoutInflater inflator = (LayoutInflater) this .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View v = inflator.inflate(R.layout.custom_imageview, null);

actionBar.setCustomView(v);

カスタムImageViewのコード

<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
xmlns:tools="http://schemas.Android.com/tools"
Android:layout_width="match_parent"
Android:layout_height="match_parent"
Android:id="@+id/layout">

<ImageView
    Android:id="@+id/imageView4"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:layout_alignParentRight="true"
    Android:layout_alignParentTop="true"
    Android:src="@drawable/adnace_search_i" />
</RelativeLayout>
22
Mandar Kakade

これにはImageViewは必要ありません。画像にアイコンを使用して新しいアイテムを使用するのが最も賢明なソリューションです。

このアイテムをmenu.xmlに追加します。

<item
    Android:title="@string/action_scanner"
    Android:orderInCategory="79"
    Android:icon="@drawable/adnace_search_i"
    Android:showAsAction="ifRoom|withText" />

メニューをonCreateOptionsMenuにインスタンス化し、onOptionsItemSelectedに実装します。

10
Alfaplus

Res/menu/menu.xmlのmenu.xmlにこの行を追加します

<menu xmlns:Android="http://schemas.Android.com/apk/res/Android"
   xmlns:yourapp="http://schemas.Android.com/apk/res-auto" >
 <!-- Search, should appear as action button -->
 <item Android:id="@+id/action_search"
      Android:icon="@drawable/ic_action_search"
      Android:title="@string/action_search"
      yourapp:showAsAction="ifRoom"  />
 ...
 </menu>

Android開発者向けチュートリアル で、より多くのactionBarプロパティを確認できます

4
Mukul Aggarwal

このレイアウトを使用します。 API 28でそれを使用しました

<Android.support.design.widget.AppBarLayout
            Android:layout_width="match_parent"
            Android:layout_height="wrap_content"
            Android:theme="@style/AppTheme.AppBarOverlay">

            <Android.support.v7.widget.Toolbar
                Android:id="@+id/toolbar"
                Android:layout_width="match_parent"
                Android:layout_height="?attr/actionBarSize"
                Android:background="?attr/colorPrimary"
                app:popupTheme="@style/AppTheme.PopupOverlay">

                <RelativeLayout
                    Android:layout_width="wrap_content"
                    Android:layout_height="wrap_content">

                    <ImageView
                        Android:layout_width="24dp"
                        Android:layout_height="24dp"
                        Android:onClick="makeToast"
                        Android:layout_alignParentEnd="true"
                        Android:src="@drawable/ic_flag" />
                </RelativeLayout>
            </Android.support.v7.widget.Toolbar>
0
Beast77