Android Toolbar

在Material Design之中有一个名称为Toolbar,用来取代过去的ActionBar控件。


基本用法

可分为三步:

新增ToolBar样式

value/styles.xml:


<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">

 <item name="colorPrimary">@color/colorPrimary</item>

 <item name="colorPrimaryDark">@color/colorPrimaryDark</item>

 <item name="colorAccent">@color/colorAccent</item>

 <item name="android:textColorPrimary">@android:color/white</item>

 <!--返回或更多(app:showAsAction="never")的按钮颜色-->

 <item name="colorControlNormal">@android:color/white</item>

 <!--菜单字体颜色-->

 <item name="actionMenuTextColor">@android:color/white</item>

</style>

看看 parent=”Theme.AppCompat.Light.NoActionBar”


<style name="Theme.AppCompat.Light.NoActionBar">

       <item name="windowActionBar">false</item>

       <item name="windowNoTitle">true</item>

</style>


XML布局中新增ToolBar

<android.support.v7.widget.Toolbar 

    android:id="@+id/toolbar"

    android:layout_width="match_parent"

    android:layout_height="wrap_content"

    android:minHeight="?actionBarSize"

    android:background="?attr/colorPrimary"

    app:popupTheme="@style/ThemeOverlay.AppCompat.Light">

 </android.support.v7.widget.Toolbar>


在程序中替代ActionBar

Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);

       setSupportActionBar(toolbar);

       android.support.v7.app.ActionBar actionBar = getSupportActionBar();

       if (actionBar != null) {

           actionBar.setDisplayHomeAsUpEnabled(true);

            

       }

res/menu/activity_main.xml


<menu xmlns:android="http://schemas.android.com/apk/res/android"

      xmlns:app="http://schemas.android.com/apk/res-auto"

      xmlns:tools="http://schemas.android.com/tools"

      tools:context=".MainActivity">

 

  <item android:id="@+id/action_edit"

        android:title="@string/action_edit"

        android:orderInCategory="80"

        android:icon="@drawable/ab_edit"

        app:showAsAction="ifRoom" />

</menu>


@Override

   public boolean onCreateOptionsMenu(Menu menu) {


       // Inflate the menu; this adds items to the action bar if it is present.

       getMenuInflater().inflate(R.menu.activity_main, menu);

       return true;

   }

@Override

   public boolean onOptionsItemSelected(MenuItem item) {

       switch (item.getItemId()) {


           case R.id.action_edit:

             return true;

           case android.R.id.home:

             super.onBackPressed();//返回

             return true;

           default:

               return super.onOptionsItemSelected(item);

       }


   }


单独使用而不与ActionBar进行关联

在前一节中设置与ActionBar进行关联,如果不进行关联也是可以使用。即执行方法:setSupportActionBar,那么Menu的操作也不用在onCreateOptionsMenu方法,直接使用ToolBar的inflateMenu方法,Menu的事件也是独立的,需要通过设置ToolBar的setOnMenuItemClickListener来实现。


Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);

 

// App Logo

toolbar.setLogo(R.drawable.ic_launcher);

// Title

toolbar.setTitle("My Title");

// Sub Title

toolbar.setSubtitle("Sub title");

 

//setSupportActionBar(toolbar);

 toolbar.inflateMenu(R.menu.activity_main);

// Navigation Icon 要設定在 setSupoortActionBar后 才有作用

// 否則會出現 back button 

toolbar.setNavigationIcon(R.drawable.ab_android);

toolbar.setNavigationOnClickListener(new View.OnClickListener() {


            @Override

            public void onClick(View v) {

                

            }

        });

// Menu item click 设定在 setSupportActionBar 之后才有作用

toolbar.setOnMenuItemClickListener(onMenuItemClick);


onMenuItemClick

private Toolbar.OnMenuItemClickListener onMenuItemClick = new Toolbar.OnMenuItemClickListener() {

  @Override

  public boolean onMenuItemClick(MenuItem menuItem) {

    String msg = "";

    switch (menuItem.getItemId()) {

      case R.id.action_edit:  

        break;

    }

    return true;

  }

};

自定义布局

title修改为居中

