Migrate wm package in sysui to WM shell lib (1/n)
Bug: 161655636 Test: atest WindowManagerShellTests Test: atest SystemUITests Change-Id: I42f13ee7fbb14ba3b7f33ed5654ec72454dc6dba
This commit is contained in:
@@ -14,7 +14,7 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.systemui.wm;
|
||||
package com.android.wm.shell.common;
|
||||
|
||||
import android.os.Handler;
|
||||
import android.os.RemoteException;
|
||||
@@ -14,7 +14,7 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.systemui.wm;
|
||||
package com.android.wm.shell.common;
|
||||
|
||||
import android.annotation.Nullable;
|
||||
import android.content.Context;
|
||||
@@ -28,21 +28,16 @@ import android.view.Display;
|
||||
import android.view.IDisplayWindowListener;
|
||||
import android.view.IWindowManager;
|
||||
|
||||
import com.android.systemui.dagger.qualifiers.Main;
|
||||
import com.android.systemui.wm.DisplayChangeController.OnDisplayChangingListener;
|
||||
import com.android.wm.shell.common.DisplayChangeController.OnDisplayChangingListener;
|
||||
|
||||
import java.util.ArrayList;
|
||||
|
||||
import javax.inject.Inject;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
/**
|
||||
* This module deals with display rotations coming from WM. When WM starts a rotation: after it has
|
||||
* frozen the screen, it will call into this class. This will then call all registered local
|
||||
* controllers and give them a chance to queue up task changes to be applied synchronously with that
|
||||
* rotation.
|
||||
*/
|
||||
@Singleton
|
||||
public class DisplayController {
|
||||
private static final String TAG = "DisplayController";
|
||||
|
||||
@@ -55,7 +50,7 @@ public class DisplayController {
|
||||
private final ArrayList<OnDisplaysChangedListener> mDisplayChangedListeners = new ArrayList<>();
|
||||
|
||||
/**
|
||||
* Get's a display by id from DisplayManager.
|
||||
* Gets a display by id from DisplayManager.
|
||||
*/
|
||||
public Display getDisplay(int displayId) {
|
||||
final DisplayManager displayManager = mContext.getSystemService(DisplayManager.class);
|
||||
@@ -169,10 +164,9 @@ public class DisplayController {
|
||||
}
|
||||
};
|
||||
|
||||
@Inject
|
||||
public DisplayController(Context context, @Main Handler mainHandler,
|
||||
public DisplayController(Context context, Handler handler,
|
||||
IWindowManager wmService) {
|
||||
mHandler = mainHandler;
|
||||
mHandler = handler;
|
||||
mContext = context;
|
||||
mWmService = wmService;
|
||||
mChangeController = new DisplayChangeController(mHandler, mWmService);
|
||||
@@ -14,7 +14,7 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.systemui.wm;
|
||||
package com.android.wm.shell.common;
|
||||
|
||||
import android.animation.Animator;
|
||||
import android.animation.AnimatorListenerAdapter;
|
||||
@@ -40,18 +40,12 @@ import android.view.animation.Interpolator;
|
||||
import android.view.animation.PathInterpolator;
|
||||
|
||||
import com.android.internal.view.IInputMethodManager;
|
||||
import com.android.systemui.TransactionPool;
|
||||
import com.android.systemui.dagger.qualifiers.Main;
|
||||
|
||||
import java.util.ArrayList;
|
||||
|
||||
import javax.inject.Inject;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
/**
|
||||
* Manages IME control at the display-level. This occurs when IME comes up in multi-window mode.
|
||||
*/
|
||||
@Singleton
|
||||
public class DisplayImeController implements DisplayController.OnDisplaysChangedListener {
|
||||
private static final String TAG = "DisplayImeController";
|
||||
|
||||
@@ -66,18 +60,17 @@ public class DisplayImeController implements DisplayController.OnDisplaysChanged
|
||||
private static final int DIRECTION_HIDE = 2;
|
||||
private static final int FLOATING_IME_BOTTOM_INSET = -80;
|
||||
|
||||
SystemWindows mSystemWindows;
|
||||
final Handler mHandler;
|
||||
protected final SystemWindows mSystemWindows;
|
||||
protected final Handler mHandler;
|
||||
final TransactionPool mTransactionPool;
|
||||
|
||||
final SparseArray<PerDisplay> mImePerDisplay = new SparseArray<>();
|
||||
|
||||
final ArrayList<ImePositionProcessor> mPositionProcessors = new ArrayList<>();
|
||||
|
||||
@Inject
|
||||
public DisplayImeController(SystemWindows syswin, DisplayController displayController,
|
||||
@Main Handler mainHandler, TransactionPool transactionPool) {
|
||||
mHandler = mainHandler;
|
||||
Handler handler, TransactionPool transactionPool) {
|
||||
mHandler = handler;
|
||||
mSystemWindows = syswin;
|
||||
mTransactionPool = transactionPool;
|
||||
displayController.addDisplayWindowListener(this);
|
||||
@@ -305,8 +298,8 @@ public class DisplayImeController implements DisplayController.OnDisplaysChanged
|
||||
// pretend the ime has some size just below the screen.
|
||||
mImeFrame.set(newFrame);
|
||||
final int floatingInset = (int) (
|
||||
mSystemWindows.mDisplayController.getDisplayLayout(mDisplayId).density()
|
||||
* FLOATING_IME_BOTTOM_INSET);
|
||||
mSystemWindows.mDisplayController.getDisplayLayout(mDisplayId)
|
||||
.density() * FLOATING_IME_BOTTOM_INSET);
|
||||
mImeFrame.bottom -= floatingInset;
|
||||
} else if (newFrame.height() != 0) {
|
||||
// Don't set a new frame if it's empty and hiding -- this maintains continuity
|
||||
@@ -364,6 +357,7 @@ public class DisplayImeController implements DisplayController.OnDisplaysChanged
|
||||
mAnimation.setInterpolator(INTERPOLATOR);
|
||||
mAnimation.addListener(new AnimatorListenerAdapter() {
|
||||
private boolean mCancelled = false;
|
||||
|
||||
@Override
|
||||
public void onAnimationStart(Animator animation) {
|
||||
SurfaceControl.Transaction t = mTransactionPool.acquire();
|
||||
@@ -386,10 +380,12 @@ public class DisplayImeController implements DisplayController.OnDisplaysChanged
|
||||
t.apply();
|
||||
mTransactionPool.release(t);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onAnimationCancel(Animator animation) {
|
||||
mCancelled = true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onAnimationEnd(Animator animation) {
|
||||
if (DEBUG) Slog.d(TAG, "onAnimationEnd " + mCancelled);
|
||||
@@ -449,18 +445,19 @@ public class DisplayImeController implements DisplayController.OnDisplaysChanged
|
||||
int IME_ANIMATION_NO_ALPHA = 1;
|
||||
|
||||
/** @hide */
|
||||
@IntDef(prefix = { "IME_ANIMATION_" }, value = {
|
||||
@IntDef(prefix = {"IME_ANIMATION_"}, value = {
|
||||
IME_ANIMATION_NO_ALPHA,
|
||||
})
|
||||
@interface ImeAnimationFlags {}
|
||||
@interface ImeAnimationFlags {
|
||||
}
|
||||
|
||||
/**
|
||||
* Called when the IME position is starting to animate.
|
||||
*
|
||||
* @param hiddenTop The y position of the top of the IME surface when it is hidden.
|
||||
* @param shownTop The y position of the top of the IME surface when it is shown.
|
||||
* @param showing {@code true} when we are animating from hidden to shown, {@code false}
|
||||
* when animating from shown to hidden.
|
||||
* @param hiddenTop The y position of the top of the IME surface when it is hidden.
|
||||
* @param shownTop The y position of the top of the IME surface when it is shown.
|
||||
* @param showing {@code true} when we are animating from hidden to shown, {@code false}
|
||||
* when animating from shown to hidden.
|
||||
* @param isFloating {@code true} when the ime is a floating ime (doesn't inset).
|
||||
* @return flags that may alter how ime itself is animated (eg. no-alpha).
|
||||
*/
|
||||
@@ -476,8 +473,8 @@ public class DisplayImeController implements DisplayController.OnDisplaysChanged
|
||||
*
|
||||
* @param imeTop The current y position of the top of the IME surface.
|
||||
*/
|
||||
default void onImePositionChanged(int displayId, int imeTop,
|
||||
SurfaceControl.Transaction t) {}
|
||||
default void onImePositionChanged(int displayId, int imeTop, SurfaceControl.Transaction t) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Called when the IME position is done animating.
|
||||
@@ -485,7 +482,8 @@ public class DisplayImeController implements DisplayController.OnDisplaysChanged
|
||||
* @param cancel {@code true} if this was cancelled. This implies another start is coming.
|
||||
*/
|
||||
default void onImeEndPositioning(int displayId, boolean cancel,
|
||||
SurfaceControl.Transaction t) {}
|
||||
SurfaceControl.Transaction t) {
|
||||
}
|
||||
}
|
||||
|
||||
public IInputMethodManager getImms() {
|
||||
@@ -14,7 +14,7 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.systemui.wm;
|
||||
package com.android.wm.shell.common;
|
||||
|
||||
import static android.content.res.Configuration.ORIENTATION_LANDSCAPE;
|
||||
import static android.content.res.Configuration.ORIENTATION_PORTRAIT;
|
||||
@@ -52,7 +52,7 @@ import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
/**
|
||||
* Contains information about the layout-properties of a display. This refers to internal layout
|
||||
* like insets/cutout/rotation. In general, this can be thought of as the System-UI analog to
|
||||
* like insets/cutout/rotation. In general, this can be thought of as the shell analog to
|
||||
* DisplayPolicy.
|
||||
*/
|
||||
public class DisplayLayout {
|
||||
@@ -345,9 +345,9 @@ public class DisplayLayout {
|
||||
/** Retrieve the statusbar height from resources. */
|
||||
static int getStatusBarHeight(boolean landscape, Resources res) {
|
||||
return landscape ? res.getDimensionPixelSize(
|
||||
com.android.internal.R.dimen.status_bar_height_landscape)
|
||||
: res.getDimensionPixelSize(
|
||||
com.android.internal.R.dimen.status_bar_height_portrait);
|
||||
com.android.internal.R.dimen.status_bar_height_landscape)
|
||||
: res.getDimensionPixelSize(
|
||||
com.android.internal.R.dimen.status_bar_height_portrait);
|
||||
}
|
||||
|
||||
/** Calculate the DisplayCutout for a particular display size/rotation. */
|
||||
@@ -14,7 +14,7 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.systemui.wm;
|
||||
package com.android.wm.shell.common;
|
||||
|
||||
import static android.view.WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED;
|
||||
|
||||
@@ -52,23 +52,19 @@ import com.android.internal.os.IResultReceiver;
|
||||
|
||||
import java.util.HashMap;
|
||||
|
||||
import javax.inject.Inject;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
/**
|
||||
* Represents the "windowing" layer of the System-UI. This layer allows system-ui components to
|
||||
* place and manipulate windows without talking to WindowManager.
|
||||
* Represents the "windowing" layer of the WM Shell. This layer allows shell components to place and
|
||||
* manipulate windows without talking to WindowManager.
|
||||
*/
|
||||
@Singleton
|
||||
public class SystemWindows {
|
||||
private static final String TAG = "SystemWindows";
|
||||
|
||||
private final SparseArray<PerDisplay> mPerDisplay = new SparseArray<>();
|
||||
final HashMap<View, SurfaceControlViewHost> mViewRoots = new HashMap<>();
|
||||
Context mContext;
|
||||
public Context mContext;
|
||||
public IWindowManager mWmService;
|
||||
IWindowSession mSession;
|
||||
DisplayController mDisplayController;
|
||||
IWindowManager mWmService;
|
||||
|
||||
private final DisplayController.OnDisplaysChangedListener mDisplayListener =
|
||||
new DisplayController.OnDisplaysChangedListener() {
|
||||
@@ -88,7 +84,6 @@ public class SystemWindows {
|
||||
public void onDisplayRemoved(int displayId) { }
|
||||
};
|
||||
|
||||
@Inject
|
||||
public SystemWindows(Context context, DisplayController displayController,
|
||||
IWindowManager wmService) {
|
||||
mContext = context;
|
||||
@@ -172,7 +167,7 @@ public class SystemWindows {
|
||||
/**
|
||||
* Get the IWindow token for a specific root.
|
||||
*
|
||||
* @param windowType A window type from {@link android.view.WindowManager}.
|
||||
* @param windowType A window type from {@link WindowManager}.
|
||||
*/
|
||||
IWindow getWindow(int displayId, int windowType) {
|
||||
PerDisplay pd = mPerDisplay.get(displayId);
|
||||
@@ -14,24 +14,19 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.systemui;
|
||||
package com.android.wm.shell.common;
|
||||
|
||||
import android.util.Pools;
|
||||
import android.view.SurfaceControl;
|
||||
|
||||
import javax.inject.Inject;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
/**
|
||||
* Provides a synchronized pool of {@link SurfaceControl.Transaction}s to minimize allocations.
|
||||
*/
|
||||
@Singleton
|
||||
public class TransactionPool {
|
||||
private final Pools.SynchronizedPool<SurfaceControl.Transaction> mTransactionPool =
|
||||
new Pools.SynchronizedPool<>(4);
|
||||
|
||||
@Inject
|
||||
TransactionPool() {
|
||||
public TransactionPool() {
|
||||
}
|
||||
|
||||
/** Gets a transaction from the pool. */
|
||||
@@ -36,9 +36,6 @@ android_test {
|
||||
"libstaticjvmtiagent",
|
||||
],
|
||||
|
||||
sdk_version: "current",
|
||||
platform_apis: true,
|
||||
|
||||
optimize: {
|
||||
enabled: false,
|
||||
},
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) 2019 The Android Open Source Project
|
||||
* Copyright (C) 2020 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.
|
||||
@@ -14,13 +14,11 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.wm.shell.tests;
|
||||
package com.android.wm.shell;
|
||||
|
||||
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||
import androidx.test.filters.SmallTest;
|
||||
|
||||
import com.android.wm.shell.WindowManagerShell;
|
||||
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
|
||||
@@ -14,7 +14,7 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.systemui.wm;
|
||||
package com.android.wm.shell.common;
|
||||
|
||||
import static android.content.res.Configuration.UI_MODE_TYPE_NORMAL;
|
||||
import static android.view.Surface.ROTATION_0;
|
||||
@@ -35,12 +35,11 @@ import android.view.DisplayInfo;
|
||||
import androidx.test.filters.SmallTest;
|
||||
|
||||
import com.android.internal.R;
|
||||
import com.android.systemui.SysuiTestCase;
|
||||
|
||||
import org.junit.Test;
|
||||
|
||||
@SmallTest
|
||||
public class DisplayLayoutTest extends SysuiTestCase {
|
||||
public class DisplayLayoutTest {
|
||||
|
||||
@Test
|
||||
public void testInsets() {
|
||||
@@ -22,6 +22,7 @@ import static com.android.systemui.Dependency.LEAK_REPORT_EMAIL_NAME;
|
||||
import android.content.Context;
|
||||
import android.os.Handler;
|
||||
import android.os.PowerManager;
|
||||
import android.view.IWindowManager;
|
||||
|
||||
import com.android.keyguard.KeyguardViewController;
|
||||
import com.android.systemui.broadcast.BroadcastDispatcher;
|
||||
@@ -67,8 +68,11 @@ import com.android.systemui.statusbar.policy.ConfigurationController;
|
||||
import com.android.systemui.statusbar.policy.DeviceProvisionedController;
|
||||
import com.android.systemui.statusbar.policy.HeadsUpManager;
|
||||
import com.android.systemui.volume.VolumeDialogComponent;
|
||||
import com.android.systemui.wm.DisplayImeController;
|
||||
import com.android.systemui.wm.DisplaySystemBarsController;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayImeController;
|
||||
import com.android.wm.shell.common.SystemWindows;
|
||||
import com.android.wm.shell.common.TransactionPool;
|
||||
|
||||
import javax.inject.Named;
|
||||
import javax.inject.Singleton;
|
||||
@@ -99,10 +103,6 @@ public abstract class CarSystemUIModule {
|
||||
groupManager, configurationController);
|
||||
}
|
||||
|
||||
@Binds
|
||||
abstract DisplayImeController bindDisplayImeController(
|
||||
DisplaySystemBarsController displaySystemBarsController);
|
||||
|
||||
@Singleton
|
||||
@Provides
|
||||
@Named(LEAK_REPORT_EMAIL_NAME)
|
||||
@@ -117,6 +117,31 @@ public abstract class CarSystemUIModule {
|
||||
return new Recents(context, recentsImplementation, commandQueue);
|
||||
}
|
||||
|
||||
@Singleton
|
||||
@Provides
|
||||
static TransactionPool provideTransactionPool() {
|
||||
return new TransactionPool();
|
||||
}
|
||||
|
||||
@Singleton
|
||||
@Provides
|
||||
static DisplayController providerDisplayController(Context context, @Main Handler handler,
|
||||
IWindowManager wmService) {
|
||||
return new DisplayController(context, handler, wmService);
|
||||
}
|
||||
|
||||
@Singleton
|
||||
@Provides
|
||||
static SystemWindows provideSystemWindows(Context context, DisplayController displayController,
|
||||
IWindowManager wmService) {
|
||||
return new SystemWindows(context, displayController, wmService);
|
||||
}
|
||||
|
||||
@Singleton
|
||||
@Binds
|
||||
abstract DisplayImeController bindDisplayImeController(
|
||||
DisplaySystemBarsController displaySystemBarsController);
|
||||
|
||||
@Binds
|
||||
abstract HeadsUpManager bindHeadsUpManagerPhone(HeadsUpManagerPhone headsUpManagerPhone);
|
||||
|
||||
|
||||
@@ -29,8 +29,11 @@ import android.view.WindowInsets;
|
||||
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
|
||||
import com.android.systemui.TransactionPool;
|
||||
import com.android.systemui.dagger.qualifiers.Main;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayImeController;
|
||||
import com.android.wm.shell.common.SystemWindows;
|
||||
import com.android.wm.shell.common.TransactionPool;
|
||||
|
||||
import javax.inject.Inject;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
@@ -33,7 +33,9 @@ import android.view.IWindowManager;
|
||||
import androidx.test.filters.SmallTest;
|
||||
|
||||
import com.android.systemui.SysuiTestCase;
|
||||
import com.android.systemui.TransactionPool;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
import com.android.wm.shell.common.SystemWindows;
|
||||
import com.android.wm.shell.common.TransactionPool;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
@@ -45,7 +45,7 @@ android_library {
|
||||
"WindowManager-Shell",
|
||||
"SystemUIPluginLib",
|
||||
"SystemUISharedLib",
|
||||
"SystemUI-statsd",
|
||||
"SystemUI-statsd",
|
||||
"SettingsLib",
|
||||
"androidx.viewpager2_viewpager2",
|
||||
"androidx.legacy_legacy-support-v4",
|
||||
|
||||
@@ -122,9 +122,9 @@ import com.android.systemui.util.leak.GarbageMonitor;
|
||||
import com.android.systemui.util.leak.LeakDetector;
|
||||
import com.android.systemui.util.leak.LeakReporter;
|
||||
import com.android.systemui.util.sensors.AsyncSensorManager;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.systemui.wm.DisplayImeController;
|
||||
import com.android.systemui.wm.SystemWindows;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayImeController;
|
||||
import com.android.wm.shell.common.SystemWindows;
|
||||
|
||||
import java.util.function.Consumer;
|
||||
|
||||
|
||||
@@ -59,6 +59,7 @@ import com.android.systemui.statusbar.policy.ConfigurationController;
|
||||
import com.android.systemui.statusbar.policy.DeviceProvisionedController;
|
||||
import com.android.systemui.statusbar.policy.DeviceProvisionedControllerImpl;
|
||||
import com.android.systemui.statusbar.policy.HeadsUpManager;
|
||||
import com.android.systemui.wmshell.WindowManagerShellModule;
|
||||
|
||||
import javax.inject.Named;
|
||||
import javax.inject.Singleton;
|
||||
@@ -71,7 +72,7 @@ import dagger.Provides;
|
||||
* A dagger module for injecting default implementations of components of System UI that may be
|
||||
* overridden by the System UI implementation.
|
||||
*/
|
||||
@Module(includes = {DividerModule.class, QSModule.class})
|
||||
@Module(includes = {DividerModule.class, QSModule.class, WindowManagerShellModule.class})
|
||||
public abstract class SystemUIDefaultModule {
|
||||
|
||||
@Singleton
|
||||
|
||||
@@ -27,7 +27,6 @@ import android.graphics.Rect;
|
||||
import android.os.Handler;
|
||||
import android.os.Looper;
|
||||
import android.util.Log;
|
||||
import android.view.Surface;
|
||||
import android.view.SurfaceControl;
|
||||
import android.window.DisplayAreaInfo;
|
||||
import android.window.DisplayAreaOrganizer;
|
||||
@@ -39,7 +38,7 @@ import androidx.annotation.VisibleForTesting;
|
||||
|
||||
import com.android.internal.os.SomeArgs;
|
||||
import com.android.systemui.Dumpable;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
|
||||
import java.io.FileDescriptor;
|
||||
import java.io.PrintWriter;
|
||||
|
||||
@@ -41,8 +41,8 @@ import androidx.annotation.VisibleForTesting;
|
||||
|
||||
import com.android.systemui.R;
|
||||
import com.android.systemui.statusbar.phone.NavigationModeController;
|
||||
import com.android.systemui.wm.DisplayChangeController;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayChangeController;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
|
||||
import javax.inject.Inject;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
@@ -33,8 +33,8 @@ import com.android.systemui.R;
|
||||
import com.android.systemui.model.SysUiState;
|
||||
import com.android.systemui.shared.system.ActivityManagerWrapper;
|
||||
import com.android.systemui.shared.system.TaskStackChangeListener;
|
||||
import com.android.systemui.wm.DisplayChangeController;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayChangeController;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
|
||||
import java.io.FileDescriptor;
|
||||
import java.io.PrintWriter;
|
||||
|
||||
@@ -39,8 +39,8 @@ import android.view.DisplayInfo;
|
||||
import android.view.Gravity;
|
||||
import android.window.WindowContainerTransaction;
|
||||
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.systemui.wm.DisplayLayout;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayLayout;
|
||||
|
||||
import java.io.PrintWriter;
|
||||
|
||||
|
||||
@@ -58,8 +58,8 @@ import android.window.WindowOrganizer;
|
||||
import com.android.internal.os.SomeArgs;
|
||||
import com.android.systemui.pip.phone.PipUpdateThread;
|
||||
import com.android.systemui.stackdivider.Divider;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.wm.shell.R;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
|
||||
import java.io.PrintWriter;
|
||||
import java.util.ArrayList;
|
||||
|
||||
@@ -56,9 +56,8 @@ import com.android.systemui.shared.system.WindowManagerWrapper;
|
||||
import com.android.systemui.statusbar.policy.ConfigurationController;
|
||||
import com.android.systemui.util.DeviceConfigProxy;
|
||||
import com.android.systemui.util.FloatingContentCoordinator;
|
||||
import com.android.systemui.wm.DisplayChangeController;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.systemui.wm.DisplayLayout;
|
||||
import com.android.wm.shell.common.DisplayChangeController;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
|
||||
import java.io.PrintWriter;
|
||||
|
||||
|
||||
@@ -39,16 +39,16 @@ import android.window.WindowOrganizer;
|
||||
import com.android.internal.policy.DividerSnapAlgorithm;
|
||||
import com.android.systemui.R;
|
||||
import com.android.systemui.SystemUI;
|
||||
import com.android.systemui.TransactionPool;
|
||||
import com.android.systemui.recents.Recents;
|
||||
import com.android.systemui.shared.system.ActivityManagerWrapper;
|
||||
import com.android.systemui.shared.system.TaskStackChangeListener;
|
||||
import com.android.systemui.statusbar.policy.KeyguardStateController;
|
||||
import com.android.systemui.wm.DisplayChangeController;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.systemui.wm.DisplayImeController;
|
||||
import com.android.systemui.wm.DisplayLayout;
|
||||
import com.android.systemui.wm.SystemWindows;
|
||||
import com.android.wm.shell.common.DisplayChangeController;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayImeController;
|
||||
import com.android.wm.shell.common.DisplayLayout;
|
||||
import com.android.wm.shell.common.SystemWindows;
|
||||
import com.android.wm.shell.common.TransactionPool;
|
||||
|
||||
import java.io.FileDescriptor;
|
||||
import java.io.PrintWriter;
|
||||
|
||||
@@ -33,8 +33,8 @@ import android.window.WindowOrganizer;
|
||||
|
||||
import androidx.annotation.Nullable;
|
||||
|
||||
import com.android.systemui.TransactionPool;
|
||||
import com.android.systemui.wm.DisplayImeController;
|
||||
import com.android.wm.shell.common.DisplayImeController;
|
||||
import com.android.wm.shell.common.TransactionPool;
|
||||
|
||||
class DividerImeController implements DisplayImeController.ImePositionProcessor {
|
||||
private static final String TAG = "DividerImeController";
|
||||
|
||||
@@ -19,13 +19,13 @@ package com.android.systemui.stackdivider;
|
||||
import android.content.Context;
|
||||
import android.os.Handler;
|
||||
|
||||
import com.android.systemui.TransactionPool;
|
||||
import com.android.systemui.dagger.qualifiers.Main;
|
||||
import com.android.systemui.recents.Recents;
|
||||
import com.android.systemui.statusbar.policy.KeyguardStateController;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.systemui.wm.DisplayImeController;
|
||||
import com.android.systemui.wm.SystemWindows;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayImeController;
|
||||
import com.android.wm.shell.common.SystemWindows;
|
||||
import com.android.wm.shell.common.TransactionPool;
|
||||
|
||||
import java.util.Optional;
|
||||
|
||||
|
||||
@@ -32,7 +32,7 @@ import android.os.Binder;
|
||||
import android.view.View;
|
||||
import android.view.WindowManager;
|
||||
|
||||
import com.android.systemui.wm.SystemWindows;
|
||||
import com.android.wm.shell.common.SystemWindows;
|
||||
|
||||
/**
|
||||
* Manages the window parameters of the docked stack divider.
|
||||
|
||||
@@ -34,7 +34,7 @@ import android.window.WindowContainerTransaction;
|
||||
|
||||
import com.android.internal.policy.DividerSnapAlgorithm;
|
||||
import com.android.internal.policy.DockedDividerUtils;
|
||||
import com.android.systemui.wm.DisplayLayout;
|
||||
import com.android.wm.shell.common.DisplayLayout;
|
||||
|
||||
/**
|
||||
* Handles split-screen related internal display layout. In general, this represents the
|
||||
|
||||
@@ -25,7 +25,7 @@ import android.window.WindowOrganizer;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
import com.android.systemui.TransactionPool;
|
||||
import com.android.wm.shell.common.TransactionPool;
|
||||
|
||||
import java.util.ArrayList;
|
||||
|
||||
|
||||
@@ -40,7 +40,7 @@ import android.window.WindowContainerTransaction;
|
||||
import android.window.WindowOrganizer;
|
||||
|
||||
import com.android.internal.annotations.GuardedBy;
|
||||
import com.android.systemui.TransactionPool;
|
||||
import com.android.wm.shell.common.TransactionPool;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
@@ -0,0 +1,67 @@
|
||||
/*
|
||||
* Copyright (C) 2020 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.systemui.wmshell;
|
||||
|
||||
import android.content.Context;
|
||||
import android.os.Handler;
|
||||
import android.view.IWindowManager;
|
||||
|
||||
import com.android.systemui.dagger.qualifiers.Main;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayImeController;
|
||||
import com.android.wm.shell.common.SystemWindows;
|
||||
import com.android.wm.shell.common.TransactionPool;
|
||||
|
||||
import javax.inject.Singleton;
|
||||
|
||||
import dagger.Module;
|
||||
import dagger.Provides;
|
||||
|
||||
/**
|
||||
* Provides dependencies from {@link com.android.wm.shell}.
|
||||
*/
|
||||
@Module
|
||||
// TODO(b/161116823) Clean up dependencies after wm shell migration finished.
|
||||
public class WindowManagerShellModule {
|
||||
@Singleton
|
||||
@Provides
|
||||
static TransactionPool provideTransactionPool() {
|
||||
return new TransactionPool();
|
||||
}
|
||||
|
||||
@Singleton
|
||||
@Provides
|
||||
static DisplayController provideDisplayController(Context context, @Main Handler handler,
|
||||
IWindowManager wmService) {
|
||||
return new DisplayController(context, handler, wmService);
|
||||
}
|
||||
|
||||
@Singleton
|
||||
@Provides
|
||||
static SystemWindows provideSystemWindows(Context context, DisplayController displayController,
|
||||
IWindowManager wmService) {
|
||||
return new SystemWindows(context, displayController, wmService);
|
||||
}
|
||||
|
||||
@Singleton
|
||||
@Provides
|
||||
static DisplayImeController provideDisplayImeController(
|
||||
SystemWindows syswin, DisplayController displayController,
|
||||
@Main Handler mainHandler, TransactionPool transactionPool) {
|
||||
return new DisplayImeController(syswin, displayController, mainHandler, transactionPool);
|
||||
}
|
||||
}
|
||||
@@ -41,7 +41,7 @@ import android.window.WindowContainerToken;
|
||||
|
||||
import androidx.test.filters.SmallTest;
|
||||
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Ignore;
|
||||
|
||||
@@ -33,7 +33,7 @@ import androidx.test.platform.app.InstrumentationRegistry;
|
||||
|
||||
import com.android.systemui.model.SysUiState;
|
||||
import com.android.systemui.statusbar.phone.NavigationModeController;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
@@ -33,7 +33,7 @@ import android.view.Display;
|
||||
import androidx.test.filters.SmallTest;
|
||||
|
||||
import com.android.systemui.model.SysUiState;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
@@ -31,7 +31,7 @@ import androidx.test.platform.app.InstrumentationRegistry;
|
||||
|
||||
import com.android.systemui.model.SysUiState;
|
||||
import com.android.systemui.statusbar.phone.NavigationModeController;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
@@ -33,7 +33,7 @@ import android.view.Gravity;
|
||||
import androidx.test.filters.SmallTest;
|
||||
|
||||
import com.android.systemui.SysuiTestCase;
|
||||
import com.android.systemui.wm.DisplayController;
|
||||
import com.android.wm.shell.common.DisplayController;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
Reference in New Issue
Block a user