ホームページ > Java > &#&チュートリアル > Android の基本: ツールバーの使用

Android の基本: ツールバーの使用

高洛峰
リリース: 2016-11-15 10:02:13
オリジナル
1215 人が閲覧しました

Toolbar は Android 5.0 で起動され、ActionBar コントロールを置き換えるために使用されます。これよりも前のバージョンで使用する必要がある場合は、公式の ToolBar を使用する必要があります。パッケージ内のサポート v7 ツールバーを使用します。

次は公式ウェブサイトのツールバーの紹介です:

Toolbar 
extends ViewGroup 
java.lang.Object 
   ↳    android.view.View 
       ↳    android.view.ViewGroup 
           ↳    android.support.v7.widget.Toolbar
ログイン後にコピー

Android の基本: ツールバーの使用

使用の前提条件

ツールバーを使用するには、アクティビティのアクションバーを非表示にする必要があります。 では、非表示にする方法は 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中
ログイン後にコピー

メニューの追加Android の基本: ツールバーの使用

メニューを追加するには、まずメニューが必要です。ここでは、メニューファイルを定義するために 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>
ログイン後にコピー

以下は、次のコードです。 Javaファイル。

@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; 
    }
ログイン後にコピー

メニューにアイコンを表示

これを書いた後、非表示のメニューにはアイコンが表示されないことがわかります。どのように設定すればよいですか:Android の基本: ツールバーの使用

メソッドをやり直すだけです:ここでのアクティビティは 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); 
   }
ログイン後にコピー
効果は次のとおりです:

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート