ToolBar是android L引入的新控件,相当于更为灵活版的actionbar,官方提供了supprot library用于向下兼容。Toolbar更像是一般的View元素,可以被放置在view树体系的任意位置,可以应用动画,可以跟着scrollView滚动,可以与布局中的其他view交互。
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来说,设计与可操控性大幅提升。
很基础的东西,在博客中记录也是为自己做一个总结。