John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2013 The Android Open Source Project |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
Jorim Jaggi | b10e33f | 2015-02-04 21:57:40 +0100 | [diff] [blame] | 17 | package com.android.server.policy; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 18 | |
| 19 | import android.app.StatusBarManager; |
| 20 | import android.os.Handler; |
| 21 | import android.os.RemoteException; |
| 22 | import android.os.ServiceManager; |
John Spurlock | b77edbf | 2013-08-21 21:04:12 -0400 | [diff] [blame] | 23 | import android.os.SystemClock; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 24 | import android.util.Slog; |
| 25 | import android.view.View; |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 26 | import android.view.WindowManager; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 27 | import android.view.WindowManagerPolicy.WindowState; |
| 28 | |
| 29 | import com.android.internal.statusbar.IStatusBarService; |
| 30 | |
| 31 | import java.io.PrintWriter; |
| 32 | |
| 33 | /** |
| 34 | * Controls state/behavior specific to a system bar window. |
| 35 | */ |
| 36 | public class BarController { |
John Spurlock | 7edfbca | 2013-09-14 11:58:55 -0400 | [diff] [blame] | 37 | private static final boolean DEBUG = false; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 38 | |
| 39 | private static final int TRANSIENT_BAR_NONE = 0; |
John Spurlock | f25706f | 2013-11-07 18:02:43 -0500 | [diff] [blame] | 40 | private static final int TRANSIENT_BAR_SHOW_REQUESTED = 1; |
| 41 | private static final int TRANSIENT_BAR_SHOWING = 2; |
| 42 | private static final int TRANSIENT_BAR_HIDING = 3; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 43 | |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 44 | private static final int TRANSLUCENT_ANIMATION_DELAY_MS = 1000; |
John Spurlock | b77edbf | 2013-08-21 21:04:12 -0400 | [diff] [blame] | 45 | |
Jorim Jaggi | 24bec7c | 2015-02-04 12:40:14 +0100 | [diff] [blame] | 46 | protected final String mTag; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 47 | private final int mTransientFlag; |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 48 | private final int mUnhideFlag; |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 49 | private final int mTranslucentFlag; |
Jorim Jaggi | 4fa7892 | 2015-11-30 17:13:56 -0800 | [diff] [blame] | 50 | private final int mTransparentFlag; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 51 | private final int mStatusBarManagerId; |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 52 | private final int mTranslucentWmFlag; |
Jorim Jaggi | 24bec7c | 2015-02-04 12:40:14 +0100 | [diff] [blame] | 53 | protected final Handler mHandler; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 54 | private final Object mServiceAquireLock = new Object(); |
Jorim Jaggi | 24bec7c | 2015-02-04 12:40:14 +0100 | [diff] [blame] | 55 | protected IStatusBarService mStatusBarService; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 56 | |
| 57 | private WindowState mWin; |
John Spurlock | d4e6575 | 2013-08-28 14:17:09 -0400 | [diff] [blame] | 58 | private int mState = StatusBarManager.WINDOW_STATE_SHOWING; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 59 | private int mTransientBarState; |
| 60 | private boolean mPendingShow; |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 61 | private long mLastTranslucent; |
Selim Cinek | 4a4a2bddc | 2015-05-07 12:50:19 -0700 | [diff] [blame] | 62 | private boolean mShowTransparent; |
| 63 | private boolean mSetUnHideFlagWhenNextTransparent; |
| 64 | private boolean mNoAnimationOnNextShow; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 65 | |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 66 | public BarController(String tag, int transientFlag, int unhideFlag, int translucentFlag, |
Jorim Jaggi | 4fa7892 | 2015-11-30 17:13:56 -0800 | [diff] [blame] | 67 | int statusBarManagerId, int translucentWmFlag, int transparentFlag) { |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 68 | mTag = "BarController." + tag; |
| 69 | mTransientFlag = transientFlag; |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 70 | mUnhideFlag = unhideFlag; |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 71 | mTranslucentFlag = translucentFlag; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 72 | mStatusBarManagerId = statusBarManagerId; |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 73 | mTranslucentWmFlag = translucentWmFlag; |
Jorim Jaggi | 4fa7892 | 2015-11-30 17:13:56 -0800 | [diff] [blame] | 74 | mTransparentFlag = transparentFlag; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 75 | mHandler = new Handler(); |
| 76 | } |
| 77 | |
| 78 | public void setWindow(WindowState win) { |
| 79 | mWin = win; |
| 80 | } |
| 81 | |
Selim Cinek | 4a4a2bddc | 2015-05-07 12:50:19 -0700 | [diff] [blame] | 82 | public void setShowTransparent(boolean transparent) { |
| 83 | if (transparent != mShowTransparent) { |
| 84 | mShowTransparent = transparent; |
| 85 | mSetUnHideFlagWhenNextTransparent = transparent; |
| 86 | mNoAnimationOnNextShow = true; |
| 87 | } |
| 88 | } |
| 89 | |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 90 | public void showTransient() { |
| 91 | if (mWin != null) { |
John Spurlock | f25706f | 2013-11-07 18:02:43 -0500 | [diff] [blame] | 92 | setTransientBarState(TRANSIENT_BAR_SHOW_REQUESTED); |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 93 | } |
| 94 | } |
| 95 | |
| 96 | public boolean isTransientShowing() { |
| 97 | return mTransientBarState == TRANSIENT_BAR_SHOWING; |
| 98 | } |
| 99 | |
John Spurlock | f25706f | 2013-11-07 18:02:43 -0500 | [diff] [blame] | 100 | public boolean isTransientShowRequested() { |
| 101 | return mTransientBarState == TRANSIENT_BAR_SHOW_REQUESTED; |
| 102 | } |
| 103 | |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 104 | public boolean wasRecentlyTranslucent() { |
| 105 | return (SystemClock.uptimeMillis() - mLastTranslucent) < TRANSLUCENT_ANIMATION_DELAY_MS; |
John Spurlock | b77edbf | 2013-08-21 21:04:12 -0400 | [diff] [blame] | 106 | } |
| 107 | |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 108 | public void adjustSystemUiVisibilityLw(int oldVis, int vis) { |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 109 | if (mWin != null && mTransientBarState == TRANSIENT_BAR_SHOWING && |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 110 | (vis & mTransientFlag) == 0) { |
| 111 | // sysui requests hide |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 112 | setTransientBarState(TRANSIENT_BAR_HIDING); |
| 113 | setBarShowingLw(false); |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 114 | } else if (mWin != null && (oldVis & mUnhideFlag) != 0 && (vis & mUnhideFlag) == 0) { |
| 115 | // sysui ready to unhide |
| 116 | setBarShowingLw(true); |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 117 | } |
| 118 | } |
| 119 | |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 120 | public int applyTranslucentFlagLw(WindowState win, int vis, int oldVis) { |
| 121 | if (mWin != null) { |
| 122 | if (win != null && (win.getAttrs().privateFlags |
| 123 | & WindowManager.LayoutParams.PRIVATE_FLAG_INHERIT_TRANSLUCENT_DECOR) == 0) { |
Adrian Roos | ea56251 | 2014-05-05 13:33:03 +0200 | [diff] [blame] | 124 | int fl = PolicyControl.getWindowFlags(win, null); |
| 125 | if ((fl & mTranslucentWmFlag) != 0) { |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 126 | vis |= mTranslucentFlag; |
| 127 | } else { |
| 128 | vis &= ~mTranslucentFlag; |
| 129 | } |
Adrian Roos | ea56251 | 2014-05-05 13:33:03 +0200 | [diff] [blame] | 130 | if ((fl & WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS) != 0) { |
Jorim Jaggi | 4fa7892 | 2015-11-30 17:13:56 -0800 | [diff] [blame] | 131 | vis |= mTransparentFlag; |
Adrian Roos | ea56251 | 2014-05-05 13:33:03 +0200 | [diff] [blame] | 132 | } else { |
Jorim Jaggi | 4fa7892 | 2015-11-30 17:13:56 -0800 | [diff] [blame] | 133 | vis &= ~mTransparentFlag; |
Adrian Roos | ea56251 | 2014-05-05 13:33:03 +0200 | [diff] [blame] | 134 | } |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 135 | } else { |
| 136 | vis = (vis & ~mTranslucentFlag) | (oldVis & mTranslucentFlag); |
Jorim Jaggi | 4fa7892 | 2015-11-30 17:13:56 -0800 | [diff] [blame] | 137 | vis = (vis & ~mTransparentFlag) | (oldVis & mTransparentFlag); |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 138 | } |
| 139 | } |
| 140 | return vis; |
| 141 | } |
| 142 | |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 143 | public boolean setBarShowingLw(final boolean show) { |
| 144 | if (mWin == null) return false; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 145 | if (show && mTransientBarState == TRANSIENT_BAR_HIDING) { |
| 146 | mPendingShow = true; |
| 147 | return false; |
| 148 | } |
John Spurlock | 7edfbca | 2013-09-14 11:58:55 -0400 | [diff] [blame] | 149 | final boolean wasVis = mWin.isVisibleLw(); |
| 150 | final boolean wasAnim = mWin.isAnimatingLw(); |
Selim Cinek | 4a4a2bddc | 2015-05-07 12:50:19 -0700 | [diff] [blame] | 151 | final boolean change = show ? mWin.showLw(!mNoAnimationOnNextShow) |
| 152 | : mWin.hideLw(!mNoAnimationOnNextShow); |
| 153 | mNoAnimationOnNextShow = false; |
John Spurlock | 7edfbca | 2013-09-14 11:58:55 -0400 | [diff] [blame] | 154 | final int state = computeStateLw(wasVis, wasAnim, mWin, change); |
John Spurlock | c23bd80 | 2013-11-06 12:20:38 -0500 | [diff] [blame] | 155 | final boolean stateChanged = updateStateLw(state); |
| 156 | return change || stateChanged; |
John Spurlock | 7edfbca | 2013-09-14 11:58:55 -0400 | [diff] [blame] | 157 | } |
| 158 | |
| 159 | private int computeStateLw(boolean wasVis, boolean wasAnim, WindowState win, boolean change) { |
Adrian Roos | 76d2fe4 | 2015-07-09 14:54:08 -0700 | [diff] [blame] | 160 | if (win.isDrawnLw()) { |
John Spurlock | 7edfbca | 2013-09-14 11:58:55 -0400 | [diff] [blame] | 161 | final boolean vis = win.isVisibleLw(); |
| 162 | final boolean anim = win.isAnimatingLw(); |
| 163 | if (mState == StatusBarManager.WINDOW_STATE_HIDING && !change && !vis) { |
| 164 | return StatusBarManager.WINDOW_STATE_HIDDEN; |
John Spurlock | c23bd80 | 2013-11-06 12:20:38 -0500 | [diff] [blame] | 165 | } else if (mState == StatusBarManager.WINDOW_STATE_HIDDEN && vis) { |
| 166 | return StatusBarManager.WINDOW_STATE_SHOWING; |
John Spurlock | 7edfbca | 2013-09-14 11:58:55 -0400 | [diff] [blame] | 167 | } else if (change) { |
| 168 | if (wasVis && vis && !wasAnim && anim) { |
| 169 | return StatusBarManager.WINDOW_STATE_HIDING; |
| 170 | } else { |
| 171 | return StatusBarManager.WINDOW_STATE_SHOWING; |
| 172 | } |
| 173 | } |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 174 | } |
John Spurlock | 7edfbca | 2013-09-14 11:58:55 -0400 | [diff] [blame] | 175 | return mState; |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 176 | } |
| 177 | |
John Spurlock | c23bd80 | 2013-11-06 12:20:38 -0500 | [diff] [blame] | 178 | private boolean updateStateLw(final int state) { |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 179 | if (state != mState) { |
| 180 | mState = state; |
John Spurlock | 0ec64c6 | 2013-08-26 15:37:58 -0400 | [diff] [blame] | 181 | if (DEBUG) Slog.d(mTag, "mState: " + StatusBarManager.windowStateToString(state)); |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 182 | mHandler.post(new Runnable() { |
| 183 | @Override |
| 184 | public void run() { |
| 185 | try { |
| 186 | IStatusBarService statusbar = getStatusBarService(); |
| 187 | if (statusbar != null) { |
| 188 | statusbar.setWindowState(mStatusBarManagerId, state); |
| 189 | } |
| 190 | } catch (RemoteException e) { |
John Spurlock | 0ec64c6 | 2013-08-26 15:37:58 -0400 | [diff] [blame] | 191 | if (DEBUG) Slog.w(mTag, "Error posting window state", e); |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 192 | // re-acquire status bar service next time it is needed. |
| 193 | mStatusBarService = null; |
| 194 | } |
| 195 | } |
| 196 | }); |
John Spurlock | c23bd80 | 2013-11-06 12:20:38 -0500 | [diff] [blame] | 197 | return true; |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 198 | } |
John Spurlock | c23bd80 | 2013-11-06 12:20:38 -0500 | [diff] [blame] | 199 | return false; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 200 | } |
| 201 | |
| 202 | public boolean checkHiddenLw() { |
Adrian Roos | 76d2fe4 | 2015-07-09 14:54:08 -0700 | [diff] [blame] | 203 | if (mWin != null && mWin.isDrawnLw()) { |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 204 | if (!mWin.isVisibleLw() && !mWin.isAnimatingLw()) { |
John Spurlock | 7edfbca | 2013-09-14 11:58:55 -0400 | [diff] [blame] | 205 | updateStateLw(StatusBarManager.WINDOW_STATE_HIDDEN); |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 206 | } |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 207 | if (mTransientBarState == TRANSIENT_BAR_HIDING && !mWin.isVisibleLw()) { |
| 208 | // Finished animating out, clean up and reset style |
| 209 | setTransientBarState(TRANSIENT_BAR_NONE); |
| 210 | if (mPendingShow) { |
| 211 | setBarShowingLw(true); |
| 212 | mPendingShow = false; |
| 213 | } |
| 214 | return true; |
| 215 | } |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 216 | } |
| 217 | return false; |
| 218 | } |
| 219 | |
| 220 | public boolean checkShowTransientBarLw() { |
| 221 | if (mTransientBarState == TRANSIENT_BAR_SHOWING) { |
| 222 | if (DEBUG) Slog.d(mTag, "Not showing transient bar, already shown"); |
| 223 | return false; |
John Spurlock | f25706f | 2013-11-07 18:02:43 -0500 | [diff] [blame] | 224 | } else if (mTransientBarState == TRANSIENT_BAR_SHOW_REQUESTED) { |
| 225 | if (DEBUG) Slog.d(mTag, "Not showing transient bar, already requested"); |
| 226 | return false; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 227 | } else if (mWin == null) { |
| 228 | if (DEBUG) Slog.d(mTag, "Not showing transient bar, bar doesn't exist"); |
| 229 | return false; |
| 230 | } else if (mWin.isDisplayedLw()) { |
| 231 | if (DEBUG) Slog.d(mTag, "Not showing transient bar, bar already visible"); |
| 232 | return false; |
| 233 | } else { |
| 234 | return true; |
| 235 | } |
| 236 | } |
| 237 | |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 238 | public int updateVisibilityLw(boolean transientAllowed, int oldVis, int vis) { |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 239 | if (mWin == null) return vis; |
John Spurlock | f25706f | 2013-11-07 18:02:43 -0500 | [diff] [blame] | 240 | if (isTransientShowing() || isTransientShowRequested()) { // transient bar requested |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 241 | if (transientAllowed) { |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 242 | vis |= mTransientFlag; |
| 243 | if ((oldVis & mTransientFlag) == 0) { |
John Spurlock | 5b9145b | 2013-08-20 15:13:47 -0400 | [diff] [blame] | 244 | vis |= mUnhideFlag; // tell sysui we're ready to unhide |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 245 | } |
John Spurlock | f25706f | 2013-11-07 18:02:43 -0500 | [diff] [blame] | 246 | setTransientBarState(TRANSIENT_BAR_SHOWING); // request accepted |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 247 | } else { |
| 248 | setTransientBarState(TRANSIENT_BAR_NONE); // request denied |
| 249 | } |
| 250 | } |
Selim Cinek | 4a4a2bddc | 2015-05-07 12:50:19 -0700 | [diff] [blame] | 251 | if (mShowTransparent) { |
Jorim Jaggi | 4fa7892 | 2015-11-30 17:13:56 -0800 | [diff] [blame] | 252 | vis |= mTransparentFlag; |
Selim Cinek | 4a4a2bddc | 2015-05-07 12:50:19 -0700 | [diff] [blame] | 253 | if (mSetUnHideFlagWhenNextTransparent) { |
| 254 | vis |= mUnhideFlag; |
| 255 | mSetUnHideFlagWhenNextTransparent = false; |
| 256 | } |
| 257 | } |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 258 | if (mTransientBarState != TRANSIENT_BAR_NONE) { |
| 259 | vis |= mTransientFlag; // ignore clear requests until transition completes |
| 260 | vis &= ~View.SYSTEM_UI_FLAG_LOW_PROFILE; // never show transient bars in low profile |
| 261 | } |
Adrian Roos | ea56251 | 2014-05-05 13:33:03 +0200 | [diff] [blame] | 262 | if ((vis & mTranslucentFlag) != 0 || (oldVis & mTranslucentFlag) != 0 || |
Jorim Jaggi | 4fa7892 | 2015-11-30 17:13:56 -0800 | [diff] [blame] | 263 | ((vis | oldVis) & mTransparentFlag) != 0) { |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 264 | mLastTranslucent = SystemClock.uptimeMillis(); |
John Spurlock | b77edbf | 2013-08-21 21:04:12 -0400 | [diff] [blame] | 265 | } |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 266 | return vis; |
| 267 | } |
| 268 | |
| 269 | private void setTransientBarState(int state) { |
| 270 | if (mWin != null && state != mTransientBarState) { |
John Spurlock | b77edbf | 2013-08-21 21:04:12 -0400 | [diff] [blame] | 271 | if (mTransientBarState == TRANSIENT_BAR_SHOWING || state == TRANSIENT_BAR_SHOWING) { |
John Spurlock | bd95740 | 2013-10-03 11:38:39 -0400 | [diff] [blame] | 272 | mLastTranslucent = SystemClock.uptimeMillis(); |
John Spurlock | b77edbf | 2013-08-21 21:04:12 -0400 | [diff] [blame] | 273 | } |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 274 | mTransientBarState = state; |
John Spurlock | 0ec64c6 | 2013-08-26 15:37:58 -0400 | [diff] [blame] | 275 | if (DEBUG) Slog.d(mTag, "mTransientBarState: " + transientBarStateToString(state)); |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 276 | } |
| 277 | } |
| 278 | |
Jorim Jaggi | 24bec7c | 2015-02-04 12:40:14 +0100 | [diff] [blame] | 279 | protected IStatusBarService getStatusBarService() { |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 280 | synchronized (mServiceAquireLock) { |
| 281 | if (mStatusBarService == null) { |
| 282 | mStatusBarService = IStatusBarService.Stub.asInterface( |
| 283 | ServiceManager.getService("statusbar")); |
| 284 | } |
| 285 | return mStatusBarService; |
| 286 | } |
| 287 | } |
| 288 | |
| 289 | private static String transientBarStateToString(int state) { |
| 290 | if (state == TRANSIENT_BAR_HIDING) return "TRANSIENT_BAR_HIDING"; |
| 291 | if (state == TRANSIENT_BAR_SHOWING) return "TRANSIENT_BAR_SHOWING"; |
John Spurlock | f25706f | 2013-11-07 18:02:43 -0500 | [diff] [blame] | 292 | if (state == TRANSIENT_BAR_SHOW_REQUESTED) return "TRANSIENT_BAR_SHOW_REQUESTED"; |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 293 | if (state == TRANSIENT_BAR_NONE) return "TRANSIENT_BAR_NONE"; |
| 294 | throw new IllegalArgumentException("Unknown state " + state); |
| 295 | } |
| 296 | |
| 297 | public void dump(PrintWriter pw, String prefix) { |
| 298 | if (mWin != null) { |
John Spurlock | 0ec64c6 | 2013-08-26 15:37:58 -0400 | [diff] [blame] | 299 | pw.print(prefix); pw.println(mTag); |
John Spurlock | d4e6575 | 2013-08-28 14:17:09 -0400 | [diff] [blame] | 300 | pw.print(prefix); pw.print(" "); pw.print("mState"); pw.print('='); |
John Spurlock | 0ec64c6 | 2013-08-26 15:37:58 -0400 | [diff] [blame] | 301 | pw.println(StatusBarManager.windowStateToString(mState)); |
John Spurlock | d4e6575 | 2013-08-28 14:17:09 -0400 | [diff] [blame] | 302 | pw.print(prefix); pw.print(" "); pw.print("mTransientBar"); pw.print('='); |
John Spurlock | 27735a4 | 2013-08-14 17:57:38 -0400 | [diff] [blame] | 303 | pw.println(transientBarStateToString(mTransientBarState)); |
| 304 | } |
| 305 | } |
| 306 | } |