一手遮天 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>