AndroidUI ToolBar
2015-09-28 16:41
573 查看
ToolBar是android L引入的新控件,相当于更为灵活版的actionbar,官方提供了supprot library用于向下兼容。Toolbar更像是一般的View元素,可以被放置在view树体系的任意位置,可以应用动画,可以跟着scrollView滚动,可以与布局中的其他view交互。
ToolBar的使用
首先要了解一下Color Palette,以便于自定义我们自己个性的App。
下面正式介绍如何使用ToolBar
(1)隐藏原本的actionbar
有两种方法,一是修改我们继承的主题为Theme.AppCompat.Light.NoActionBar,或者在自定义AppTheme时:
(2)在布局文件中声明toolbar控件
这里记得需要使用support.v7中的toolbar,不然然只有 API Level 21 也就是 Android 5.0 以上的版本才能使用。
关于自定义颜色还有一点,toolbar与actionbar还有一点不同,若是actionbar,参照Color Palette图片显示的colorPrimary所定义的位置,若想改变App一栏的底色,则直接在styles.xml文件中设定colorPrimary参数即可。
若是使用toolbar,则此方法不起作用,需要在控件中设置background属性。
在MainActivity中加入toolbar声明:
(3)ToolBar中的控件
通过代码设置ToolBar中的控件
菜单部分:
menu_main.xml
菜单栏的点击回调时间可以通过重写onCreateOptionsMenu和onOptionsItemSelected,也可以通过toolbar.setOnMenuItemClickListener实现点击MenuItem的回调。
ToolBar直接成了Layout中可以控制的东西,相对于过去的actionbar来说,设计与可操控性大幅提升。
很基础的东西,在博客中记录也是为自己做一个总结。
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来说,设计与可操控性大幅提升。
很基础的东西,在博客中记录也是为自己做一个总结。
相关文章推荐
- 树状数组+二分||线段树 HDOJ 5493 Queue
- iOS开发UI篇—常见的项目文件介绍
- UVA - 11235 Frequent values 频繁出现的数值 RMQ+游程编码
- SpriteBuilder中的CCSprite9Slice是个什么鬼?
- SpriteBuilder中的CCSprite9Slice是个什么鬼?
- SpriteBuilder中的CCSprite9Slice是个什么鬼?
- getRequestDispatcher 和sendRedirect区别
- iOS-UICollectionView自定义布局
- android AlertDialog.Builder(Context context)换行
- iOS绘图系统UIKit与Core Graphics
- iOS绘图系统UIKit与Core Graphics
- 蓝牙服务 UUID
- 处理【Fatal error: Can't use function return value in write context 】的情况之《empty的解析》
- 在非Activity(非主线程)中更新UI的办法:(二)Handler+接口回调
- uCGUI学习笔记之显示文本
- 给UITextView增加链接
- 并发队列ConcurrentLinkedQueue和阻塞队列LinkedBlockingQueue用法
- 25-id to load is required for loading
- Android UI适配研究
- android中build过程