Material Design----全新的界面设计语言(一)

谷歌从Android 5.0系统开始,就将所有内置应用都使用Material Design风格来进行设计。本文主要记录学习的ToolBar这个控件。
ToolBar,继承了ActionBar的所有功能,灵活性很高。
首先设置项目的主题不要ActionBar

 <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>

接着写activity_main.xml

<FrameLayout 
        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.support.v7.widget.Toolbar 
         android:id="@+id/toolbar"
         android:layout_width="match_parent"  
         android:layout_height="?attr/actionBarSize"
         android:background="?attr/colorPrimary"
         android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
         app:popupTheme="@style/ThemeOverlay.AppCompat.Light" >
       </android.support.v7.widget.Toolbar>
 </FrameLayout>

注意:加入xmlns:app=http://schemas.android.com/apk/res-auto是由于Material Design是Android5.0系统中才出现的,为了兼容低版本,不使用android:attribute,而使用app:attribute
为了把ToobBar的主题和主题色系分开,设置ToolBar的主题android:theme,为了使得菜单弹出框的主题美观,此处设置app:popupTheme属性
在MainActivity.class中使用:

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

此时看到的效果图为:
这里写图片描述
在res->menu文件夹->New ->Menu resource file创建toolbar.xml

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
      xmlns:app="http://schemas.android.com/apk/res-auto"
     >
    <item android:id="@+id/backup"
          android:title="backup"
          android:icon="@mipmap/sel_button"
          app:showAsAction="always"
          />
    <item android:id="@+id/delete"
          android:title="delete"
          android:icon="@mipmap/trash_button_click"
          app:showAsAction="ifRoom"
    />
    <item android:id="@+id/settings"
          android:title="settings"
          android:icon="@mipmap/ic_launcher"
          app:showAsAction="never"
    />

</menu>

在MainActivity.class中添加代码如下:

 @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.toolbar,menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()){
            case R.id.backup:
                Toast.makeText(MainActivity.this,"You clicked backup",Toast.LENGTH_LONG).show();
                break;
            case R.id.delete:
                Toast.makeText(MainActivity.this,"You clicked delete",Toast.LENGTH_LONG).show();
                break;
            case R.id.settings:
                Toast.makeText(MainActivity.this,"You clicked settings",Toast.LENGTH_LONG).show();
                break;
        }
        return true

;
    }

效果图为:
这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值