[置顶] AndroidUI ToolBar

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

  1. ToolBar的使用
    首先要了解一下Color Palette,以便于自定义我们自己个性的App。
    [置顶] AndroidUI ToolBar_第1张图片

    下面正式介绍如何使用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中的控件
[置顶] AndroidUI ToolBar_第2张图片
通过代码设置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来说,设计与可操控性大幅提升。

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

你可能感兴趣的:(android)