Androi ActionBarDrawerToggle&DrawerLayout雙向側滑動

本實踐在於練習使用ActionBarDrawerToggle+DrawerLayout實現雙向側滑欄菜單佈局java


須要的庫文件 android-v7-appcompat android

所選要的jar android-support-v4.jar,android.jarapp


效果圖
ide

點擊Home菜單 ↓-->searchview被隱藏佈局

點擊照相機 ↓-->searchview被隱藏post

點擊搜索 ↓ui

點擊隱藏菜單 ↓this




首先是ActionBar的菜單設計toggle_menu.xmlspa

<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    tools:context="com.example.actiontabbar.DrawerToggleActivity" >

    <item android:id="@+id/action_search"
        	android:orderInCategory="100"
 			android:title="@string/action_search"  
 			app:actionViewClass="android.support.v7.widget.SearchView" 
 			app:showAsAction="ifRoom"
 />
  
     <item
        android:id="@+id/action_camera"
        android:orderInCategory="100"
        android:icon="@drawable/ofm_camera_icon"
        android:title="@string/action_camera"
        app:showAsAction="ifRoom"/>
     <item
        android:id="@+id/action_settings"
        android:orderInCategory="100"
        android:icon="@drawable/ofm_setting_icon"
        android:title="@string/action_settings"
        app:showAsAction="never"/>

</menu>

佈局文件drawertoggle_layout.xml設計

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/main_drawer_layout"
    android:orientation="vertical" >
    
	<FrameLayout 
	    android:id="@+id/main_content"
	    android:layout_width="match_parent"
	    android:layout_height="wrap_content"
	    />

	    
	<LinearLayout 
	    android:id="@+id/main_left_menu"
	    android:layout_width="200dip"
	    android:layout_height="match_parent"
	    android:orientation="vertical"
	    android:layout_gravity="start"
	    android:background="#f09001"
	    />
	<LinearLayout 
	    android:id="@+id/main_right_menu"
	    android:layout_width="200dip"
	    android:layout_height="match_parent"
	    android:orientation="vertical"
	    android:layout_gravity="end"
	    android:background="#f09001"
	    />
	    

</android.support.v4.widget.DrawerLayout>

Activity代碼

package com.example.actiontabbar;

import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;

import android.content.res.Configuration;
import android.graphics.drawable.ColorDrawable;
import android.os.Bundle;
import android.support.v4.app.ActionBarDrawerToggle;
import android.support.v4.view.GravityCompat;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarActivity;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewConfiguration;
import android.view.Window;
import android.widget.LinearLayout;

public class DrawerToggleActivity  extends ActionBarActivity{

	private DrawerLayout mDrawerLayout;
	
	private LinearLayout leftMenuPanel;
	
	private LinearLayout rightMenuPanel;

	private ActionBarDrawerToggle actionBarDrawerToggle;
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		forceShowOverflowMenu();
		setContentView(R.layout.drawertoggle_layout);
		
