diff options
| author | Dianne Hackborn <hackbod@google.com> | 2013-02-26 14:53:55 -0800 |
|---|---|---|
| committer | Dianne Hackborn <hackbod@google.com> | 2013-02-27 18:27:42 -0800 |
| commit | df7221ced3b7cd807f14e84c302fc09fd659fd68 (patch) | |
| tree | 2e5cdc00c406f577492a7168580fa6c127b0a1f4 /core/java | |
| parent | d0d209ed4d6280b6e1203eebe823f04f9db766c0 (diff) | |
Unify normal and overlay action bar layouts.
Switch the action bar to always use the overlay layout, and
make it smarter to do the right thing depending on whether the
action bar is in overlay mode or not.
This allows apps to use the system UI magic flags without
having to worry about whether the action bar is configured
in overlay mode or note -- just select a stable layout and it
will automatically go into overlay mode.
In the future this should also allow us to simplify the action
bar code, since it is all sitting on one common implementation.
For example, much of the logic in ActionBarImpl can be moved
to the root action bar layout, and that layout can be optimized
to do custom layout with all of the known elements it has.
Also fixed a little bug in the performance tests.
Change-Id: Iec0c0c0699754f0d1ce37402d786b4966e052a56
Diffstat (limited to 'core/java')
| -rw-r--r-- | core/java/com/android/internal/app/ActionBarImpl.java | 24 | ||||
| -rw-r--r-- | core/java/com/android/internal/widget/ActionBarOverlayLayout.java | 56 |
2 files changed, 52 insertions, 28 deletions
diff --git a/core/java/com/android/internal/app/ActionBarImpl.java b/core/java/com/android/internal/app/ActionBarImpl.java index f041f0781768..db20549ee5ae 100644 --- a/core/java/com/android/internal/app/ActionBarImpl.java +++ b/core/java/com/android/internal/app/ActionBarImpl.java @@ -110,6 +110,7 @@ public class ActionBarImpl extends ActionBar { private int mCurWindowVisibility = View.VISIBLE; + private boolean mContentAnimations = true; private boolean mHiddenByApp; private boolean mHiddenBySystem; private boolean mShowingForMode; @@ -122,7 +123,7 @@ public class ActionBarImpl extends ActionBar { final AnimatorListener mHideListener = new AnimatorListenerAdapter() { @Override public void onAnimationEnd(Animator animation) { - if (mContentView != null) { + if (mContentAnimations && mContentView != null) { mContentView.setTranslationY(0); mTopVisibilityView.setTranslationY(0); } @@ -151,23 +152,24 @@ public class ActionBarImpl extends ActionBar { mActivity = activity; Window window = activity.getWindow(); View decor = window.getDecorView(); - init(decor); - if (!mActivity.getWindow().hasFeature(Window.FEATURE_ACTION_BAR_OVERLAY)) { + boolean overlayMode = mActivity.getWindow().hasFeature(Window.FEATURE_ACTION_BAR_OVERLAY); + init(decor, overlayMode); + if (!overlayMode) { mContentView = decor.findViewById(android.R.id.content); } } public ActionBarImpl(Dialog dialog) { mDialog = dialog; - init(dialog.getWindow().getDecorView()); + init(dialog.getWindow().getDecorView(), false); } - private void init(View decor) { + private void init(View decor, boolean overlayMode) { mContext = decor.getContext(); mOverlayLayout = (ActionBarOverlayLayout) decor.findViewById( com.android.internal.R.id.action_bar_overlay_layout); if (mOverlayLayout != null) { - mOverlayLayout.setActionBar(this); + mOverlayLayout.setActionBar(this, overlayMode); } mActionView = (ActionBarView) decor.findViewById(com.android.internal.R.id.action_bar); mContextView = (ActionBarContextView) decor.findViewById( @@ -586,6 +588,10 @@ public class ActionBarImpl extends ActionBar { return mContainerView.getHeight(); } + public void enableContentAnimations(boolean enabled) { + mContentAnimations = enabled; + } + @Override public void show() { if (mHiddenByApp) { @@ -684,7 +690,7 @@ public class ActionBarImpl extends ActionBar { AnimatorSet anim = new AnimatorSet(); AnimatorSet.Builder b = anim.play(ObjectAnimator.ofFloat(mTopVisibilityView, "translationY", 0)); - if (mContentView != null) { + if (mContentAnimations && mContentView != null) { b.with(ObjectAnimator.ofFloat(mContentView, "translationY", startingY, 0)); } @@ -709,7 +715,7 @@ public class ActionBarImpl extends ActionBar { } else { mTopVisibilityView.setAlpha(1); mTopVisibilityView.setTranslationY(0); - if (mContentView != null) { + if (mContentAnimations && mContentView != null) { mContentView.setTranslationY(0); } if (mSplitView != null && mContextDisplayMode == CONTEXT_DISPLAY_SPLIT) { @@ -742,7 +748,7 @@ public class ActionBarImpl extends ActionBar { } AnimatorSet.Builder b = anim.play(ObjectAnimator.ofFloat(mTopVisibilityView, "translationY", endingY)); - if (mContentView != null) { + if (mContentAnimations && mContentView != null) { b.with(ObjectAnimator.ofFloat(mContentView, "translationY", 0, endingY)); } diff --git a/core/java/com/android/internal/widget/ActionBarOverlayLayout.java b/core/java/com/android/internal/widget/ActionBarOverlayLayout.java index 18a696e31489..482eba71e959 100644 --- a/core/java/com/android/internal/widget/ActionBarOverlayLayout.java +++ b/core/java/com/android/internal/widget/ActionBarOverlayLayout.java @@ -40,6 +40,7 @@ public class ActionBarOverlayLayout extends FrameLayout { private ActionBarContainer mContainerView; private ActionBarView mActionView; private View mActionBarBottom; + private boolean mOverlayMode; private int mLastSystemUiVisibility; private final Rect mLocalInsets = new Rect(); @@ -63,8 +64,13 @@ public class ActionBarOverlayLayout extends FrameLayout { ta.recycle(); } - public void setActionBar(ActionBarImpl impl) { + public void setOverlayMode(boolean mode) { + mOverlayMode = mode; + } + + public void setActionBar(ActionBarImpl impl, boolean overlayMode) { mActionBar = impl; + mOverlayMode = overlayMode; if (getWindowToken() != null) { // This is being initialized after being added to a window; // make sure to update all state now. @@ -105,8 +111,13 @@ public class ActionBarOverlayLayout extends FrameLayout { mLastSystemUiVisibility = visible; final boolean barVisible = (visible&SYSTEM_UI_FLAG_FULLSCREEN) == 0; final boolean wasVisible = mActionBar != null ? mActionBar.isSystemShowing() : true; + final boolean stable = (visible&SYSTEM_UI_FLAG_LAYOUT_STABLE) != 0; if (mActionBar != null) { - if (barVisible) mActionBar.showForSystem(); + // We want the bar to be visible if it is not being hidden, + // or the app has not turned on a stable UI mode (meaning they + // are performing explicit layout around the action bar). + mActionBar.enableContentAnimations(!stable); + if (barVisible || !stable) mActionBar.showForSystem(); else mActionBar.hideForSystem(); } if ((diff&SYSTEM_UI_FLAG_LAYOUT_STABLE) != 0) { @@ -161,35 +172,42 @@ public class ActionBarOverlayLayout extends FrameLayout { changed |= applyInsets(mActionBarBottom, insets, true, false, true, true); } - // If the window has not requested system UI layout flags, we need to - // make sure its content is not being covered by system UI... though it - // will still be covered by the action bar since they have requested it to - // overlay. - boolean res = computeFitSystemWindows(insets, mLocalInsets); - changed |= applyInsets(mContent, mLocalInsets, true, true, true, true); - - + int topSpace = 0; if (stable || mActionBarTop.getVisibility() == VISIBLE) { - // The action bar creates additional insets for its content to use. - insets.top += mActionBarHeight; + // This is the space needed on top of the window for the action bar. + topSpace = mActionBarHeight; } - if (mActionBar != null && mActionBar.hasNonEmbeddedTabs()) { View tabs = mContainerView.getTabContainer(); - if (stable || (tabs != null && tabs.getVisibility() == VISIBLE)) { - // If tabs are not embedded, adjust insets to account for them. - insets.top += mActionBarHeight; + if (tabs != null && (stable || tabs.getVisibility() == VISIBLE)) { + // If tabs are not embedded, increase space on top to account for them. + topSpace += mActionBarHeight; } } + int bottomSpace = 0; if (mActionView.isSplitActionBar()) { - if (stable || (mActionBarBottom != null - && mActionBarBottom.getVisibility() == VISIBLE)) { + if ((mActionBarBottom != null + && (stable || mActionBarBottom.getVisibility() == VISIBLE))) { // If action bar is split, adjust bottom insets for it. - insets.bottom += mActionBarHeight; + bottomSpace = mActionBarHeight; } } + // If the window has not requested system UI layout flags, we need to + // make sure its content is not being covered by system UI... though it + // will still be covered by the action bar since they have requested it to + // overlay. + boolean res = computeFitSystemWindows(insets, mLocalInsets); + if (!mOverlayMode && !stable) { + mLocalInsets.top += topSpace; + mLocalInsets.bottom += bottomSpace; + } else { + insets.top += topSpace; + insets.bottom += bottomSpace; + } + changed |= applyInsets(mContent, mLocalInsets, true, true, true, true); + if (changed) { requestLayout(); } |
