標籤:android style blog http io ar os 使用 sp
ActionBarDrawerToggle是一個開關,用於開啟/關閉DrawerLayout抽屜
ActionBarDrawerToggle 提供了一個方便的方式來配合DrawerLayout和ActionBar,以實現推薦的抽屜功能。即點擊ActionBar的home按鈕,即可彈出DrawerLayout抽屜。
在Activity中的兩個回呼函數中使用它:
onConfigurationChanged
onOptionsItemSelected
調用ActionBarDrawerToggle.syncState() 在Activity的onPostCreate()中;指示,ActionBarDrawerToggle與DrawerLayout的狀態同步
關於DrawerLayout就不多說了,請移步這裡 http://blog.csdn.net/jjwwmlp456/article/details/38682637
整體的效果呢,需要支援ActionBar,support-v7包的 compat中有 ActionBarActivity可繼承, 3.0以後也可以用主題的方式直接使用。不多說了
幾個主要的函數調用
ActionBarDrawerToggle mDrawerToggle;DrawerLayout mDrawerLayout;void init() {mDrawerLayout.setDrawerListener(new MyDrawerListener());//設定drawer的開關監聽mDrawerToggle = new ActionBarDrawerToggle(activity, mDrawerLayout, R.drawable.ic_drawer, R.string.drawer_open, R.string.drawer_close);}/** activity建立完成後 */@Overrideprotected void onPostCreate(Bundle savedInstanceState) {super.onPostCreate(savedInstanceState);mDrawerToggle.syncState();//該方法會自動和actionBar關聯, 將開關的圖片顯示在了action上,如果不設定,也可以有抽屜的效果,不過是預設的表徵圖}/** 菜單鍵點擊的事件處理 */@Overridepublic boolean onOptionsItemSelected(MenuItem item) {return mDrawerToggle.onOptionsItemSelected(item) || super.onOptionsItemSelected(item);}/** 裝置配置改變時 */@Overridepublic void onConfigurationChanged(Configuration newConfig) {super.onConfigurationChanged(newConfig);mDrawerToggle.onConfigurationChanged(newConfig);}/** drawer的監聽 */private class MyDrawerListener implements DrawerLayout.DrawerListener {@Overridepublic void onDrawerOpened(View drawerView) {// 開啟drawermDrawerToggle.onDrawerOpened(drawerView);//開關狀態改為opened}@Overridepublic void onDrawerClosed(View drawerView) {// 關閉drawermDrawerToggle.onDrawerClosed(drawerView);//開關狀態改為closed}@Overridepublic void onDrawerSlide(View drawerView, float slideOffset) {// drawer滑動的回調mDrawerToggle.onDrawerSlide(drawerView, slideOffset);}@Overridepublic void onDrawerStateChanged(int newState) {// drawer狀態改變的回調mDrawerToggle.onDrawerStateChanged(newState);}}
Android ActionBarDrawerToggle、DrawerLayout、ActionBar 結合