Android ToolBar控件詳解及實例
ToolBar控件詳解
在Activity中添加ToolBar
1.添加庫
dependencies { ... compile "com.android.support:appcompat-v7:18.0.+" }
2.Activity要繼承AppCompatActivity
3.設置主題
使用ToolBar,要將系統(tǒng)默認的ActionBar隱藏掉
<application android:theme="@style/Theme.AppCompat.Light.NoActionBar" />
4.在XML添加ToolBar布局
<android.support.v7.widget.Toolbar android:id="@+id/my_toolbar" android:layout_width="match_parent" android:layout_height="?attr/actionBarSize" android:background="?attr/colorPrimary" android:elevation="4dp" android:theme="@style/ThemeOverlay.AppCompat.ActionBar" app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>
Material Design specification 建議設置 elevation 為 4dp
Toolbar放在Activity的頂部(等于廢話)
5.設置ToolBar
在Activity的onCreate()方法中,調(diào)用setSupportActionBar()方法,把我們的ToolBar對象傳遞進去,將我們xml中添加的ToolBar設置為我們這個Activity頁面的App Bar。
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_my); Toolbar myToolbar = (Toolbar) findViewById(R.id.my_toolbar); setSupportActionBar(myToolbar); }
現(xiàn)在,我們的頁面中,應該就會有一個App Bar了,默認情況下,這個App Bar只會顯示一個App的名字和一個帶有下拉選項的按鈕,也可以在App Bar上添加更多的選項按鈕
添加并處理一個Action
ToolBar允許在上面添加操作按鈕,但是因為ToolBar上空間是有限的,如果一個程序有太多的Action,那么可以將Action添加到下拉菜單中,而不顯示在ToolBar上
添加一個Action按鈕
可以在XML文件中定義所有我們想添加的操作按鈕和下拉列表中的行為,如果想要添加Action,可以在 res/目錄下創(chuàng)建一個新的XML文件,添加元素。例如這樣
<menu xmlns:android="http://schemas.android.com/apk/res/android" > <!-- "Mark Favorite", should appear as action button if possible --> <item android:id="@+id/action_favorite" android:icon="@drawable/ic_favorite_black_48dp" android:title="@string/action_favorite" app:showAsAction="ifRoom"/> <!-- Settings, should always be in the overflow --> <item android:id="@+id/action_settings" android:title="@string/action_settings" app:showAsAction="never"/> </menu>
App:showAsAction 屬性是用來設置Action顯示在哪,如果我們設置 app:showAsAction =”ifRoom”(示例中最常用的一種方式) ,這個Action將顯示在ToolBar上,如果ToolBar上沒有足夠的控件,則顯示在下拉菜單中。如果在程序中設置為 app:showAsAction=”never”,那么這個Action將永遠顯示在下拉列表中,而不會顯示在ToolBar上。
響應操作(回調(diào))
當用戶選擇了一個Action后,系統(tǒng)會回調(diào) onOptionsItemSelected() 方法并傳遞 MenuItem 對象,在 onOptionsItemSelected() 的實現(xiàn)中,調(diào)用 MenuItem.getItemId() 方法來確定按下了哪個項目。返回的 ID 與您在相應的 元素 Android: id 屬性中聲明的值匹配。
例如下面
@Override public boolean onOptionsItemSelected(MenuItem item) { switch (item.getItemId()) { case R.id.action_settings: // User chose the "Settings" item, show the app settings UI... return true; case R.id.action_favorite: // User chose the "Favorite" action, mark the current item // as a favorite... return true; default: // If we got here, the user's action was not recognized. // Invoke the superclass to handle it. return super.onOptionsItemSelected(item); } }
添加一個回到主界面的按鈕
應用為了使用戶可以方便的回到主界面,ToolBar可以添加一個按鈕,直接返回到指定的主界面。
聲明主界面(父界面)
需要在清單文件中通過設置 android: parentActivityName 屬性聲明,如果要支持舊版本的Android設備,需要定義 ,類似這樣:
<application ... > ... <!-- The main/home activity (it has no parent activity) --> <activity android:name="com.example.myfirstapp.MainActivity" ...> ... </activity> <!-- A child of the main activity --> <activity android:name="com.example.myfirstapp.MyChildActivity" android:label="@string/title_activity_child" android:parentActivityName="com.example.myfirstapp.MainActivity" > <!-- Parent activity meta-data to support 4.0 and lower --> <meta-data android:name="android.support.PARENT_ACTIVITY" android:value="com.example.myfirstapp.MainActivity" /> </activity> </application>
使用返回按鈕
若要使用返回的按鈕,需要調(diào)用setDisplayHomeAsUpEnabled()方法,類似這樣:
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_my_child); // my_child_toolbar is defined in the layout file Toolbar myChildToolbar = (Toolbar) findViewById(R.id.my_child_toolbar); setSupportActionBar(myChildToolbar); // Get a support ActionBar corresponding to this toolbar ActionBar ab = getSupportActionBar(); // Enable the Up button ab.setDisplayHomeAsUpEnabled(true); }
添加Action Views
和上面 添加并處理一個Action 類似,只不過設置 showAsAction 為 “ifRoom|collapseActionView” 或者 “never|collapseActionView” 就可以了,類似這樣
<item android:id="@+id/action_search" android:title="@string/action_search" android:icon="@drawable/ic_search" app:showAsAction="ifRoom|collapseActionView" app:actionViewClass="android.support.v7.widget.SearchView" />
這里我們添加的是一個帶有搜索功能的Search按鈕,如果我們要自定義一個自己的按鈕,不添加 actionViewClass 即可
如果想要配置這個Action,可以在 onCreateOptionsMenu() 的回調(diào)里通過 getActionView() 獲取到Search對象,類似這樣:
@Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.main_activity_actions, menu); MenuItem searchItem = menu.findItem(R.id.action_search); SearchView searchView = (SearchView) MenuItemCompat.getActionView(searchItem); // Configure the search info and add any event listeners... return super.onCreateOptionsMenu(menu);6 }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
Android編程實現(xiàn)應用自動更新、下載、安裝的方法
這篇文章主要介紹了Android編程實現(xiàn)應用自動更新、下載、安裝的方法,涉及Android針對應用程序包的讀取,屬性判斷與更新操作的相關技巧,需要的朋友可以參考下2016-02-02Android開發(fā)之獲取SD卡及手機ROM容量的方法
這篇文章主要介紹了Android開發(fā)之獲取SD卡及手機ROM容量的方法,結(jié)合實例形式分析了Android針對SD卡的讀取及屬性操作相關技巧,需要的朋友可以參考下2016-04-04Android UI設計系列之ImageView實現(xiàn)ProgressBar旋轉(zhuǎn)效果(1)
這篇文章主要為大家詳細介紹了Android UI設計之ImageView實現(xiàn)ProgressBar旋轉(zhuǎn)效果,具有一定的實用性和參考價值,感興趣的小伙伴們可以參考一下2016-06-06Android ViewPager實現(xiàn)動畫切換效果
這篇文章主要為大家詳細介紹了Android ViewPager實現(xiàn)動畫切換效果的相關資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01Android高級界面組件之拖動條和評星條的功能實現(xiàn)
這篇文章主要介紹了Android高級界面組件之拖動條和評星條的實現(xiàn)實例,需要的的朋友參考下2017-03-03Android?studio實現(xiàn)日期?、時間選擇器與進度條
這篇文章主要為大家詳細介紹了Android?studio實現(xiàn)日期、時間選擇器與進度條,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01android自定義控件和自定義回調(diào)函數(shù)步驟示例
這篇文章主要介紹了android自定義控件步驟示例,包括為View類增加屬性、響應用戶消息、自定義回調(diào)函數(shù)等方法2014-01-01