Merge "Fix One-handed mode Settings Main Switch does not update its state correctly" into sc-dev

This commit is contained in:
Jason Chang
2021-06-17 13:00:52 +00:00
committed by Android (Google) Code Review
2 changed files with 49 additions and 1 deletions

View File

@@ -17,17 +17,30 @@
package com.android.settings.gestures; package com.android.settings.gestures;
import android.content.Context; import android.content.Context;
import android.net.Uri;
import androidx.preference.PreferenceScreen;
import com.android.settings.widget.SettingsMainSwitchPreferenceController; import com.android.settings.widget.SettingsMainSwitchPreferenceController;
import com.android.settingslib.core.lifecycle.LifecycleObserver;
import com.android.settingslib.core.lifecycle.events.OnStart;
import com.android.settingslib.core.lifecycle.events.OnStop;
import com.android.settingslib.widget.MainSwitchPreference;
/** /**
* The controller to handle one-handed mode main switch enable or disable state. * The controller to handle one-handed mode main switch enable or disable state.
**/ **/
public class OneHandedMainSwitchPreferenceController extends public class OneHandedMainSwitchPreferenceController extends
SettingsMainSwitchPreferenceController { SettingsMainSwitchPreferenceController implements OneHandedSettingsUtils.TogglesCallback,
LifecycleObserver, OnStart, OnStop {
private final OneHandedSettingsUtils mUtils;
private MainSwitchPreference mPreference;
public OneHandedMainSwitchPreferenceController(Context context, String preferenceKey) { public OneHandedMainSwitchPreferenceController(Context context, String preferenceKey) {
super(context, preferenceKey); super(context, preferenceKey);
mUtils = new OneHandedSettingsUtils(context);
} }
@Override @Override
@@ -53,4 +66,30 @@ public class OneHandedMainSwitchPreferenceController extends
OneHandedSettingsUtils.setOneHandedModeEnabled(mContext, isChecked); OneHandedSettingsUtils.setOneHandedModeEnabled(mContext, isChecked);
return true; return true;
} }
@Override
public void displayPreference(PreferenceScreen screen) {
super.displayPreference(screen);
mPreference = screen.findPreference(getPreferenceKey());
}
@Override
public void onStart() {
mUtils.registerToggleAwareObserver(this);
}
@Override
public void onStop() {
mUtils.unregisterToggleAwareObserver();
}
@Override
public void onChange(Uri uri) {
if (mPreference == null) {
return;
}
if (uri.equals(OneHandedSettingsUtils.ONE_HANDED_MODE_ENABLED_URI)) {
mPreference.setChecked(isChecked());
}
}
} }

View File

@@ -56,6 +56,15 @@ public class OneHandedMainSwitchPreferenceControllerTest {
assertThat(OneHandedSettingsUtils.isOneHandedModeEnabled(mContext)).isTrue(); assertThat(OneHandedSettingsUtils.isOneHandedModeEnabled(mContext)).isTrue();
} }
@Test
public void isChecked_setOneHandedModeEnabled_shouldReturnTrue() {
SystemProperties.set(OneHandedSettingsUtils.SUPPORT_ONE_HANDED_MODE, "true");
mUtils.setNavigationBarMode(mContext, "2" /* fully gestural */);
OneHandedSettingsUtils.setOneHandedModeEnabled(mContext, true);
assertThat(mController.isChecked()).isTrue();
}
@Test @Test
public void getAvailabilityStatus_setSupportOneHandedModeProperty_shouldAvailable() { public void getAvailabilityStatus_setSupportOneHandedModeProperty_shouldAvailable() {
SystemProperties.set(OneHandedSettingsUtils.SUPPORT_ONE_HANDED_MODE, "true"); SystemProperties.set(OneHandedSettingsUtils.SUPPORT_ONE_HANDED_MODE, "true");