mirror of
https://github.com/MinimalBible/MinimalBible
synced 2024-11-22 07:58:20 -05:00
Get the DownloadActivity back on track.
This commit is contained in:
parent
787cc4aa24
commit
23c41ddb72
@ -82,6 +82,7 @@ public class DownloadActivity extends BaseActivity implements
|
|||||||
// Set up the drawer.
|
// Set up the drawer.
|
||||||
mNavigationDrawerFragment.setUp(R.id.navigation_drawer,
|
mNavigationDrawerFragment.setUp(R.id.navigation_drawer,
|
||||||
(DrawerLayout) findViewById(R.id.drawer_layout));
|
(DrawerLayout) findViewById(R.id.drawer_layout));
|
||||||
|
mNavigationDrawerFragment.selectItem(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -0,0 +1,258 @@
|
|||||||
|
package org.bspeice.minimalbible.activity.navigation;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
|
import android.content.res.Configuration;
|
||||||
|
import android.os.Build;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.preference.PreferenceManager;
|
||||||
|
import android.support.v4.app.ActionBarDrawerToggle;
|
||||||
|
import android.support.v4.app.Fragment;
|
||||||
|
import android.support.v4.view.GravityCompat;
|
||||||
|
import android.support.v4.widget.DrawerLayout;
|
||||||
|
import android.support.v7.app.ActionBar;
|
||||||
|
import android.support.v7.app.ActionBarActivity;
|
||||||
|
import android.view.Menu;
|
||||||
|
import android.view.MenuInflater;
|
||||||
|
import android.view.MenuItem;
|
||||||
|
import android.view.View;
|
||||||
|
|
||||||
|
import com.readystatesoftware.systembartint.SystemBarTintManager;
|
||||||
|
|
||||||
|
import org.bspeice.minimalbible.R;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Abstract NavDrawer Fragment to build on top of.
|
||||||
|
* Likely needs some more methods refactored to truly support both List and ExandableList
|
||||||
|
*/
|
||||||
|
public abstract class AbstractNavDrawerFragment extends Fragment {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remember the position of the selected item.
|
||||||
|
*/
|
||||||
|
private static final String STATE_SELECTED_POSITION = "selected_navigation_drawer_position";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Per the design guidelines, you should show the drawer on launch until the
|
||||||
|
* user manually expands it. This shared preference tracks this.
|
||||||
|
*/
|
||||||
|
private static final String PREF_USER_LEARNED_DRAWER = "navigation_drawer_learned";
|
||||||
|
protected int mCurrentSelectedPosition = 0;
|
||||||
|
/**
|
||||||
|
* A pointer to the current callbacks instance (the Activity).
|
||||||
|
*/
|
||||||
|
protected NavigationDrawerCallbacks mCallbacks;
|
||||||
|
protected DrawerLayout mDrawerLayout;
|
||||||
|
protected View mFragmentContainerView;
|
||||||
|
/**
|
||||||
|
* Helper component that ties the action bar to the navigation drawer.
|
||||||
|
*/
|
||||||
|
private ActionBarDrawerToggle mDrawerToggle;
|
||||||
|
private boolean mFromSavedInstanceState;
|
||||||
|
private boolean mUserLearnedDrawer;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
|
// Read in the flag indicating whether or not the user has demonstrated
|
||||||
|
// awareness of the
|
||||||
|
// drawer. See PREF_USER_LEARNED_DRAWER for details.
|
||||||
|
SharedPreferences sp = PreferenceManager
|
||||||
|
.getDefaultSharedPreferences(getActivity());
|
||||||
|
mUserLearnedDrawer = sp.getBoolean(PREF_USER_LEARNED_DRAWER, false);
|
||||||
|
|
||||||
|
if (savedInstanceState != null) {
|
||||||
|
mCurrentSelectedPosition = savedInstanceState
|
||||||
|
.getInt(STATE_SELECTED_POSITION);
|
||||||
|
mFromSavedInstanceState = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onActivityCreated(Bundle savedInstanceState) {
|
||||||
|
super.onActivityCreated(savedInstanceState);
|
||||||
|
// Indicate that this fragment would like to influence the set of
|
||||||
|
// actions in the action bar.
|
||||||
|
setHasOptionsMenu(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isDrawerOpen() {
|
||||||
|
return mDrawerLayout != null
|
||||||
|
&& mDrawerLayout.isDrawerOpen(mFragmentContainerView);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Users of this fragment must call this method to set up the navigation
|
||||||
|
* drawer interactions.
|
||||||
|
*
|
||||||
|
* @param fragmentId The android:id of this fragment in its activity's layout.
|
||||||
|
* @param drawerLayout The DrawerLayout containing this fragment's UI.
|
||||||
|
*/
|
||||||
|
public void setUp(int fragmentId, DrawerLayout drawerLayout) {
|
||||||
|
mFragmentContainerView = getActivity().findViewById(fragmentId);
|
||||||
|
mDrawerLayout = drawerLayout;
|
||||||
|
|
||||||
|
// set a custom shadow that overlays the main content when the drawer
|
||||||
|
// opens
|
||||||
|
mDrawerLayout.setDrawerShadow(R.drawable.drawer_shadow,
|
||||||
|
GravityCompat.START);
|
||||||
|
// set up the drawer's list view with items and click listener
|
||||||
|
|
||||||
|
ActionBar actionBar = getActionBar();
|
||||||
|
actionBar.setDisplayHomeAsUpEnabled(true);
|
||||||
|
actionBar.setHomeButtonEnabled(true);
|
||||||
|
|
||||||
|
// ActionBarDrawerToggle ties together the the proper interactions
|
||||||
|
// between the navigation drawer and the action bar app icon.
|
||||||
|
mDrawerToggle = new ActionBarDrawerToggle(getActivity(), /* host Activity */
|
||||||
|
mDrawerLayout, /* DrawerLayout object */
|
||||||
|
R.drawable.ic_drawer, /* nav drawer image to replace 'Up' caret */
|
||||||
|
R.string.navigation_drawer_open, /*
|
||||||
|
* "open drawer" description for
|
||||||
|
* accessibility
|
||||||
|
*/
|
||||||
|
R.string.navigation_drawer_close /*
|
||||||
|
* "close drawer" description for
|
||||||
|
* accessibility
|
||||||
|
*/
|
||||||
|
) {
|
||||||
|
@Override
|
||||||
|
public void onDrawerClosed(View drawerView) {
|
||||||
|
super.onDrawerClosed(drawerView);
|
||||||
|
if (!isAdded()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
getActivity().supportInvalidateOptionsMenu(); // calls
|
||||||
|
// onPrepareOptionsMenu()
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDrawerOpened(View drawerView) {
|
||||||
|
super.onDrawerOpened(drawerView);
|
||||||
|
if (!isAdded()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!mUserLearnedDrawer) {
|
||||||
|
// The user manually opened the drawer; store this flag to
|
||||||
|
// prevent auto-showing
|
||||||
|
// the navigation drawer automatically in the future.
|
||||||
|
mUserLearnedDrawer = true;
|
||||||
|
SharedPreferences sp = PreferenceManager
|
||||||
|
.getDefaultSharedPreferences(getActivity());
|
||||||
|
sp.edit().putBoolean(PREF_USER_LEARNED_DRAWER, true)
|
||||||
|
.commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
getActivity().supportInvalidateOptionsMenu(); // calls
|
||||||
|
// onPrepareOptionsMenu()
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// If the user hasn't 'learned' about the drawer, open it to introduce
|
||||||
|
// them to the drawer,
|
||||||
|
// per the navigation drawer design guidelines.
|
||||||
|
if (!mUserLearnedDrawer && !mFromSavedInstanceState) {
|
||||||
|
mDrawerLayout.openDrawer(mFragmentContainerView);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Defer code dependent on restoration of previous instance state.
|
||||||
|
mDrawerLayout.post(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
mDrawerToggle.syncState();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
mDrawerLayout.setDrawerListener(mDrawerToggle);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onAttach(Activity activity) {
|
||||||
|
super.onAttach(activity);
|
||||||
|
try {
|
||||||
|
mCallbacks = (NavigationDrawerCallbacks) activity;
|
||||||
|
} catch (ClassCastException e) {
|
||||||
|
throw new ClassCastException(
|
||||||
|
"Activity must implement NavigationDrawerCallbacks.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDetach() {
|
||||||
|
super.onDetach();
|
||||||
|
mCallbacks = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSaveInstanceState(Bundle outState) {
|
||||||
|
super.onSaveInstanceState(outState);
|
||||||
|
outState.putInt(STATE_SELECTED_POSITION, mCurrentSelectedPosition);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onConfigurationChanged(Configuration newConfig) {
|
||||||
|
super.onConfigurationChanged(newConfig);
|
||||||
|
// Forward the new configuration the drawer toggle component.
|
||||||
|
mDrawerToggle.onConfigurationChanged(newConfig);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
|
||||||
|
// If the drawer is open, show the global app actions in the action bar.
|
||||||
|
// See also
|
||||||
|
// showGlobalContextActionBar, which controls the top-left area of the
|
||||||
|
// action bar.
|
||||||
|
if (mDrawerLayout != null && isDrawerOpen()) {
|
||||||
|
inflater.inflate(R.menu.global, menu);
|
||||||
|
showGlobalContextActionBar();
|
||||||
|
}
|
||||||
|
super.onCreateOptionsMenu(menu, inflater);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onOptionsItemSelected(MenuItem item) {
|
||||||
|
if (mDrawerToggle.onOptionsItemSelected(item)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return super.onOptionsItemSelected(item);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Per the navigation drawer design guidelines, updates the action bar to
|
||||||
|
* show the global app 'context', rather than just what's in the current
|
||||||
|
* screen.
|
||||||
|
*/
|
||||||
|
private void showGlobalContextActionBar() {
|
||||||
|
ActionBar actionBar = getActionBar();
|
||||||
|
actionBar.setDisplayShowTitleEnabled(true);
|
||||||
|
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_STANDARD);
|
||||||
|
// actionBar.setTitle(R.string.app_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected ActionBar getActionBar() {
|
||||||
|
return ((ActionBarActivity) getActivity()).getSupportActionBar();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setInsets(View view) {
|
||||||
|
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT)
|
||||||
|
return;
|
||||||
|
SystemBarTintManager tintManager = new SystemBarTintManager(getActivity());
|
||||||
|
SystemBarTintManager.SystemBarConfig config = tintManager.getConfig();
|
||||||
|
view.setPadding(0, config.getPixelInsetTop(true),
|
||||||
|
config.getPixelInsetRight(), config.getPixelInsetBottom());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Callbacks interface that all activities using this fragment must
|
||||||
|
* implement.
|
||||||
|
*/
|
||||||
|
public static interface NavigationDrawerCallbacks {
|
||||||
|
/**
|
||||||
|
* Called when an item in the navigation drawer is selected.
|
||||||
|
*/
|
||||||
|
void onNavigationDrawerItemSelected(int position);
|
||||||
|
}
|
||||||
|
}
|
@ -1,26 +1,9 @@
|
|||||||
package org.bspeice.minimalbible.activity.navigation;
|
package org.bspeice.minimalbible.activity.navigation;
|
||||||
|
|
||||||
import android.app.Activity;
|
|
||||||
import android.content.SharedPreferences;
|
|
||||||
import android.content.res.Configuration;
|
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.preference.PreferenceManager;
|
|
||||||
import android.support.v4.app.ActionBarDrawerToggle;
|
|
||||||
import android.support.v4.app.Fragment;
|
|
||||||
import android.support.v4.view.GravityCompat;
|
|
||||||
import android.support.v4.widget.DrawerLayout;
|
|
||||||
import android.support.v7.app.ActionBar;
|
|
||||||
import android.support.v7.app.ActionBarActivity;
|
|
||||||
import android.view.Menu;
|
|
||||||
import android.view.MenuInflater;
|
|
||||||
import android.view.MenuItem;
|
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.widget.ExpandableListView;
|
|
||||||
import android.widget.ListView;
|
import android.widget.ListView;
|
||||||
|
|
||||||
import com.readystatesoftware.systembartint.SystemBarTintManager;
|
|
||||||
|
|
||||||
import org.bspeice.minimalbible.R;
|
import org.bspeice.minimalbible.R;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -31,155 +14,22 @@ import org.bspeice.minimalbible.R;
|
|||||||
* implemented here.
|
* implemented here.
|
||||||
* TODO: Refactor to allow ExpandableListView
|
* TODO: Refactor to allow ExpandableListView
|
||||||
*/
|
*/
|
||||||
public class NavDrawerFragment extends Fragment {
|
public class NavDrawerFragment extends AbstractNavDrawerFragment {
|
||||||
|
|
||||||
/**
|
|
||||||
* Remember the position of the selected item.
|
|
||||||
*/
|
|
||||||
private static final String STATE_SELECTED_POSITION = "selected_navigation_drawer_position";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Per the design guidelines, you should show the drawer on launch until the
|
|
||||||
* user manually expands it. This shared preference tracks this.
|
|
||||||
*/
|
|
||||||
private static final String PREF_USER_LEARNED_DRAWER = "navigation_drawer_learned";
|
|
||||||
protected ListView mDrawerListView;
|
protected ListView mDrawerListView;
|
||||||
protected int mCurrentSelectedPosition = 0;
|
|
||||||
/**
|
|
||||||
* A pointer to the current callbacks instance (the Activity).
|
|
||||||
*/
|
|
||||||
private NavigationDrawerCallbacks mCallbacks;
|
|
||||||
/**
|
|
||||||
* Helper component that ties the action bar to the navigation drawer.
|
|
||||||
*/
|
|
||||||
private ActionBarDrawerToggle mDrawerToggle;
|
|
||||||
private DrawerLayout mDrawerLayout;
|
|
||||||
private View mFragmentContainerView;
|
|
||||||
private boolean mFromSavedInstanceState;
|
|
||||||
private boolean mUserLearnedDrawer;
|
|
||||||
|
|
||||||
public NavDrawerFragment() {
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onViewCreated(View view, Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onViewCreated(view, savedInstanceState);
|
||||||
|
|
||||||
// Read in the flag indicating whether or not the user has demonstrated
|
// This could also be a ScrollView
|
||||||
// awareness of the
|
ListView list = (ListView) view.findViewById(R.id.list_nav_drawer);
|
||||||
// drawer. See PREF_USER_LEARNED_DRAWER for details.
|
// This could also be set in your layout, allows the list items to
|
||||||
SharedPreferences sp = PreferenceManager
|
// scroll through the bottom padded area (navigation bar)
|
||||||
.getDefaultSharedPreferences(getActivity());
|
list.setClipToPadding(false);
|
||||||
mUserLearnedDrawer = sp.getBoolean(PREF_USER_LEARNED_DRAWER, false);
|
// Sets the padding to the insets (include action bar and navigation bar
|
||||||
|
// padding for the current device and orientation)
|
||||||
if (savedInstanceState != null) {
|
super.setInsets(list);
|
||||||
mCurrentSelectedPosition = savedInstanceState
|
|
||||||
.getInt(STATE_SELECTED_POSITION);
|
|
||||||
mFromSavedInstanceState = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Select either the default item (0) or the last selected item.
|
|
||||||
selectItem(mCurrentSelectedPosition);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onActivityCreated(Bundle savedInstanceState) {
|
|
||||||
super.onActivityCreated(savedInstanceState);
|
|
||||||
// Indicate that this fragment would like to influence the set of
|
|
||||||
// actions in the action bar.
|
|
||||||
setHasOptionsMenu(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isDrawerOpen() {
|
|
||||||
return mDrawerLayout != null
|
|
||||||
&& mDrawerLayout.isDrawerOpen(mFragmentContainerView);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Users of this fragment must call this method to set up the navigation
|
|
||||||
* drawer interactions.
|
|
||||||
*
|
|
||||||
* @param fragmentId The android:id of this fragment in its activity's layout.
|
|
||||||
* @param drawerLayout The DrawerLayout containing this fragment's UI.
|
|
||||||
*/
|
|
||||||
public void setUp(int fragmentId, DrawerLayout drawerLayout) {
|
|
||||||
mFragmentContainerView = getActivity().findViewById(fragmentId);
|
|
||||||
mDrawerLayout = drawerLayout;
|
|
||||||
|
|
||||||
// set a custom shadow that overlays the main content when the drawer
|
|
||||||
// opens
|
|
||||||
mDrawerLayout.setDrawerShadow(R.drawable.drawer_shadow,
|
|
||||||
GravityCompat.START);
|
|
||||||
// set up the drawer's list view with items and click listener
|
|
||||||
|
|
||||||
ActionBar actionBar = getActionBar();
|
|
||||||
actionBar.setDisplayHomeAsUpEnabled(true);
|
|
||||||
actionBar.setHomeButtonEnabled(true);
|
|
||||||
|
|
||||||
// ActionBarDrawerToggle ties together the the proper interactions
|
|
||||||
// between the navigation drawer and the action bar app icon.
|
|
||||||
mDrawerToggle = new ActionBarDrawerToggle(getActivity(), /* host Activity */
|
|
||||||
mDrawerLayout, /* DrawerLayout object */
|
|
||||||
R.drawable.ic_drawer, /* nav drawer image to replace 'Up' caret */
|
|
||||||
R.string.navigation_drawer_open, /*
|
|
||||||
* "open drawer" description for
|
|
||||||
* accessibility
|
|
||||||
*/
|
|
||||||
R.string.navigation_drawer_close /*
|
|
||||||
* "close drawer" description for
|
|
||||||
* accessibility
|
|
||||||
*/
|
|
||||||
) {
|
|
||||||
@Override
|
|
||||||
public void onDrawerClosed(View drawerView) {
|
|
||||||
super.onDrawerClosed(drawerView);
|
|
||||||
if (!isAdded()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
getActivity().supportInvalidateOptionsMenu(); // calls
|
|
||||||
// onPrepareOptionsMenu()
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onDrawerOpened(View drawerView) {
|
|
||||||
super.onDrawerOpened(drawerView);
|
|
||||||
if (!isAdded()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!mUserLearnedDrawer) {
|
|
||||||
// The user manually opened the drawer; store this flag to
|
|
||||||
// prevent auto-showing
|
|
||||||
// the navigation drawer automatically in the future.
|
|
||||||
mUserLearnedDrawer = true;
|
|
||||||
SharedPreferences sp = PreferenceManager
|
|
||||||
.getDefaultSharedPreferences(getActivity());
|
|
||||||
sp.edit().putBoolean(PREF_USER_LEARNED_DRAWER, true)
|
|
||||||
.commit();
|
|
||||||
}
|
|
||||||
|
|
||||||
getActivity().supportInvalidateOptionsMenu(); // calls
|
|
||||||
// onPrepareOptionsMenu()
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// If the user hasn't 'learned' about the drawer, open it to introduce
|
|
||||||
// them to the drawer,
|
|
||||||
// per the navigation drawer design guidelines.
|
|
||||||
if (!mUserLearnedDrawer && !mFromSavedInstanceState) {
|
|
||||||
mDrawerLayout.openDrawer(mFragmentContainerView);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Defer code dependent on restoration of previous instance state.
|
|
||||||
mDrawerLayout.post(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
mDrawerToggle.syncState();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
mDrawerLayout.setDrawerListener(mDrawerToggle);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void selectItem(int position) {
|
public void selectItem(int position) {
|
||||||
@ -195,105 +45,4 @@ public class NavDrawerFragment extends Fragment {
|
|||||||
mCallbacks.onNavigationDrawerItemSelected(position);
|
mCallbacks.onNavigationDrawerItemSelected(position);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onAttach(Activity activity) {
|
|
||||||
super.onAttach(activity);
|
|
||||||
try {
|
|
||||||
mCallbacks = (NavigationDrawerCallbacks) activity;
|
|
||||||
} catch (ClassCastException e) {
|
|
||||||
throw new ClassCastException(
|
|
||||||
"Activity must implement NavigationDrawerCallbacks.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onDetach() {
|
|
||||||
super.onDetach();
|
|
||||||
mCallbacks = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onSaveInstanceState(Bundle outState) {
|
|
||||||
super.onSaveInstanceState(outState);
|
|
||||||
outState.putInt(STATE_SELECTED_POSITION, mCurrentSelectedPosition);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onConfigurationChanged(Configuration newConfig) {
|
|
||||||
super.onConfigurationChanged(newConfig);
|
|
||||||
// Forward the new configuration the drawer toggle component.
|
|
||||||
mDrawerToggle.onConfigurationChanged(newConfig);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
|
|
||||||
// If the drawer is open, show the global app actions in the action bar.
|
|
||||||
// See also
|
|
||||||
// showGlobalContextActionBar, which controls the top-left area of the
|
|
||||||
// action bar.
|
|
||||||
if (mDrawerLayout != null && isDrawerOpen()) {
|
|
||||||
inflater.inflate(R.menu.global, menu);
|
|
||||||
showGlobalContextActionBar();
|
|
||||||
}
|
|
||||||
super.onCreateOptionsMenu(menu, inflater);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onOptionsItemSelected(MenuItem item) {
|
|
||||||
if (mDrawerToggle.onOptionsItemSelected(item)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return super.onOptionsItemSelected(item);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Per the navigation drawer design guidelines, updates the action bar to
|
|
||||||
* show the global app 'context', rather than just what's in the current
|
|
||||||
* screen.
|
|
||||||
*/
|
|
||||||
private void showGlobalContextActionBar() {
|
|
||||||
ActionBar actionBar = getActionBar();
|
|
||||||
actionBar.setDisplayShowTitleEnabled(true);
|
|
||||||
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_STANDARD);
|
|
||||||
// actionBar.setTitle(R.string.app_name);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected ActionBar getActionBar() {
|
|
||||||
return ((ActionBarActivity) getActivity()).getSupportActionBar();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setInsets(View view) {
|
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT)
|
|
||||||
return;
|
|
||||||
SystemBarTintManager tintManager = new SystemBarTintManager(getActivity());
|
|
||||||
SystemBarTintManager.SystemBarConfig config = tintManager.getConfig();
|
|
||||||
view.setPadding(0, config.getPixelInsetTop(true),
|
|
||||||
config.getPixelInsetRight(), config.getPixelInsetBottom());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onViewCreated(View view, Bundle savedInstanceState) {
|
|
||||||
super.onViewCreated(view, savedInstanceState);
|
|
||||||
|
|
||||||
// This could also be a ScrollView
|
|
||||||
ExpandableListView list = (ExpandableListView) view.findViewById(R.id.list_nav_drawer);
|
|
||||||
// This could also be set in your layout, allows the list items to
|
|
||||||
// scroll through the bottom padded area (navigation bar)
|
|
||||||
list.setClipToPadding(false);
|
|
||||||
// Sets the padding to the insets (include action bar and navigation bar
|
|
||||||
// padding for the current device and orientation)
|
|
||||||
setInsets(list);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Callbacks interface that all activities using this fragment must
|
|
||||||
* implement.
|
|
||||||
*/
|
|
||||||
public static interface NavigationDrawerCallbacks {
|
|
||||||
/**
|
|
||||||
* Called when an item in the navigation drawer is selected.
|
|
||||||
*/
|
|
||||||
void onNavigationDrawerItemSelected(int position);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user