AndroidUI ToolBar

本文深入探讨了Android L引入的ToolBar控件的使用方法,包括隐藏原生ActionBar、自定义样式、设置控件及菜单栏交互等关键步骤。详细介绍了ToolBar在布局、主题和自定义颜色等方面的特性,以及如何通过代码和XML文件进行配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ToolBar是android L引入的新控件,相当于更为灵活版的actionbar,官方提供了supprot library用于向下兼容。Toolbar更像是一般的View元素,可以被放置在view树体系的任意位置,可以应用动画,可以跟着scrollView滚动,可以与布局中的其他view交互。

  1. ToolBar的使用
    首先要了解一下Color Palette,以便于自定义我们自己个性的App。
    这里写图片描述

    下面正式介绍如何使用ToolBar
    (1)隐藏原本的actionbar
    有两种方法,一是修改我们继承的主题为Theme.AppCompat.Light.NoActionBar,或者在自定义AppTheme时:

<resources>

    <!-- Base application theme. -->
    <style name="AppTheme" parent="AppTheme.Base">
        <item name="colorPrimary">#F44336</item>
        <item name="colorPrimaryDark">#D32F2F</item>
        <!-- Customize your theme here. -->
    </style>
    <style name="AppTheme.Base" parent="Theme.AppCompat.Light">


        <item name="windowNoTitle">true</item>
        <item name="windowActionBar">false</item>
    </style>

</resources>

(2)在布局文件中声明toolbar控件

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent" tools:context=".MainActivity">

    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:minHeight="?attr/actionBarSize"
        android:background="#FFCDD2"
        ></android.support.v7.widget.Toolbar>



</RelativeLayout>

这里记得需要使用support.v7中的toolbar,不然然只有 API Level 21 也就是 Android 5.0 以上的版本才能使用。
关于自定义颜色还有一点,toolbar与actionbar还有一点不同,若是actionbar,参照Color Palette图片显示的colorPrimary所定义的位置,若想改变App一栏的底色,则直接在styles.xml文件中设定colorPrimary参数即可。
若是使用toolbar,则此方法不起作用,需要在控件中设置background属性。
在MainActivity中加入toolbar声明:

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

这里写图片描述

(3)ToolBar中的控件
这里写图片描述
通过代码设置ToolBar中的控件

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        toolbar.setLogo(R.mipmap.ic_launcher);
        toolbar.setTitle("My Title");
        toolbar.setSubtitle("Sub Title");
        setSupportActionBar(toolbar);
        toolbar.setNavigationIcon(R.mipmap.ic_launcher);
    }

菜单部分:
menu_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"
        app:showAsAction="always"
        />

    <item android:id="@+id/action_settings" android:title="@string/action_settings"
        android:orderInCategory="100" app:showAsAction="always" />
</menu>

菜单栏的点击回调时间可以通过重写onCreateOptionsMenu和onOptionsItemSelected,也可以通过toolbar.setOnMenuItemClickListener实现点击MenuItem的回调。

@Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            Toast.makeText(this,"Settings",Toast.LENGTH_SHORT).show();
            return true;
        }else if (id == R.id.action_edit){
            Toast.makeText(this,"Edit",Toast.LENGTH_SHORT).show();
            return true;
        }

        return super.onOptionsItemSelected(item);
    }

这里写图片描述

ToolBar直接成了Layout中可以控制的东西,相对于过去的actionbar来说,设计与可操控性大幅提升。

很基础的东西,在博客中记录也是为自己做一个总结。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值