Merge "Fix app crash while running in second display" into qt-dev

am: 0fcd8ceef8

Change-Id: I65a04a80d5fe47f7ed41c06569387a2ea3ec45a1
This commit is contained in:
sanryhuang
2019-04-29 19:13:58 -07:00
committed by android-build-merger
3 changed files with 91 additions and 2 deletions

View File

@@ -25,6 +25,8 @@ import android.view.WindowManager;
import android.view.WindowManagerImpl;
import android.view.contentcapture.ContentCaptureManager;
import com.android.internal.annotations.VisibleForTesting;
import java.lang.ref.WeakReference;
/**
@@ -34,7 +36,8 @@ import java.lang.ref.WeakReference;
*
* @hide
*/
class DecorContext extends ContextThemeWrapper {
@VisibleForTesting(visibility = VisibleForTesting.Visibility.PACKAGE)
public class DecorContext extends ContextThemeWrapper {
private PhoneWindow mPhoneWindow;
private WindowManager mWindowManager;
private Resources mActivityResources;
@@ -42,8 +45,9 @@ class DecorContext extends ContextThemeWrapper {
private WeakReference<Context> mActivityContext;
@VisibleForTesting
public DecorContext(Context context, Context activityContext) {
super(context, null);
super(context.createDisplayContext(activityContext.getDisplay()), null);
mActivityContext = new WeakReference<>(activityContext);
mActivityResources = activityContext.getResources();
}

View File

@@ -1943,6 +1943,13 @@ public class DecorView extends FrameLayout implements RootViewSurfaceTaker, Wind
initializeElevation();
}
@Override
public void onMovedToDisplay(int displayId, Configuration config) {
super.onMovedToDisplay(displayId, config);
// Have to explicitly update displayId because it may use DecorContext
getContext().updateDisplay(displayId);
}
/**
* Determines if the workspace is entirely covered by the window.
* @return {@code true} when the window is filling the entire screen/workspace.

View File

@@ -0,0 +1,78 @@
/*
* Copyright (C) 2019 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.internal.policy;
import static android.view.Display.DEFAULT_DISPLAY;
import static org.junit.Assert.assertEquals;
import android.content.Context;
import android.hardware.display.DisplayManagerGlobal;
import android.platform.test.annotations.Presubmit;
import android.view.Display;
import android.view.DisplayAdjustments;
import android.view.DisplayInfo;
import android.view.WindowManager;
import androidx.test.InstrumentationRegistry;
import androidx.test.filters.SmallTest;
import androidx.test.runner.AndroidJUnit4;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
/**
* Tests {@link DecorContext}.
*/
@SmallTest
@Presubmit
@RunWith(AndroidJUnit4.class)
public final class DecorContextTest {
private Context mContext;
private static final int EXTERNAL_DISPLAY = DEFAULT_DISPLAY + 1;
@Before
public void setUp() throws Exception {
mContext = InstrumentationRegistry.getContext();
}
@Test
public void testDecorContextWithDefaultDisplay() {
DecorContext context = new DecorContext(mContext.getApplicationContext(), mContext);
assertDecorContextDisplay(DEFAULT_DISPLAY, context);
}
@Test
public void testDecorContextWithExternalDisplay() {
Display display = new Display(DisplayManagerGlobal.getInstance(), EXTERNAL_DISPLAY,
new DisplayInfo(), DisplayAdjustments.DEFAULT_DISPLAY_ADJUSTMENTS);
DecorContext context = new DecorContext(mContext.getApplicationContext(),
mContext.createDisplayContext(display));
assertDecorContextDisplay(EXTERNAL_DISPLAY, context);
}
private static void assertDecorContextDisplay(int expectedDisplayId,
DecorContext decorContext) {
WindowManager wm = (WindowManager) decorContext.getSystemService(Context.WINDOW_SERVICE);
Display associatedDisplay = wm.getDefaultDisplay();
assertEquals(expectedDisplayId, associatedDisplay.getDisplayId());
}
}