Toolbar は Android 5.0 で起動され、ActionBar コントロールを置き換えるために使用されます。これよりも前のバージョンで使用する必要がある場合は、公式の ToolBar を使用する必要があります。パッケージ内のサポート v7 ツールバーを使用します。
次は公式ウェブサイトのツールバーの紹介です:
Toolbar extends ViewGroup java.lang.Object ↳ android.view.View ↳ android.view.ViewGroup ↳ android.support.v7.widget.Toolbar
使用の前提条件
ツールバーを使用するには、アクティビティのアクションバーを非表示にする必要があります。 では、非表示にする方法は 3 つあります。以下にそれぞれを紹介します
方法 1:
res/values/styles.xml ファイルで変更する
<style name="AppTheme.Base" parent="Theme.AppCompat"> <item name="windowActionBar">false</item> <item name="android:windowNoTitle">true</item> </style>
ActionBar を使用せずにテーマを直接使用することもできます
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
方法 2:
でアクティビティのテーマを変更する以下に示すようにマニフェスト ファイルを作成します。
<activity android:name="MainActivity" android:theme="@style/Theme.AppCompat.Light.NoActionBar"> </activity>
方法 3 :
setContentView の前にコードで直接キャンセルします。
requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.activity_main); //supportRequestWindowFeature(Window.FEATURE_NO_TITLE); 在AppCompatActivity中
使い方
位置は固定ではありませんので、レイアウトファイルに以下のコードを追加します。
<android.support.v7.widget.Toolbar android:id="@+id/toolbar" android:layout_width="match_parent" android:layout_height="?android:attr/actionBarSize" android:background="?attr/colorPrimaryDark" app:title="Title" app:titleTextColor="#222222" app:logo="@mipmap/ic_launcher" app:subtitle="subtitle"></android.support.v7.widget.Toolbar>
title はタイトルの設定に使用され、titleTextColor はタイトルのフォント色の設定に使用されます。background は背景色の設定に使用されます。値は Java コードで動的に設定することもできます。
mToolbar.setTitle("JavaTitle"); mToolbar.setSubtitle("JavaSubTitle"); mToolbar.setLogo(R.mipmap.ic_launcher); mToolbar.setNavigationIcon(android.R.drawable.ic_input_delete); mToolbar.setOverflowIcon(ContextCompat.getDrawable(this, android.R.drawable.ic_menu_more)); / setActionBar(mToolbar); //activity中 setSupportActionBar(mToolbar); //AppCompatActivity中
メニューの追加
メニューを追加するには、まずメニューが必要です。ここでは、メニューファイルを定義するために main.xml を res/menu/ に作成することを選択します。 コードは次のとおりです<?xml version="1.0" encoding="utf-8"?> <menu xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto"> <item android:id="@+id/add" android:icon="@android:drawable/ic_menu_add" android:title="Add" app:showAsAction="never|withText"/> <item android:id="@+id/delete" android:icon="@android:drawable/ic_menu_delete" android:title="Delete" app:showAsAction="never|withText"/> <item android:id="@+id/edit" android:icon="@android:drawable/ic_menu_edit" android:title="Edit" app:showAsAction="never|withText"/> <item android:id="@+id/email" android:icon="@android:drawable/sym_action_email" android:title="Email" app:showAsAction="never|withText"/> </menu>
@Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.main, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { switch (item.getItemId()) { case android.R.id.home: Toast.makeText(MainActivity.this, "您点击了NavigationIcon", Toast.LENGTH_SHORT).show(); break; case R.id.add: Toast.makeText(MainActivity.this, "Add", Toast.LENGTH_SHORT).show(); break; case R.id.delete: Toast.makeText(MainActivity.this, "Delete", Toast.LENGTH_SHORT).show(); break; case R.id.edit: Toast.makeText(MainActivity.this, "Edit", Toast.LENGTH_SHORT).show(); break; case R.id.email: Toast.makeText(MainActivity.this, "Email", Toast.LENGTH_SHORT).show(); break; } return true; }
メニューにアイコンを表示
これを書いた後、非表示のメニューにはアイコンが表示されないことがわかります。どのように設定すればよいですか:
メソッドをやり直すだけです:ここでのアクティビティは AppCompatActivity です@Override protected boolean onPrepareOptionsPanel(View view, Menu menu) { if (menu != null) { if (menu.getClass() == MenuBuilder.class) { try { Method m = menu.getClass().getDeclaredMethod("setOptionalIconsVisible", Boolean.TYPE); m.setAccessible(true); m.invoke(menu, true); } catch (Exception e) { Log.i("tag", "onPrepareOptionsPanel: " + getClass().getSimpleName() + "onMenuOpened...unable to set icons for overflow menu" + e); } } } return super.onPrepareOptionsPanel(view, menu); }