アクションバーの右側に画像ビューを追加したいのですが、それを試みましたが、できませんでした。誰も私を助けることができますか?
これは私の画像ビュー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" />
これは、作成するアクションバーの画像です。
これを試して...
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);
つかいます
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>
これにはImageViewは必要ありません。画像にアイコンを使用して新しいアイテムを使用するのが最も賢明なソリューションです。
このアイテムをmenu.xmlに追加します。
<item
Android:title="@string/action_scanner"
Android:orderInCategory="79"
Android:icon="@drawable/adnace_search_i"
Android:showAsAction="ifRoom|withText" />
メニューをonCreateOptionsMenu
にインスタンス化し、onOptionsItemSelected
に実装します。
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プロパティを確認できます
このレイアウトを使用します。 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>