Android高级UI开发(十三)之ToolBar基本用法

举报
yd_57386892 发表于 2020/12/29 00:19:39 2020/12/29
【摘要】 我记得之前Android4.0的时候是actionBar,到了Android5.0以后google新出了ToolBar用以弥补ActionBar的不足。今天我们就来讲一下 ToolBar的用法。其实现在Android系统的UI设计有些已经超越了IOS... 一、基本用法 1. 我们新建立一个工程; 2. 然后找到values---styles.xml修改其中的AppTh...

我记得之前Android4.0的时候是actionBar,到了Android5.0以后google新出了ToolBar用以弥补ActionBar的不足。今天我们就来讲一下 ToolBar的用法。其实现在Android系统的UI设计有些已经超越了IOS...

一、基本用法

1. 我们新建立一个工程;

2. 然后找到values---styles.xml修改其中的AppTheme为Theme.AppCompat.Light.NoActionBar,因为我们要自定义ToolBar并代替ActionBar。styles.xml中的AppTheme如下:


  
  1. <resources>
  2. <!-- Base application theme. -->
  3. <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
  4. <!-- Customize your theme here. -->
  5. <item name="colorPrimary">@color/colorPrimary</item>
  6. <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
  7. <item name="colorAccent">@color/colorAccent</item>
  8. </style>
  9. </resources>

3.布局main.xml:


  
  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. xmlns:app="http://schemas.android.com/apk/res-auto"
  6. android:orientation="vertical">
  7. <android.support.v7.widget.Toolbar
  8. android:id="@+id/toolbar"
  9. android:layout_width="match_parent"
  10. android:layout_height="wrap_content"
  11. android:background="?attr/colorPrimary"
  12. app:navigationIcon="@mipmap/gongzhong_fanhui"
  13. app:title="ToolBar学习">
  14. </android.support.v7.widget.Toolbar>
  15. </LinearLayout>

其中app:title为标题,app:navigationIcon为向导图片,在这里即返回箭头。

默认情况下app:title一般靠左对齐的,并且在app:navigationIcon的右边,稍后在 第(二)节 中研究如何让title居中。

4. MainActivity.java代码


  
  1. package com.example.administrator.toolbarstudy;
  2. import android.graphics.Color;
  3. import android.os.Bundle;
  4. import android.support.v4.view.MenuItemCompat;
  5. import android.support.v7.app.AppCompatActivity;
  6. import android.support.v7.widget.SearchView;
  7. import android.support.v7.widget.SearchView.OnCloseListener;
  8. import android.support.v7.widget.SearchView.OnQueryTextListener;
  9. import android.support.v7.widget.Toolbar;
  10. import android.view.Menu;
  11. import android.view.MenuItem;
  12. import android.view.View;
  13. import android.view.View.OnClickListener;
  14. import android.view.View.OnFocusChangeListener;
  15. import android.widget.EditText;
  16. import android.widget.ImageView;
  17. import android.widget.Toast;
  18. import java.util.ArrayList;
  19. import java.util.List;
  20. public class MainActivity extends AppCompatActivity {
  21. @Override
  22. protected void onCreate(Bundle savedInstanceState) {
  23. super.onCreate(savedInstanceState);
  24. setContentView(R.layout.activity_main);
  25. Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
  26. setSupportActionBar(toolbar);
  27. //设置NavigationIcon的点击事件监听,比如返回按钮。
  28. // app:navigationIcon="@drawable/abc_ic_ab_back_mtrl_am_alpha"
  29. toolbar.setNavigationOnClickListener(new OnClickListener() {
  30. @Override
  31. public void onClick(View v) {
  32. finish();
  33. }
  34. });
  35. }
  36. }

setSupportActionBar(toolbar),用toolbar来替代actionBar,我们之前appTheme是NoActionBar,在这里用toolbar占据actionBar的位置。toolbar.setNavigationOnClickListener来实现 “返回键”的点击处理,一般就是finish()结束当前页面,返回上一层页面。

5. 运行效果:

通过以上步骤我们显示出了Toolbar,这是一个最基本的Toolbar。

