您的位置:首页 > 产品设计 > UI/UE

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时:

<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来说,设计与可操控性大幅提升。

很基础的东西,在博客中记录也是为自己做一个总结。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: