Toolbar是在Android5.0时出现的一个新控件,其目的用于取代Actionbar,它与Actionbar最大的差异就是Toolbar使用更加灵活、自由,并且Toolbar遵循Material Design规范。css
想要使用Toolbar必须引用appcompat-v7库。固然另外一种方法。就是将API改动为21以上,这样的方法的Toolbar不支持API21下面的系统,因此用的很少。java
这里使用appcompat-v7库中的Toolbar,这个库的Toolbar可以兼容5.0下面的系统。
首先在AndroidStudio的build.gradle
文件里加入上这行代码android
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
testCompile 'junit:junit:4.12'
// 加入V7支持库
compile 'com.android.support:appcompat-v7:23.2.1'
}
在styles
文件里改动主题样式,使其继承Theme.AppCompat.Light.NoActionBar
。这个主题样式没有ActionBar。因此咱们一会本身定义一个。markdown
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar"> <!-- 顶部状态栏的颜色 --> <item name="colorPrimaryDark">@color/colorPrimaryDark</item> <!-- actionbar 的颜色 --> <item name="colorPrimary">@color/colorPrimary</item> <!-- actionbar 文字的颜色 --> <item name="android:textColorPrimary">@color/body_text_1</item> <!-- 改动默认颜色和menu文字颜色 --> <item name="android:textColor">@color/body_text_2</item> <!-- 文字选中时的高亮 --> <item name="android:textColorHighlight">@color/colorPrimary</item> <!-- 各类控件的颜色 --> <item name="colorAccent">@color/colorPrimary</item> </style>
OK,以后在layout中建立一个xml布局,在布局中加入例如如下代码。app
ide
<?xml version="1.0" encoding="utf-8"?> <android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:id="@+id/toolbar" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@color/colorPrimary" android:minHeight="56dp" />
Toolbar定义完毕。假设想使用它。仅仅要在其它的xml布局中经过include
标签引入它便可了。布局
在文章的开头说了。Toolbar主要使用于替换Actionbar的,因此Toolbar的使用方法事实上跟Actionbar的使用方法类似,但也有些不同。
假设想要在Activity中使用Toolbar,那么该Activity必须继承AppCompatActivity
,并经过setSupportActionBar()
方法替换掉Actionbar。post
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// 得到Toolbar。替换Actionbar
mToolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(mToolbar);
}
可以经过例如如下代码来加入Toolbar的标题和图标。gradle
mToolbar.setTitle("标题");
mToolbar.setSubtitle("子标题");
mToolbar.setLogo(R.mipmap.ic_launcher);
OK。效果例如如下
ui
Menu配置也与Actionbar类似,首先在menu目录中定义menu配置文件
<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="com.torment.toolbardemo.MainActivity">
<item android:id="@+id/action_settings" android:orderInCategory="100" android:title="@string/str_setting" app:showAsAction="never" />
<item android:id="@+id/action_add" android:icon="@mipmap/ic_search_white" android:orderInCategory="100" android:title="@string/str_add" app:showAsAction="ifRoom" />
<item android:id="@+id/action_delete" android:icon="@mipmap/ic_notifications_white" android:orderInCategory="100" android:title="@string/str_delete" app:showAsAction="ifRoom" />
</menu>
这里需要注意app:showAsAction
这个属性。不能使用android:showAsAction
。这是因为使用Toolbar来自V7包,因此使用android:showAsAction
设置完是无效的。这是一个坑需要注意一下(下面还有好多坑)。
当配置完menu文件以后。仅仅需要在Activity的onCreateOptionsMenu()
中载入这个menu文件便可。
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
假设想要监听menu的话。需要重写onOptionsItemSelected()
方法。
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// 监听指定的button
switch (item.getItemId()) {
case R.id.action_settings:
return true;
case R.id.action_add:
return true;
case R.id.action_delete:
return true;
}
return super.onOptionsItemSelected(item);
}
OK。效果是这样的。
加入向上导航button与直接加入button的方式有些不同。经过getSupportActionBar()的setDisplayHomeAsUpEnabled()
方法设置。
// 开启向上导航button
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
假设想要监听这个button的点击事件。仅仅需要匹配android.R.id.home
便可
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case android.R.id.home:
return true;
}
return super.onOptionsItemSelected(item);
}
OK,效果就是这样,多了一个返回button
给Toolbar加入搜索功能很easy,仅仅需要在menu文件里配置一下便可。
<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_white" android:orderInCategory="100" android:title="@string/str_search" app:actionViewClass="android.support.v7.widget.SearchView" app:showAsAction="ifRoom" />
</menu>
经过app:actionViewClass="android.support.v7.widget.SearchView"
设置搜索视图。而后在代码中处理一下监听便可了。
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_search, menu);
// 得到SearchView
final MenuItem item = menu.findItem(R.id.action_search);
SearchView searchView = (SearchView) MenuItemCompat.getActionView(item);
searchView.setQueryHint("请输入搜索内容");
// 设置弹出键盘类型
searchView.setInputType(InputType.TYPE_CLASS_NUMBER);
searchView.setIconified(true);
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String query) { // 提交时触发
return false;
}
@Override
public boolean onQueryTextChange(String newText) { // 当字符串变化时触发
return false;
}
});
return true;
}
OK,效果例如如下
分享功能与搜素功能类似。经过配置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_share" android:icon="@mipmap/ic_search_white" android:orderInCategory="100" android:title="@string/str_share" app:actionProviderClass="android.support.v7.widget.ShareActionProvider" app:showAsAction="ifRoom" /> </menu>
相同在代码中处理一下分享逻辑便可了。
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_share, menu);
MenuItem item = menu.findItem(R.id.action_share);
mShareActionProvider = (ShareActionProvider) MenuItemCompat.getActionProvider(item);
// 设置分享内容以及类型
mShareActionProvider.setShareIntent(getDefaultIntent());
return true;
}
private Intent getDefaultIntent() {
Intent intent = new Intent(Intent.ACTION_SEND);
intent.putExtra(Intent.EXTRA_TEXT, "測试分享文本");
intent.setType("text/plain");
return intent;
}
OK。效果例如如下
除了这样的分享以外,还有另外一种更简单的分享方式,直接定义一个普通的menu,而后经过startActivity调用系统的分享功能。
<?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_share2" android:icon="@mipmap/ic_search_white" android:orderInCategory="100" android:title="@string/str_share" app:showAsAction="ifRoom" /> </menu>
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.action_share2:
Intent shareIntent = new Intent();
shareIntent.setAction(Intent.ACTION_SEND);
shareIntent.putExtra(Intent.EXTRA_TEXT, "測试分享文本");
shareIntent.setType("text/plain");
// 设置分享列表的标题
startActivity(Intent.createChooser(shareIntent, "分享到"));
return true;
}
return super.onOptionsItemSelected(item);
}
OK。效果例如如下
另一种眼下使用的比較多,写起来也比較简单。
眼下先写这么多,等有时间继续无缺。