我们从效果图中也发现了一些问题:

(1)发现文字颜色不搭调,而且也没有居中。建议文字为白色且居中。

(2)ToolBar布局比较单调,能不能自定义布局。

(3)ToolBar上面能不能多放几个菜单,其余的不重要的菜单可以隐藏到右上角的Menu里,一般用三个点点表示里面隐藏了菜单。

好吧,我们带着以上问题对它进一步优化。

二、 丰富ToolBar

1. 改变文字颜色,并让其居中.

(1)改变文字颜色,直接在ToolBar布局里设置app:titlteTextColor为白色,布局代码如下:


  
  1. <android.support.v7.widget.Toolbar
  2. android:id="@+id/toolbar"
  3. android:layout_width="match_parent"
  4. android:layout_height="wrap_content"
  5. android:background="?attr/colorPrimary"
  6. app:navigationIcon="@mipmap/gongzhong_fanhui"
  7. app:titleTextColor="@color/colorWhite"
  8. app:title="ToolBar学习">
  9. </android.support.v7.widget.Toolbar>

(2)标题居中,目前没有找到相应的属性,不过我们可以在<ToolBar></ToolBar>之间放置一个TextView来实现标题居中,同时去掉原来的app:title属性。ToolBar布局代码如下:


  
  1. <android.support.v7.widget.Toolbar
  2. android:id="@+id/toolbar"
  3. android:layout_width="match_parent"
  4. android:layout_height="wrap_content"
  5. android:background="?attr/colorPrimary"
  6. app:title=""
  7. app:navigationIcon="@mipmap/gongzhong_fanhui"
  8. >
  9. <TextView
  10. android:textSize="18sp"
  11. android:textColor="@color/colorWhite"
  12. android:layout_width="wrap_content"
  13. android:layout_height="wrap_content"
  14. android:layout_gravity="center"
  15. android:text="标题" />
  16. </android.support.v7.widget.Toolbar>

 app:title="" 取消默认标题,同时我们通过设置ToolBar中间的TextView的layout_gravity 属性为center让标题居中,当然也可以设置文字的颜色。运行效果如下图:

疑?好奇怪呀,怎么默认的标题“ToolBarStudy”还在啊,这次变成了app名字了。勿慌,在MainActivity.java的onCreate中setSupportActionBar(toolbar)代码下面添加一行代码:getSupportActionBar().setDisplayShowTitleEnabled(false),再次运行就好啦。

2.  ToolBar布局比较单调,能不能自定义布局

         这个在1中已经有了答案,在1中我们通过在<ToolBar></ToolBar>之间添加布局TextView定义了标题栏的样式。当然,我们也可以添加RelativeLayout、LinearLayout等常用布局。

3. 丰富Toolbar,多放几个菜单

我们可以通过定义menu文件夹下的main.xml来为Toolbar添加菜单,或者直接显示在Toolbar上又或者隐藏在“...”三个点中。

(1)效果如下图所示:

(2)menu---main.xml代码:


  
  1. <menu xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. tools:context="com.ricky.materialdesign.toolbar.MainActivity"
  4. xmlns:app="http://schemas.android.com/apk/res-auto">
  5. <item
  6. android:id="@+id/action_search"
  7. android:orderInCategory="100"
  8. app:actionViewClass="android.support.v7.widget.SearchView"
  9. app:showAsAction="always"
  10. android:title="查找"/>
  11. <item
  12. android:id="@+id/action_settings"
  13. android:orderInCategory="100"
  14. app:showAsAction="never"
  15. android:title="设置"/>
  16. <item
  17. android:id="@+id/action_share"
  18. android:orderInCategory="100"
  19. app:showAsAction="always"
  20. android:title="分享"
  21. android:icon="@android:drawable/ic_menu_share"/>
  22. <item
  23. android:id="@+id/action_edit"
  24. android:orderInCategory="100"
  25. app:showAsAction="ifRoom"
  26. android:title="编辑"
  27. android:icon="@android:drawable/ic_menu_edit"/>
  28. </menu>

