Android高階進階ToolBar
我記得之前Android4.0的時候是actionBar,到了Android5.0以後google新出了ToolBar用以彌補ActionBar的不足。今天我們就來講一下 ToolBar的用法。其實現在Android系統的UI設計有些已經超越了IOS...
一、基本用法
1. 我們新建立一個工程;
2. 然後找到values---styles.xml修改其中的AppTheme為Theme.AppCompat.Light.NoActionBar,因為我們要自定義ToolBar並代替ActionBar。styles.xml中的AppTheme如下:
<resources> <!-- Base application theme. --> <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar"> <!-- Customize your theme here. --> <item name="colorPrimary">@color/colorPrimary</item> <item name="colorPrimaryDark">@color/colorPrimaryDark</item> <item name="colorAccent">@color/colorAccent</item> </style> </resources>
3.佈局main.xml:
<LinearLayout 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" xmlns:app="http://schemas.android.com/apk/res-auto" android:orientation="vertical"> <android.support.v7.widget.Toolbar android:id="@+id/toolbar" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="?attr/colorPrimary" app:navigationIcon="@mipmap/gongzhong_fanhui" app:title="ToolBar學習"> </android.support.v7.widget.Toolbar> </LinearLayout>
其中app:title為標題,app:navigationIcon為嚮導圖片,在這裡即返回箭頭。
預設情況下app:title一般靠左對齊的,並且在app:navigationIcon的右邊,稍後在 第(二)節 中研究如何讓title居中。
4. MainActivity.java程式碼
package com.example.administrator.toolbarstudy; import android.graphics.Color; import android.os.Bundle; import android.support.v4.view.MenuItemCompat; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.SearchView; import android.support.v7.widget.SearchView.OnCloseListener; import android.support.v7.widget.SearchView.OnQueryTextListener; import android.support.v7.widget.Toolbar; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.View.OnClickListener; import android.view.View.OnFocusChangeListener; import android.widget.EditText; import android.widget.ImageView; import android.widget.Toast; import java.util.ArrayList; import java.util.List; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); setSupportActionBar(toolbar); //設定NavigationIcon的點選事件監聽,比如返回按鈕。 // app:navigationIcon="@drawable/abc_ic_ab_back_mtrl_am_alpha" toolbar.setNavigationOnClickListener(new OnClickListener() { @Override public void onClick(View v) { finish(); } }); } }
setSupportActionBar(toolbar),用toolbar來替代actionBar,我們之前appTheme是NoActionBar,在這裡用toolbar佔據actionBar的位置。toolbar.setNavigationOnClickListener來實現 “返回鍵”的點選處理,一般就是finish()結束當前頁面,返回上一層頁面。
5. 執行效果:
通過以上步驟我們顯示出了Toolbar,這是一個最基本的Toolbar。
我們從效果圖中也發現了一些問題:
(1)發現文字顏色不搭調,而且也沒有居中。建議文字為白色且居中。
(2)ToolBar佈局比較單調,能不能自定義佈局。
(3)ToolBar上面能不能多放幾個選單,其餘的不重要的選單可以隱藏到右上角的Menu裡,一般用三個點點表示裡面隱藏了選單。
好吧,我們帶著以上問題對它進一步優化。
二、 豐富ToolBar
1. 改變文字顏色,並讓其居中.
(1)改變文字顏色,直接在ToolBar佈局裡設定app:titlteTextColor為白色,佈局程式碼如下:
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?attr/colorPrimary"
app:navigationIcon="@mipmap/gongzhong_fanhui"
app:titleTextColor="@color/colorWhite"
app:title="ToolBar學習">
</android.support.v7.widget.Toolbar>
(2)標題居中,目前沒有找到相應的屬性,不過我們可以在<ToolBar></ToolBar>之間放置一個TextView來實現標題居中,同時去掉原來的app:title屬性。ToolBar佈局程式碼如下:
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?attr/colorPrimary"
app:title=""
app:navigationIcon="@mipmap/gongzhong_fanhui"
>
<TextView
android:textSize="18sp"
android:textColor="@color/colorWhite"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="標題" />
</android.support.v7.widget.Toolbar>
app:title="" 取消預設標題,同時我們通過設定ToolBar中間的TextView的layout_gravity 熟悉為center讓標題居中,當然也可以設定文字的顏色。執行效果如下圖:
疑?好奇怪呀,怎麼預設的標題“ToolBarStudy”還在啊,這次變成了app名字了。勿慌,在MainActivity.java的onCreate中setSupportActionBar(toolbar)程式碼下面新增一行程式碼:getSupportActionBar().setDisplayShowTitleEnabled(false),再次執行就好啦。
2. ToolBar佈局比較單調,能不能自定義佈局
這個在1中已經有了答案,在1中我們通過在<ToolBar></ToolBar>之間添加布局TextView定義了標題欄的樣式。當然,我們也可以新增RelativeLayout、LinearLayout等常用佈局。
3. 豐富Toolbar,多放幾個選單
我們可以通過定義menu資料夾下的main.xml來為Toolbar新增選單,或者直接顯示在Toolbar上又或者隱藏在“...”三個點中。
(1)效果如下圖所示:
(2)menu---main.xml程式碼:
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
tools:context="com.ricky.materialdesign.toolbar.MainActivity"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/action_search"
android:orderInCategory="100"
app:actionViewClass="android.support.v7.widget.SearchView"
app:showAsAction="always"
android:title="查詢"/>
<item
android:id="@+id/action_settings"
android:orderInCategory="100"
app:showAsAction="never"
android:title="設定"/>
<item
android:id="@+id/action_share"
android:orderInCategory="100"
app:showAsAction="always"
android:title="分享"
android:icon="@android:drawable/ic_menu_share"/>
<item
android:id="@+id/action_edit"
android:orderInCategory="100"
app:showAsAction="ifRoom"
android:title="編輯"
android:icon="@android:drawable/ic_menu_edit"/>
</menu>
我們來解釋一下里面的屬性,我們看第一個item中的 app:actionViewClass="android.support.v7.widget.SearchView"表示第一個選單是一個searchView用於搜尋(見上面效果圖)。再下來就是一些公共屬性:
--- app:showAsAction="always" 表示該選單項總顯示在Toolbar表面; 如果="ifRoom"意味著如果Toolbar上還有空間那麼就把該選單項放在ToolBar表面,否則會隱藏到三個點點中。
--- android:title="分享" 表示該選單項的 “含義提示”,比如長按“分享”圖示,會提示“分享“文字。
--- android:icon="@android:drawable/ic_menu_share" 表示該選單項的圖示,例如“分享”圖示。
--- android:orderInCategory="100" 表示選單顯示的位置優先順序,例如您嘗試把“分享”選單的這個屬性改為50,那麼分享選單的顯示會排在 “搜尋”的前面,執行試試看吧。
(3)在程式碼中將menu選單項顯示出來,並定義選單項的點選事件,程式碼如下:
package com.example.administrator.toolbarstudy;
import android.graphics.Color;
import android.os.Bundle;
import android.support.v4.view.MenuItemCompat;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.SearchView;
import android.support.v7.widget.SearchView.OnCloseListener;
import android.support.v7.widget.SearchView.OnQueryTextListener;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnFocusChangeListener;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
//設定NavigationIcon的點選事件監聽,比如返回按鈕。
// app:navigationIcon="@drawable/abc_ic_ab_back_mtrl_am_alpha"
getSupportActionBar().setDisplayShowTitleEnabled(false);
toolbar.setNavigationOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
finish();
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.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();
if (id == R.id.action_settings) {
Toast.makeText(MainActivity.this,"您點選了設定",Toast.LENGTH_SHORT).show();
return true;
}
else if(id == R.id.action_share)
{
Toast.makeText(MainActivity.this,"您點選了分享",Toast.LENGTH_SHORT).show();
return true;
}
return super.onOptionsItemSelected(item);
}
}
好了,至此ToolBar的基本用法與選單項的新增就講到這裡,可能您還想知道 searchview“搜尋”圖示與輸入的搜尋文字的顏色能否自定義?敬請期待下一篇,我們專門來研究searchView的用法。
最後,本文示例原始碼下載:https://download.csdn.net/download/gaoxiaoweiandy/10770965