Merge "AOD: Fix navbar flicker when transitioning to AOD" into oc-dr1-dev am: 1cbfe74fc2 am: 63953ef041

am: 4b559a3b69

Change-Id: I7d319fa53fddc2f5386410cda6e8f25fc01f8d1b
This commit is contained in:
Adrian Roos
2017-08-12 00:48:47 +00:00
committed by android-build-merger
3 changed files with 67 additions and 8 deletions

View File

@@ -64,17 +64,13 @@ public class DozeFactory {
createDozeTriggers(context, sensorManager, host, alarmManager, config, params,
handler, wakeLock, machine),
createDozeUi(context, host, wakeLock, machine, handler, alarmManager),
createDozeScreenState(wrappedService),
new DozeScreenState(wrappedService, handler),
createDozeScreenBrightness(context, wrappedService, sensorManager, host, handler),
});
return machine;
}
private DozeMachine.Part createDozeScreenState(DozeMachine.Service service) {
return new DozeScreenState(service);
}
private DozeMachine.Part createDozeScreenBrightness(Context context,
DozeMachine.Service service, SensorManager sensorManager, DozeHost host,
Handler handler) {

View File

@@ -16,7 +16,7 @@
package com.android.systemui.doze;
import android.content.Context;
import android.os.Handler;
import android.view.Display;
/**
@@ -24,16 +24,46 @@ import android.view.Display;
*/
public class DozeScreenState implements DozeMachine.Part {
private final DozeMachine.Service mDozeService;
private final Handler mHandler;
private int mPendingScreenState = Display.STATE_UNKNOWN;
private Runnable mApplyPendingScreenState = this::applyPendingScreenState;
public DozeScreenState(DozeMachine.Service service) {
public DozeScreenState(DozeMachine.Service service, Handler handler) {
mDozeService = service;
mHandler = handler;
}
@Override
public void transitionTo(DozeMachine.State oldState, DozeMachine.State newState) {
int screenState = newState.screenState();
if (screenState == Display.STATE_UNKNOWN) {
// We'll keep it in the existing state
return;
}
boolean messagePending = mHandler.hasCallbacks(mApplyPendingScreenState);
if (messagePending || oldState == DozeMachine.State.INITIALIZED) {
// During initialization, we hide the navigation bar. That is however only applied after
// a traversal; setting the screen state here is immediate however, so it can happen
// that the screen turns on again before the navigation bar is hidden. To work around
// that, wait for a traversal to happen before applying the initial screen state.
mPendingScreenState = screenState;
if (!messagePending) {
mHandler.post(mApplyPendingScreenState);
}
return;
}
applyScreenState(screenState);
}
private void applyPendingScreenState() {
applyScreenState(mPendingScreenState);
mPendingScreenState = Display.STATE_UNKNOWN;
}
private void applyScreenState(int screenState) {
if (screenState != Display.STATE_UNKNOWN) {
mDozeService.setDozeScreenState(screenState);
mPendingScreenState = Display.STATE_UNKNOWN;
}
}
}

View File

@@ -24,7 +24,14 @@ import static com.android.systemui.doze.DozeMachine.State.INITIALIZED;
import static com.android.systemui.doze.DozeMachine.State.UNINITIALIZED;
import static org.junit.Assert.assertEquals;
import static org.mockito.ArgumentMatchers.any;
import static org.mockito.ArgumentMatchers.anyLong;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.verify;
import android.os.Handler;
import android.os.Looper;
import android.os.Message;
import android.support.test.filters.SmallTest;
import android.support.test.runner.AndroidJUnit4;
import android.view.Display;
@@ -41,11 +48,13 @@ public class DozeScreenStateTest extends SysuiTestCase {
DozeServiceFake mServiceFake;
DozeScreenState mScreen;
private ImmediateHandler mHandler;
@Before
public void setUp() throws Exception {
mServiceFake = new DozeServiceFake();
mScreen = new DozeScreenState(mServiceFake);
mHandler = spy(new ImmediateHandler(Looper.getMainLooper()));
mScreen = new DozeScreenState(mServiceFake, mHandler);
}
@Test
@@ -95,4 +104,28 @@ public class DozeScreenStateTest extends SysuiTestCase {
assertEquals(Display.STATE_OFF, mServiceFake.screenState);
}
@Test
public void test_postedToHandler() {
mScreen.transitionTo(UNINITIALIZED, INITIALIZED);
mScreen.transitionTo(INITIALIZED, DOZE_AOD);
verify(mHandler).sendMessageAtTime(any(), anyLong());
}
private static class ImmediateHandler extends Handler {
public ImmediateHandler(Looper looper) {
super(looper);
}
@Override
public boolean sendMessageAtTime(Message msg, long uptimeMillis) {
Runnable callback = msg.getCallback();
if (callback != null) {
callback.run();
return false;
}
return super.sendMessageAtTime(msg, uptimeMillis);
}
}
}