<android.support.v7.widget.Toolbar

    xmlns:android="http://schemas.android.com/apk/res/android"

    android:id="@+id/toolbar"

    android:layout_width="match_parent"

    android:background="@mipmap/bg_title"

    android:minHeight="?actionBarSize">


    <TextView

        android:id="@+id/toolbar_title"

        style="@style/TextAppearance.AppCompat.Widget.ActionBar.Title"

        android:layout_width="wrap_content"

        android:layout_height="wrap_content"

        android:layout_gravity="center" />

</android.support.v7.widget.Toolbar>

禁用系统的title显示,即setDisplayShowTitleEnabled方法

Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);

       setSupportActionBar(toolbar);

 TextView  mTitleView = (TextView) toolbar.findViewById(R.id.toolbar_title);

       android.support.v7.app.ActionBar actionBar = getSupportActionBar();

       if (actionBar != null) {

           actionBar.setDisplayHomeAsUpEnabled(true);

            actionBar.setDisplayShowTitleEnabled(false);

       }

 mTitleView.setText("");


实现将布局的内容延伸到状态栏

style

<item name="android:windowTranslucentStatus" tools:targetApi="19">true</item>


Toolbar增加一个paddingTop:

<android.support.v7.widget.Toolbar 

    android:id="@+id/toolbar"

    android:layout_width="match_parent"

    android:layout_height="wrap_content"

    android:background="@mipmap/bg_title"

    android:minHeight="?actionBarSize"

    android:paddingTop="@dimen/status_bar_height"/>


values/dimens.xml

<dimen name="status_bar_height">0dp</dimen>


values-v19/dimens.xml

<dimen name="status_bar_height">25dp</dimen>


values-v23/dimens.xml

<dimen name="status_bar_height">24dp</dimen>


可以通过以下方法取得StatusBarHeight:

public int getStatusBarHeight() {

        int result = 0;

        int resourceId = getResources().getIdentifier("status_bar_height", "dimen", "android");

        if (resourceId > 0) {

            result = getResources().getDimensionPixelSize(resourceId);

        }

        return result;

    }

另外注意:toolbar所在的父布局不能同时设置fitsSystemWindow=”true”,它会使得屏幕上的可布局空间位于状态栏下方与导航栏上方。


因为这个带来了键盘挡住EditText的问题,解决方案:

在EditText所在的父布局设置fitsSystemWindow=”true”即可。

资源下载链接为: https://pan.quark.cn/s/1bfadf00ae14 “STC单片机电压测量”是一个以STC系列单片机为基础的电压检测应用案例,它涵盖了硬件电路设计、软件编程以及数据处理等核心知识点。STC单片机凭借其低功耗、高性价比和丰富的I/O接口,在电子工程领域得到了广泛应用。 STC是Specialized Technology Corporation的缩写,该公司的单片机基于8051内核,具备内部振荡器、高速运算能力、ISP(在系统编程)和IAP(在应用编程)功能,非常适合用于各种嵌入式控制系统。 在源代码方面,“浅雪”风格的代码通常简洁易懂,非常适合初学者学习。其中,“main.c”文件是程序的入口,包含了电压测量的核心逻辑;“STARTUP.A51”是启动代码,负责初始化单片机的硬件环境;“电压测量_uvopt.bak”和“电压测量_uvproj.bak”可能是Keil编译器的配置文件备份,用于设置编译选项和项目配置。 对于3S锂电池电压测量,3S锂电池由三节锂离子电池串联而成,标称电压为11.1V。测量时需要考虑电池的串联特性,通过分压电路将高电压转换为单片机可接受的范围,并实时监控,防止过充或过放,以确保电池的安全和寿命。 在电压测量电路设计中,“电压测量.lnp”文件可能包含电路布局信息,而“.hex”文件是编译后的机器码,用于烧录到单片机中。电路中通常会使用ADC(模拟数字转换器)将模拟电压信号转换为数字信号供单片机处理。 在软件编程方面,“StringData.h”文件可能包含程序中使用的字符串常量和数据结构定义。处理电压数据时,可能涉及浮点数运算,需要了解STC单片机对浮点数的支持情况,以及如何高效地存储和显示电压值。 用户界面方面,“电压测量.uvgui.kidd”可能是用户界面的配置文件,用于显示测量结果。在嵌入式系统中,用
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值