一手遮天 Android - view(导航类): ToolBar 显示自定义 view,清除自定义 view 与 Toolbar 两侧的间距,自定义弹出的 OptionMenu 的样式

项目地址 https://github.com/webabcd/AndroidDemo
作者 webabcd

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

项目地址 https://github.com/webabcd/AndroidDemo
作者 webabcd

posted @ 2021-05-31 12:46  webabcd  阅读(187)  评论(0编辑  收藏  举报