Material Design整理(三)——ToolBar
来源:互联网 发布:域名怎么和空间绑定 编辑:程序博客网 时间:2024/05/18 02:41
github地址 点击打开
简介
应用内容的标准工具栏,可以说是ActionBar的升级版,两者不是独立关系。
- 应用内容的标准工具栏,可以说是ActionBar的升级版,两者不是独立关系。
- 相比ActionBar,ToolBar更加自由,可以随意放置,当一个ViewGroup来使用。
ToolBar提供了可定制、修改的属性:
- 导航栏图标 - AppLogo - 主标题、子标题 - 添加一个或多个自定义控件 - 支持Action Menu 等
使用
1、在res/menu文件夹下,创建menu
设置标题栏右侧条目
<?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/action_search" android:icon="@mipmap/ic_search" android:title="搜索" app:showAsAction="ifRoom" /> <!--右侧添加操作条目--> <item android:id="@+id/action_add" android:icon="@mipmap/ic_add" android:title="添加" app:showAsAction="ifRoom" /> <!--右侧设置条目,收起,不显示--> <item android:id="@+id/action_setting" android:icon="@mipmap/ic_settings" android:title="设置" app:showAsAction="never" /> <!--右侧设置帮助条目,收起,不显示--> <item android:id="@+id/action_help" android:icon="@mipmap/ic_help" android:title="帮助" app:showAsAction="never" /></menu>
其中showAsAction可选参数为:
- always:使菜单项一直显示在ToolBar上
- ifRoom:如果有足够的空间,菜单项显示在ToolBar上,否则显示在更多中
- never:菜单项永远不显示在ToolBar上,只显示在更多中
- withText:图标和文字一起显示
2、在布局中使用ToolBar
<android.support.v7.widget.Toolbar android:id="@+id/toolbar" android:layout_width="match_parent" android:layout_height="?attr/actionBarSize" android:background="?attr/colorPrimary" app:popupTheme="@style/AppTheme.PopupOverlay" />
另外:可以把ToolBar当做普通ViewGroup来使用,所以可以在布局文件中直接将自定义控件放置其中
3、在Activity中
在setContentView方法之前,设置界面没有标题栏:
- 如果Activity继承Activity,设置:
requestWindowFeature(Window.FEATURE_NO_TITLE);
- 如果Activity继承的是AppCompatActivity,则:
supportRequestWindowFeature(Window.FEATURE_NO_TITLE);
附:隐藏导航栏有两种方法:
- 如上在代码中设置
- 在清单文件中给对应Activity设置主题,主题为Theme.AppCompat.Light.NoActionBar
4、将ToolBar作为导航栏
setSupportActionBar(toolbar);
5、可以对ToolBar进行其他设置
//设置App图标toolbar.setLogo(R.mipmap.ic_launcher);//设置导航的图标toolbar.setNavigationIcon(R.mipmap.ic_menu);// 设置主标题toolbar.setTitle("J++");// 设置子标题toolbar.setSubtitle("MaterialDesign");
6、添加菜单项
@Overridepublic boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.menu_toolbar_main, menu); return true;}
此步骤就是将创建的menu文件设置给ToolBar
7、对菜单项添加点击事件
@Overridepublic boolean onOptionsItemSelected(MenuItem item) { switch (item.getItemId()) { case R.id.action_search: Snackbar.make(toolbar, "搜索", Snackbar.LENGTH_LONG).show(); break; case R.id.action_add: Snackbar.make(toolbar, "更多", Snackbar.LENGTH_LONG).show(); break; case R.id.action_setting: Snackbar.make(toolbar, "设置", Snackbar.LENGTH_LONG).show(); break; case R.id.action_help: Snackbar.make(toolbar, "帮助", Snackbar.LENGTH_LONG).show(); break; } return false;}
还有另外一种方式:
setOnMenuItemClickListener(new ToolBar.OnMenuItemClickListener());
8、当然,还有导航图标的点击
toolbar.setNavigationOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { drawer.openDrawer(Gravity.LEFT); }});
阅读全文
0 0
- Material Design整理(三)——ToolBar
- Material Design——Toolbar
- Android 之 Material Design(三)—DrawerLayout+NavigationView+Toolbar(点击icon打开关闭侧滑菜单)
- UI——Material Design设计之Toolbar详解
- Material Design——DrawerLayout+DrawerToggle+Toolbar实现炫酷侧拉动画
- Material Design整理(一)——TextInputLayout
- Material Design整理(二)——SnackBar
- Material Design整理(四)——DrawerLayout
- Material Design整理(五)——NavigationView
- Material Design整理(六)——SearchView及FlexboxLayout
- Material Design整理(七)——Palette调色板
- Material Design整理(八)——TabLayout
- Material Design整理(九)——CollapsingToolbarLayout
- Material Design控件介绍(一)——Toolbar,DrawerLayout,NavigationView
- android material design之Toolbar(一)
- Material Design 之 ToolBar
- 【Material Design】Toolbar使用
- Material Design之Toolbar
- 排序算法C++&&Python实现---基数排序
- Spring框架学习(一)
- 网络营销实战课-微信实操
- 一个DOM操作的题目
- 排序算法练习
- Material Design整理(三)——ToolBar
- 《大道至简》读后感
- 浅解多线程
- 5 树
- Vue实现组件信息的缓存
- 【有图有真相】python3.*“ImportError: No module named ‘MySQLdb'”
- ARM NEON 编程系列8——ARM NEON 优化
- VMware workstation 创建共享盘
- 微信小程序富文本解析