[Dev option] Add a dev option to enable DW.
Default value of this dev options solely depends on enable_desktop_windowing_mode, which is intended Toggle is shown only if DW is eligible on device Currently this option only overrides features guarded by enable_desktop_windowing_mode, later on it will be used to override a few other DW features Test: Added tests. Locally tested CUJs Bug: 348186127 Bug: 348193756 Flag: com.android.window.flags.show_desktop_windowing_dev_option Change-Id: I1c1f946b586a5ca0440b29879925ba1a624717aa
This commit is contained in:
@@ -16,11 +16,12 @@
|
||||
|
||||
package com.android.settings.development;
|
||||
|
||||
import static android.provider.Settings.Global.DEVELOPMENT_FORCE_DESKTOP_MODE_ON_EXTERNAL_DISPLAYS;
|
||||
import static android.provider.Settings.Global.DEVELOPMENT_OVERRIDE_DESKTOP_MODE_FEATURES;
|
||||
|
||||
import android.content.Context;
|
||||
import android.os.Build;
|
||||
import android.os.SystemProperties;
|
||||
import android.provider.Settings;
|
||||
import android.util.Log;
|
||||
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
@@ -30,19 +31,29 @@ import androidx.preference.TwoStatePreference;
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.core.PreferenceControllerMixin;
|
||||
import com.android.settingslib.development.DeveloperOptionsPreferenceController;
|
||||
import com.android.window.flags.Flags;
|
||||
|
||||
/**
|
||||
* Preference controller to control Desktop mode features
|
||||
*/
|
||||
public class DesktopModePreferenceController extends DeveloperOptionsPreferenceController
|
||||
implements Preference.OnPreferenceChangeListener, PreferenceControllerMixin,
|
||||
RebootConfirmationDialogHost {
|
||||
|
||||
private static final String FORCE_DESKTOP_MODE_KEY = "force_desktop_mode_on_external_displays";
|
||||
private static final String OVERRIDE_DESKTOP_MODE_FEATURES_KEY =
|
||||
"override_desktop_mode_features";
|
||||
|
||||
private static final String TAG = "DesktopModePreferenceController";
|
||||
|
||||
@VisibleForTesting
|
||||
static final int SETTING_VALUE_OFF = 0;
|
||||
@VisibleForTesting
|
||||
static final int SETTING_VALUE_ON = 1;
|
||||
@VisibleForTesting
|
||||
static final int SETTING_VALUE_UNSET = -1;
|
||||
|
||||
@Nullable private final DevelopmentSettingsDashboardFragment mFragment;
|
||||
@Nullable
|
||||
private final DevelopmentSettingsDashboardFragment mFragment;
|
||||
|
||||
public DesktopModePreferenceController(
|
||||
Context context, @Nullable DevelopmentSettingsDashboardFragment fragment) {
|
||||
@@ -50,41 +61,60 @@ public class DesktopModePreferenceController extends DeveloperOptionsPreferenceC
|
||||
mFragment = fragment;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isAvailable() {
|
||||
return isDeviceEligibleForDesktopMode() && Flags.showDesktopWindowingDevOption();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getPreferenceKey() {
|
||||
return FORCE_DESKTOP_MODE_KEY;
|
||||
return OVERRIDE_DESKTOP_MODE_FEATURES_KEY;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||
final boolean isEnabled = (Boolean) newValue;
|
||||
Settings.Global.putInt(mContext.getContentResolver(),
|
||||
DEVELOPMENT_FORCE_DESKTOP_MODE_ON_EXTERNAL_DISPLAYS,
|
||||
DEVELOPMENT_OVERRIDE_DESKTOP_MODE_FEATURES,
|
||||
isEnabled ? SETTING_VALUE_ON : SETTING_VALUE_OFF);
|
||||
if (isEnabled) {
|
||||
if (mFragment != null) {
|
||||
RebootConfirmationDialogFragment.show(
|
||||
mFragment, R.string.reboot_dialog_force_desktop_mode, this);
|
||||
mFragment, R.string.reboot_dialog_override_desktop_mode, this);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateState(Preference preference) {
|
||||
// Use overridden state, if not present, then use default state
|
||||
final boolean shouldDevOptionBeEnabledByDefault = Flags.enableDesktopWindowingMode();
|
||||
final int mode = Settings.Global.getInt(mContext.getContentResolver(),
|
||||
DEVELOPMENT_FORCE_DESKTOP_MODE_ON_EXTERNAL_DISPLAYS, SETTING_VALUE_OFF);
|
||||
((TwoStatePreference) mPreference).setChecked(mode != SETTING_VALUE_OFF);
|
||||
DEVELOPMENT_OVERRIDE_DESKTOP_MODE_FEATURES,
|
||||
shouldDevOptionBeEnabledByDefault ? SETTING_VALUE_ON : SETTING_VALUE_OFF);
|
||||
final boolean shouldDevOptionBeEnabled = switch (mode) {
|
||||
case SETTING_VALUE_OFF -> false;
|
||||
case SETTING_VALUE_ON -> true;
|
||||
case SETTING_VALUE_UNSET -> shouldDevOptionBeEnabledByDefault;
|
||||
default -> {
|
||||
Log.w(TAG, "Invalid override for desktop mode: " + mode);
|
||||
yield shouldDevOptionBeEnabledByDefault;
|
||||
}
|
||||
};
|
||||
((TwoStatePreference) mPreference).setChecked(shouldDevOptionBeEnabled);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onDeveloperOptionsSwitchDisabled() {
|
||||
super.onDeveloperOptionsSwitchDisabled();
|
||||
Settings.Global.putInt(mContext.getContentResolver(),
|
||||
DEVELOPMENT_FORCE_DESKTOP_MODE_ON_EXTERNAL_DISPLAYS, SETTING_VALUE_OFF);
|
||||
((TwoStatePreference) mPreference).setChecked(false);
|
||||
DEVELOPMENT_OVERRIDE_DESKTOP_MODE_FEATURES, SETTING_VALUE_UNSET);
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
String getBuildType() {
|
||||
return Build.TYPE;
|
||||
private boolean isDeviceEligibleForDesktopMode() {
|
||||
boolean enforceDeviceRestrictions = SystemProperties.getBoolean(
|
||||
"persist.wm.debug.desktop_mode_enforce_device_restrictions", true);
|
||||
boolean isDesktopModeSupported = mContext.getResources().getBoolean(
|
||||
com.android.internal.R.bool.config_isDesktopModeSupported);
|
||||
return !enforceDeviceRestrictions || isDesktopModeSupported;
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user