Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit d6565502 authored by sanryhuang's avatar sanryhuang Committed by android-build-merger
Browse files

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

am: 0fcd8cee

Change-Id: I65a04a80d5fe47f7ed41c06569387a2ea3ec45a1
parents 73bbed32 0fcd8cee
Loading
Loading
Loading
Loading
+6 −2
Original line number Diff line number Diff line
@@ -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();
    }
+7 −0
Original line number Diff line number Diff line
@@ -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.
+78 −0
Original line number Diff line number Diff line
/*
 * 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());
    }
}