一手遮天 Android - view(导航类): ToolBar 显示自定义 view,清除自定义 view 与 Toolbar 两侧的间距,自定义弹出的 OptionMenu 的样式
一手遮天 Android - view(导航类): ToolBar 显示自定义 view,清除自定义 view 与 Toolbar 两侧的间距,自定义弹出的 OptionMenu 的样式
示例如下:
/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);
}
}
/layout/activity_view_navigation_toolbardemo2.xml
<?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>
/menu/menu_view_navigation_toolbardemo2.xml
<?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>