我们来解释一下里面的属性,我们看第一个item中的 app:actionViewClass="android.support.v7.widget.SearchView"表示第一个菜单是一个searchView用于搜索(见上面效果图)。再下来就是一些公共属性:

 --- app:showAsAction="always"  表示该菜单项总显示在Toolbar表面; 如果="ifRoom"意味着如果Toolbar上还有空间那么就把该菜单项放在ToolBar表面,否则会隐藏到三个点点中。
 ---  android:title="分享"      表示该菜单项的 “含义提示”,比如长按“分享”图标,会提示“分享“文本。

 ---  android:icon="@android:drawable/ic_menu_share" 表示该菜单项的图标,例如“分享”图标。

---  android:orderInCategory="100" 表示菜单显示的位置优先级,例如您尝试把“分享”菜单的这个属性改为50,那么分享菜单的显示会排在 “搜索”的前面,运行试试看吧。

(3)在代码中将menu菜单项显示出来,并定义菜单项的点击事件,代码如下:

 


  
  1. package com.example.administrator.toolbarstudy;
  2. import android.graphics.Color;
  3. import android.os.Bundle;
  4. import android.support.v4.view.MenuItemCompat;
  5. import android.support.v7.app.AppCompatActivity;
  6. import android.support.v7.widget.SearchView;
  7. import android.support.v7.widget.SearchView.OnCloseListener;
  8. import android.support.v7.widget.SearchView.OnQueryTextListener;
  9. import android.support.v7.widget.Toolbar;
  10. import android.view.Menu;
  11. import android.view.MenuItem;
  12. import android.view.View;
  13. import android.view.View.OnClickListener;
  14. import android.view.View.OnFocusChangeListener;
  15. import android.widget.EditText;
  16. import android.widget.ImageView;
  17. import android.widget.Toast;
  18. import java.util.ArrayList;
  19. import java.util.List;
  20. public class MainActivity extends AppCompatActivity {
  21. @Override
  22. protected void onCreate(Bundle savedInstanceState) {
  23. super.onCreate(savedInstanceState);
  24. setContentView(R.layout.activity_main);
  25. Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
  26. setSupportActionBar(toolbar);
  27. //设置NavigationIcon的点击事件监听,比如返回按钮。
  28. // app:navigationIcon="@drawable/abc_ic_ab_back_mtrl_am_alpha"
  29. getSupportActionBar().setDisplayShowTitleEnabled(false);
  30. toolbar.setNavigationOnClickListener(new OnClickListener() {
  31. @Override
  32. public void onClick(View v) {
  33. finish();
  34. }
  35. });
  36. }
  37. @Override
  38. public boolean onCreateOptionsMenu(Menu menu) {
  39. getMenuInflater().inflate(R.menu.main, menu);
  40. return true;
  41. }
  42. @Override
  43. public boolean onOptionsItemSelected(MenuItem item) {
  44. // Handle action bar item clicks here. The action bar will
  45. // automatically handle clicks on the Home/Up button, so long
  46. // as you specify a parent activity in AndroidManifest.xml.
  47. int id = item.getItemId();
  48. if (id == R.id.action_settings) {
  49. Toast.makeText(MainActivity.this,"您点击了设置",Toast.LENGTH_SHORT).show();
  50. return true;
  51. }
  52. else if(id == R.id.action_share)
  53. {
  54. Toast.makeText(MainActivity.this,"您点击了分享",Toast.LENGTH_SHORT).show();
  55. return true;
  56. }
  57. return super.onOptionsItemSelected(item);
  58. }
  59. }

好了,至此ToolBar的基本用法与菜单项的添加就讲到这里,可能您还想知道 SearchView“搜索”图标与输入的搜索文本的颜色能否自定义?敬请期待下一篇,我们专门来研究SearchView的用法。

最后,本文示例源码下载:https://download.csdn.net/download/gaoxiaoweiandy/10770965

 

 

 

文章来源: blog.csdn.net,作者:冉航--小虾米,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/gaoxiaoweiandy/article/details/83752594

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。