zoukankan      html  css  js  c++  java
  • 一手遮天 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

  • 相关阅读:
    Spring使用JDBC配置具名参数
    linux中的匿名管道和命名管道
    linux查看CPU信息
    磁盘阵列RAID原理、种类及性能优缺点对比
    SMP和MPP的优缺点
    Hadoop datablock size
    MySQL 高可用架构之MHA
    MySQL 高可用架构之MMM
    五大常见的MySQL高可用方案
    hive加载数据
  • 原文地址:https://www.cnblogs.com/webabcd/p/android_view_navigation_ToolBarDemo2.html
Copyright © 2011-2022 走看看