• 一手遮天 Android


    项目地址 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

  • 相关阅读:
    单链表的反转是常见的面试题目
    线程状态
    史上最强Android只是总结
    常见的一些算法
    Android LayoutInflater.inflate()使用详解
    Android事件分发机制及滑动冲突解决方案
    Kotlin——高阶函数详解与标准的高阶函数使用
    Kotlin 中的伴生对象和静态成员
    知识点
    Android Studio:多包名打包
  • 原文地址:https://www.cnblogs.com/webabcd/p/android_view_navigation_ToolBarDemo2.html
Copyright © 2020-2023  润新知