标签:
ActionBarDrawerToggle是一个开关,用于打开/关闭DrawerLayout抽屉
ActionBarDrawerToggle 提供了一个方便的方式来配合DrawerLayout和ActionBar,以实现推荐的抽屉功能。
即点击ActionBar的home按钮,即可弹出DrawerLayout抽屉。
在Activity中的两个回调函数中使用它:
onConfigurationChanged
onOptionsItemSelected
调用ActionBarDrawerToggle.syncState() 在Activity的onPostCreate()中;指示,ActionBarDrawerToggle与DrawerLayout的状态同步,并将ActionBarDrawerToggle中的drawer图标,设置为ActionBar的Home-Button的icon
关于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());
- mDrawerToggle = new ActionBarDrawerToggle(activity, mDrawerLayout, R.drawable.ic_drawer, R.string.drawer_open, R.string.drawer_close);
- }
-
- @Override
- protected void onPostCreate(Bundle savedInstanceState) {
- super.onPostCreate(savedInstanceState);
- mDrawerToggle.syncState();
- }
-
-
- @Override
- public boolean onOptionsItemSelected(MenuItem item) {
- return mDrawerToggle.onOptionsItemSelected(item) || super.onOptionsItemSelected(item);
- }
-
- @Override
- public void onConfigurationChanged(Configuration newConfig) {
- super.onConfigurationChanged(newConfig);
- mDrawerToggle.onConfigurationChanged(newConfig);
- }
-
-
- private class MyDrawerListener implements DrawerLayout.DrawerListener {
- @Override
- public void onDrawerOpened(View drawerView) {
- mDrawerToggle.onDrawerOpened(drawerView);
- }
-
- @Override
- public void onDrawerClosed(View drawerView) {
- mDrawerToggle.onDrawerClosed(drawerView);
- }
-
- @Override
- public void onDrawerSlide(View drawerView, float slideOffset) {
- mDrawerToggle.onDrawerSlide(drawerView, slideOffset);
- }
-
- @Override
- public void onDrawerStateChanged(int newState) {
- mDrawerToggle.onDrawerStateChanged(newState);
- }
- }
Android ActionBarDrawerToggle、DrawerLayout、ActionBar 结合
标签:
原文地址:http://www.cnblogs.com/ldq2016/p/5407358.html