天天看點

一手遮天 Android - view(導航類): ToolBar 顯示自定義 view,清除自定義 view 與 Toolbar 兩側的間距,自定義彈出的 OptionMenu 的樣式

一手遮天 Android - view(導航類): ToolBar 顯示自定義 view,清除自定義 view 與 Toolbar 兩側的間距,自定義彈出的 OptionMenu 的樣式

項目位址 https://github.com/webabcd/AndroidDemo

作者 webabcd

示例如下:

/view/navigation/ToolBarDemo2.java

/**
 * Toolbar - 工具欄(導航欄)
 * 本例用于示範如果在 Toolbar 中顯示自定義 view,以及如何清除自定義 view 與 Toolbar 兩側的間距,以及如何自定義彈出的 OptionMenu 的樣式
 * “清除自定義 view 與 Toolbar 兩側的間距”和“自定義彈出的 OptionMenu 的樣式”是通過修改主題實作的,參見 res/values/styles.xml 的 MyTheme_MyToolbarStyle
 *
 * 關于 OptionMenu 菜單的基礎知識和樣式修改可以參見 PopupMenu 的相關說明(請參見 view/flyout/PopupMenuDemo1, view/flyout/PopupMenuDemo2)
 * 注:如果覺得 OptionMenu 實作不了需求,就用 PopupWindow 吧
 */

package com.webabcd.androiddemo.view.navigation;

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import androidx.appcompat.widget.Toolbar;

import com.webabcd.androiddemo.R;

public class ToolBarDemo2 extends AppCompatActivity {

    private Toolbar mToolbar1;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        // 指定主題,以便“清除自定義 view 與 Toolbar 兩側的間距”和“自定義彈出的 OptionMenu 的樣式”
        setTheme(R.style.MyTheme_MyToolbarStyle);

        setContentView(R.layout.activity_view_navigation_toolbardemo2);

        mToolbar1 = findViewById(R.id.toolbar1);

        sample();
    }

    private void sample() {
        // 從 xml 中加載 OptionMenu 的資料
        mToolbar1.inflateMenu(R.menu.menu_view_navigation_toolbardemo2);
    }
}

           
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <!--
        Toolbar - 工具欄(導航欄)
            layout_height - 高度
            background - 背景
            navigationIcon - 左側按鈕的圖示

        注:本例中的 Toolbar 來自 androidx 包,如果要使用自定義屬性,則要引入 xmlns:app="http://schemas.android.com/apk/res-auto"
    -->
    <androidx.appcompat.widget.Toolbar
        android:id="@+id/toolbar1"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="@color/red"
        app:navigationIcon="@drawable/img_sample_son">

        <!--
           Toolbar 中顯示的自定義 view
        -->
        <TextView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@color/orange"
            android:text="自定義 view"
            android:textColor="#fff"
            android:textSize="18sp" />

    </androidx.appcompat.widget.Toolbar>

</LinearLayout>


           
<?xml version="1.0" encoding="utf-8"?>
<!--
    用于構造 OptionMenu 的選項資料,參見 view/navigation/ToolBarDemo2.java
-->
<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:id="@+id/item1" android:title="菜單 1" />
    <item android:id="@+id/item2" android:title="菜單 2" />
    <item android:id="@+id/item3" android:title="菜單 3" />
</menu>