		initDrawerLayout();
	
	}

	private void initDrawerLayout()
	{
		mDrawerLayout  = (DrawerLayout)findViewById(R.id.main_drawer_layout);
		leftMenuPanel  = (LinearLayout) findViewById(R.id.main_left_menu);
		rightMenuPanel = (LinearLayout) findViewById(R.id.main_right_menu);
		
		mDrawerLayout.setScrimColor(0x000000);
		mDrawerLayout.setDrawerShadow(R.drawable.goss_whitemask_drawable,GravityCompat.START);
		
		actionBarDrawerToggle = new ActionBarDrawerToggle(this, mDrawerLayout, R.drawable.abc_ic_menu_moreoverflow_normal_holo_dark, R.string.action_toggle,R.string.action_toggle){
			@Override
			public boolean onOptionsItemSelected(MenuItem item) {
				
				if (item.getItemId() == android.R.id.home) {
					//actionbar上的home icon  
                    //END即gravity.right 從右向左顯示   START即left  從左向右彈出顯示  
					mDrawerLayout.closeDrawer(rightMenuPanel);//關閉抽屜  
                    if (mDrawerLayout.isDrawerVisible(leftMenuPanel)) {  
                        mDrawerLayout.closeDrawer(leftMenuPanel);//關閉抽屜  
                    } else {  
                        mDrawerLayout.openDrawer(leftMenuPanel);//打開抽屜  
                    }  
                    return true;  
                }
				else if(item.getItemId()==R.id.action_camera)
                {
					mDrawerLayout.closeDrawer(leftMenuPanel);//關閉抽屜  
					//END即gravity.right 從右向左顯示   START即left  從左向右彈出顯示  
                    if (mDrawerLayout.isDrawerVisible(rightMenuPanel)) {  
                        mDrawerLayout.closeDrawer(rightMenuPanel);//關閉抽屜  
                    } else {  
                        mDrawerLayout.openDrawer(rightMenuPanel);//打開抽屜  
                    }  
                    return true; 
                }
				return super.onOptionsItemSelected(item);
			}
			
			@Override
			public void onDrawerClosed(View drawerView) {
				if(drawerView==leftMenuPanel)
				{
					super.onDrawerClosed(drawerView);
				}
				getSupportActionBar().setTitle(R.string.app_name);
				postInvalidateOptionsMenu();
			}
			
			@Override
			public void onDrawerOpened(View drawerView) {
				super.onDrawerOpened(drawerView);
				if(drawerView==rightMenuPanel)
				{
					super.onDrawerClosed(drawerView);
				}
				getSupportActionBar().setTitle(R.string.action_toggle);
				postInvalidateOptionsMenu();
				
			}
			
			@Override
			public void onDrawerSlide(View drawerView, float slideOffset) {
				super.onDrawerSlide(drawerView, slideOffset);
				if(drawerView==rightMenuPanel)
				{
					super.onDrawerClosed(drawerView);
				}
			}
			
			@Override
			public void onDrawerStateChanged(int newState) {
				super.onDrawerStateChanged(newState);
			}
		};
		
		getSupportActionBar().setDisplayHomeAsUpEnabled(true);//給home icon的左邊加上一個返回的圖標  
		getSupportActionBar().setIcon(new ColorDrawable(0x00ffffff));
		 
		mDrawerLayout.setDrawerListener(actionBarDrawerToggle);
		actionBarDrawerToggle.setDrawerIndicatorEnabled(true);
	}
	
	private void postInvalidateOptionsMenu()
	{
		try {
			Method method = this.getClass().getMethod("invalidateOptionsMenu", new Class<?>[]{});
			if(method!=null)
			{
	            if (Modifier.isPublic(method.getModifiers()) &&
	                    Modifier.isPublic(method.getDeclaringClass().getModifiers())) {
	            	method.invoke(this, new Object[]{});
	            }
	            else if(!method.isAccessible())
            	{
            		method.setAccessible(true);
            		method.invoke(this, new Object[]{});
            	}
			}
		} catch (NoSuchMethodException e) {
			e.printStackTrace();
		} catch (IllegalAccessException e) {
			e.printStackTrace();
		} catch (IllegalArgumentException e) {
			e.printStackTrace();
		} catch (InvocationTargetException e) {
			e.printStackTrace();
		}
	}
	
	private void forceShowOverflowMenu() {
		try {
			ViewConfiguration config = ViewConfiguration.get(this);
			Field menuKeyField = ViewConfiguration.class
					.getDeclaredField("sHasPermanentMenuKey");
			if (menuKeyField != null) {
				menuKeyField.setAccessible(true);
				menuKeyField.setBoolean(config, false);
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
	
	@Override
	public boolean onCreateOptionsMenu(Menu menu) {

		getMenuInflater().inflate(R.menu.toggle_menu, menu);
		return true;
	}
	 @Override  
	 public boolean onPrepareOptionsMenu(Menu menu) {  
	        // If the nav drawer is open, hide action items related to the content view  
	        boolean drawerOpen = mDrawerLayout.isDrawerOpen(leftMenuPanel) || mDrawerLayout.isDrawerOpen(rightMenuPanel);  
	        menu.findItem(R.id.action_search).setVisible(!drawerOpen);//search的顯示與drawer的顯示相反  
	        return super.onPrepareOptionsMenu(menu);  
	  }  

	@Override
	public boolean onOptionsItemSelected(MenuItem item) {
	    if (actionBarDrawerToggle.onOptionsItemSelected(item))
        {
            return true;
        }
		return super.onOptionsItemSelected(item);
	}
	
	@Override
	public boolean onMenuOpened(int featureId, Menu menu) 
	{
		if (featureId == Window.FEATURE_ACTION_BAR && menu != null) {
			if (menu.getClass().getSimpleName().equals("MenuBuilder")) {
				try {
					Method m = menu.getClass().getDeclaredMethod(
							"setOptionalIconsVisible", Boolean.TYPE);
					m.setAccessible(true);
					m.invoke(menu, true);
				} catch (Exception e) {
				}
			}
		}
		return super.onMenuOpened(featureId, menu);
	}
	
	@Override  
    protected void onPostCreate(Bundle savedInstanceState) {  
        super.onPostCreate(savedInstanceState);  
        actionBarDrawerToggle.syncState();  
    }  
	
	 @Override  
	 public void onConfigurationChanged(Configuration newConfig) {  
	        super.onConfigurationChanged(newConfig);  
	        actionBarDrawerToggle.onConfigurationChanged(newConfig);  
	 }  
	
}
相關文章
相關標籤/搜索