Android DrawerLayout帶有側(cè)滑功能的布局類(2)
ActionBarDrawerToggle:
在前一張中我們并沒有使用drawLayout.setDrawerListener();
對(duì)應(yīng)的參數(shù)對(duì)象就是DrawerLayout.DrawerListener:
public interface DrawerListener { void onDrawerSlide(View var1, float var2); void onDrawerOpened(View var1); void onDrawerClosed(View var1); void onDrawerStateChanged(int var1); }
本文講一下drawLayout.setDrawerListener(toggle);方式,ActionBarDrawerToggle 就是實(shí)現(xiàn)了這個(gè)接口。他主要作用在于。
•改變ActionBar上的返回按鈕圖片(android.R.id.home)
•在打開和關(guān)閉Drawer的時(shí)候,ActionBar的返回圖標(biāo)會(huì)有動(dòng)畫效果。
•監(jiān)聽側(cè)邊欄的打開和收起
在點(diǎn)擊側(cè)邊菜單選項(xiàng)的時(shí)候我們往往需要隱藏菜單來顯示整個(gè)菜單對(duì)應(yīng)的內(nèi)容。ActionBarDrawerToggle就是其中一種方法。
你也可以不用ActionBarDrawerToggle直接用import android.support.v4.widget.DrawerLayout.DrawerListener;
然后DrawerLayout相關(guān)在上一個(gè)文章中已經(jīng)介紹了就不一一說明了。就從DrawerLayout的監(jiān)聽開始。
我們今天用的包如下:
import android.support.v4.app.ActionBarDrawerToggle;
首先我們初始化一個(gè)ActionBarDrawerToggle :
toggle = new ActionBarDrawerToggle( this, /* host Activity */ mDrawerLayout, /* DrawerLayout object */ R.drawable.ic_drawer, /* nav drawer image to replace 'Up' caret */ R.string.drawer_open, /* "open drawer" description for accessibility */ R.string.drawer_close /* "close drawer" description for accessibility */ ) { public void onDrawerClosed(View view) { getActionBar().setTitle(mTitle); invalidateOptionsMenu(); // creates call to onPrepareOptionsMenu() } public void onDrawerOpened(View drawerView) { getActionBar().setTitle(mDrawerTitle); invalidateOptionsMenu(); // creates call to onPrepareOptionsMenu() } };
初始化相關(guān)比較簡單看注釋就行。在監(jiān)聽的回調(diào)方法中我們用invalidateOptionsMenu通知activity重繪menu,然后activity就有機(jī)會(huì)在onPrepareOptionsMenu方法中更新menu元素的顯示與隱藏。
接下來需要設(shè)置一下ActionBar:
private void initActionBar() { // enable ActionBar app icon to behave as action to toggle nav drawer ActionBar actionBar = getActionBar(); actionBar.setDisplayHomeAsUpEnabled(true); actionBar.setHomeButtonEnabled(true); }
不難看出是顯示菜單鍵以及設(shè)置為可點(diǎn)擊使用的菜單鍵。
ActionBar相關(guān)設(shè)置:
•setHomeButtonEnabled //這個(gè)小于4.0版本的默認(rèn)值為true的。但是在4.0及其以上是false,該方法的作用:決定左上角的圖標(biāo)是否可以點(diǎn)擊。沒有向左的小圖標(biāo)。 true 圖標(biāo)可以點(diǎn)擊 false 不可以點(diǎn)擊。
•actionBar.setDisplayHomeAsUpEnabled(true) // 給左上角圖標(biāo)的左邊加上一個(gè)返回的圖標(biāo) 。對(duì)應(yīng)ActionBar.DISPLAY_HOME_AS_UP
•actionBar.setDisplayShowCustomEnabled(true) // 使自定義的普通View能在title欄顯示,即actionBar.setCustomView能起作用,對(duì)應(yīng)ActionBar.DISPLAY_SHOW_CUSTOM
•actionBar.setDisplayShowTitleEnabled(true) //對(duì)應(yīng)ActionBar.DISPLAY_SHOW_TITLE。
然后我們需要綁定此監(jiān)聽器:
mDrawerLayout.setDrawerListener(toggle);
之后我們需實(shí)現(xiàn)Acitivity的一下代碼才能使用:
@Override protected void onPostCreate(Bundle savedInstanceState) { super.onPostCreate(savedInstanceState); // Sync the toggle state after onRestoreInstanceState has occurred. toggle.syncState(); } @Override public void onConfigurationChanged(Configuration newConfig) { super.onConfigurationChanged(newConfig); // Pass any configuration change to the drawer toggls toggle.onConfigurationChanged(newConfig); } @Override public boolean onOptionsIwotemSelected(MenuItem item) { // The action bar home/up action should open or close the drawer. // ActionBarDrawerToggle will take care of this. if (toggle.onOptionsItemSelected(item)) { return true; } return super.onOptionsItemSelected(item); }
在這里如果不去實(shí)現(xiàn)onOptionsIwotemSelected中的代碼那么點(diǎn)擊菜單是沒有效果的。
現(xiàn)在運(yùn)行代碼后可以看出如下效果:
在android.support.v7.app.ActionBarDrawerToggle;中的ActionBarDrawerToggle第三個(gè)參數(shù)
即:R.drawable.ic_drawer, /* nav drawer image to replace 'Up' caret */
更換為Toolbar對(duì)象,這樣一來你可以自定一個(gè)Toolbar做更為漂亮UI。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android實(shí)現(xiàn)右邊抽屜Drawerlayout效果
- Android使用DrawerLayout實(shí)現(xiàn)仿QQ雙向側(cè)滑菜單
- Android App中DrawerLayout抽屜效果的菜單編寫實(shí)例
- Android組件之DrawerLayout實(shí)現(xiàn)抽屜菜單
- Android Drawerlayout側(cè)拉欄事件傳遞問題的解決方法
- Android DrawerLayout帶有側(cè)滑功能的布局類(1)
- Android中DrawerLayout+ViewPager滑動(dòng)沖突的解決方法
- Android DrawerLayout實(shí)現(xiàn)側(cè)拉菜單功能
- Android組件DrawerLayout仿網(wǎng)易新聞v4.4側(cè)滑菜單
- android側(cè)滑菜單控件DrawerLayout使用方法詳解
相關(guān)文章
Android跟隨手指移動(dòng)的控件demo實(shí)例
大家好,本篇文章主要講的是Android跟隨手指移動(dòng)的控件demo實(shí)例,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12探究Android中ListView復(fù)用導(dǎo)致布局錯(cuò)亂的解決方案
這篇文章主要介紹了探究Android中ListView復(fù)用導(dǎo)致布局錯(cuò)亂的解決方案,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-10-10如何判斷軟件程序是否聯(lián)網(wǎng) 聯(lián)網(wǎng)狀態(tài)提示信息Android實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了如何判斷軟件程序是否聯(lián)網(wǎng)的實(shí)現(xiàn)代碼,Android實(shí)現(xiàn)聯(lián)網(wǎng)狀態(tài)信息提示,感興趣的小伙伴們可以參考一下2016-05-05Android后臺(tái)模擬點(diǎn)擊探索(附源碼)
這篇文章主要介紹了Android后臺(tái)模擬點(diǎn)擊探索(附源碼),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-01-01Android利用Sensor實(shí)現(xiàn)傳感器功能
這篇文章主要為大家詳細(xì)介紹了Android利用Sensor實(shí)現(xiàn)傳感器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11android全屏去掉title欄的多種實(shí)現(xiàn)方法
android全屏去掉title欄包括以下幾個(gè)部分:實(shí)現(xiàn)應(yīng)用中的所有activity都全屏/實(shí)現(xiàn)單個(gè)activity全屏/實(shí)現(xiàn)單個(gè)activity去掉title欄/自定義標(biāo)題內(nèi)容/自定義標(biāo)題布局等等感興趣的可參考下啊2013-02-02Android listview的滑動(dòng)沖突解決方法
這篇文章主要介紹了Android listview的滑動(dòng)沖突解決方法的相關(guān)資料,需要的朋友可以參考下2017-02-02