Merge "Fix app crash while running in second display" into qt-dev
am: 0fcd8ceef8
Change-Id: I65a04a80d5fe47f7ed41c06569387a2ea3ec45a1
This commit is contained in:
@@ -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();
|
||||
}
|
||||
|
||||
@@ -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.
|
||||
|
||||
@@ -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());
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user