Explicitly request focus after button pressed
Don't use focusableInTouchMode, it was causing focus/clickability issues when the device wasn't in touch mode. Test: manually tap button (tap works first try) Test: turn on talkback and toggle buttons, also try toggling QS tile while on the Settings page - doesn't reannounce state Fixes: 158717450 Change-Id: I785d0200dd61235aa3308a8588f9ee998e7cb6e5
This commit is contained in:
@@ -24,7 +24,6 @@
|
|||||||
<Button
|
<Button
|
||||||
android:id="@+id/night_display_turn_on_button"
|
android:id="@+id/night_display_turn_on_button"
|
||||||
style="@style/ActionPrimaryButton"
|
style="@style/ActionPrimaryButton"
|
||||||
android:focusableInTouchMode="true"
|
|
||||||
android:layout_marginStart="@dimen/screen_margin_sides"
|
android:layout_marginStart="@dimen/screen_margin_sides"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
@@ -33,7 +32,6 @@
|
|||||||
<Button
|
<Button
|
||||||
android:id="@+id/night_display_turn_off_button"
|
android:id="@+id/night_display_turn_off_button"
|
||||||
style="@style/ActionSecondaryButton"
|
style="@style/ActionSecondaryButton"
|
||||||
android:focusableInTouchMode="true"
|
|
||||||
android:layout_marginStart="@dimen/screen_margin_sides"
|
android:layout_marginStart="@dimen/screen_margin_sides"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
@@ -38,7 +38,6 @@
|
|||||||
android:layout_marginTop="@dimen/zen_mode_settings_button_margin_vertical"
|
android:layout_marginTop="@dimen/zen_mode_settings_button_margin_vertical"
|
||||||
android:layout_marginBottom="@dimen/zen_mode_settings_button_margin_vertical"
|
android:layout_marginBottom="@dimen/zen_mode_settings_button_margin_vertical"
|
||||||
android:text="@string/zen_mode_button_turn_on"
|
android:text="@string/zen_mode_button_turn_on"
|
||||||
android:focusableInTouchMode="true"
|
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"/>
|
android:layout_height="wrap_content"/>
|
||||||
|
|
||||||
@@ -50,7 +49,6 @@
|
|||||||
android:layout_marginTop="@dimen/zen_mode_settings_button_margin_vertical"
|
android:layout_marginTop="@dimen/zen_mode_settings_button_margin_vertical"
|
||||||
android:layout_marginBottom="@dimen/zen_mode_settings_button_margin_vertical"
|
android:layout_marginBottom="@dimen/zen_mode_settings_button_margin_vertical"
|
||||||
android:text="@string/zen_mode_button_turn_off"
|
android:text="@string/zen_mode_button_turn_off"
|
||||||
android:focusableInTouchMode="true"
|
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"/>
|
android:layout_height="wrap_content"/>
|
||||||
|
|
||||||
|
@@ -16,6 +16,8 @@
|
|||||||
|
|
||||||
package com.android.settings.display;
|
package com.android.settings.display;
|
||||||
|
|
||||||
|
import static android.view.accessibility.AccessibilityEvent.TYPE_VIEW_FOCUSED;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.hardware.display.ColorDisplayManager;
|
import android.hardware.display.ColorDisplayManager;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
@@ -39,20 +41,16 @@ public class NightDisplayActivationPreferenceController extends TogglePreference
|
|||||||
private NightDisplayTimeFormatter mTimeFormatter;
|
private NightDisplayTimeFormatter mTimeFormatter;
|
||||||
private LayoutPreference mPreference;
|
private LayoutPreference mPreference;
|
||||||
|
|
||||||
// Night light can also be toggled from QS. If night light wasn't toggled by this preference,
|
|
||||||
// don't requestFocus
|
|
||||||
private boolean mButtonTriggered = false;
|
|
||||||
private Button mTurnOffButton;
|
private Button mTurnOffButton;
|
||||||
private Button mTurnOnButton;
|
private Button mTurnOnButton;
|
||||||
|
|
||||||
private final OnClickListener mListener = new OnClickListener() {
|
private final OnClickListener mListener = new OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
mButtonTriggered = true;
|
|
||||||
mMetricsFeatureProvider.logClickedPreference(mPreference, getMetricsCategory());
|
mMetricsFeatureProvider.logClickedPreference(mPreference, getMetricsCategory());
|
||||||
mColorDisplayManager.setNightDisplayActivated(
|
mColorDisplayManager.setNightDisplayActivated(
|
||||||
!mColorDisplayManager.isNightDisplayActivated());
|
!mColorDisplayManager.isNightDisplayActivated());
|
||||||
updateStateInternal();
|
updateStateInternal(true);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -93,7 +91,7 @@ public class NightDisplayActivationPreferenceController extends TogglePreference
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final void updateState(Preference preference) {
|
public final void updateState(Preference preference) {
|
||||||
updateStateInternal();
|
updateStateInternal(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** FOR SLICES */
|
/** FOR SLICES */
|
||||||
@@ -113,7 +111,7 @@ public class NightDisplayActivationPreferenceController extends TogglePreference
|
|||||||
return mTimeFormatter.getAutoModeSummary(mContext, mColorDisplayManager);
|
return mTimeFormatter.getAutoModeSummary(mContext, mColorDisplayManager);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateStateInternal() {
|
private void updateStateInternal(boolean selfChanged) {
|
||||||
if (mTurnOnButton == null || mTurnOffButton == null) {
|
if (mTurnOnButton == null || mTurnOffButton == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -143,17 +141,15 @@ public class NightDisplayActivationPreferenceController extends TogglePreference
|
|||||||
mTurnOnButton.setVisibility(View.GONE);
|
mTurnOnButton.setVisibility(View.GONE);
|
||||||
mTurnOffButton.setVisibility(View.VISIBLE);
|
mTurnOffButton.setVisibility(View.VISIBLE);
|
||||||
mTurnOffButton.setText(buttonText);
|
mTurnOffButton.setText(buttonText);
|
||||||
if (mButtonTriggered) {
|
if (selfChanged) {
|
||||||
mButtonTriggered = false;
|
mTurnOffButton.sendAccessibilityEvent(TYPE_VIEW_FOCUSED);
|
||||||
mTurnOffButton.requestFocus();
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
mTurnOnButton.setVisibility(View.VISIBLE);
|
mTurnOnButton.setVisibility(View.VISIBLE);
|
||||||
mTurnOffButton.setVisibility(View.GONE);
|
mTurnOffButton.setVisibility(View.GONE);
|
||||||
mTurnOnButton.setText(buttonText);
|
mTurnOnButton.setText(buttonText);
|
||||||
if (mButtonTriggered) {
|
if (selfChanged) {
|
||||||
mButtonTriggered = false;
|
mTurnOnButton.sendAccessibilityEvent(TYPE_VIEW_FOCUSED);
|
||||||
mTurnOnButton.requestFocus();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -16,6 +16,8 @@
|
|||||||
|
|
||||||
package com.android.settings.notification.zen;
|
package com.android.settings.notification.zen;
|
||||||
|
|
||||||
|
import static android.view.accessibility.AccessibilityEvent.TYPE_VIEW_FOCUSED;
|
||||||
|
|
||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
@@ -40,8 +42,9 @@ public class ZenModeButtonPreferenceController extends AbstractZenModePreference
|
|||||||
private static final String TAG = "EnableZenModeButton";
|
private static final String TAG = "EnableZenModeButton";
|
||||||
private final FragmentManager mFragment;
|
private final FragmentManager mFragment;
|
||||||
|
|
||||||
// DND can also be toggled from QS. If DND wasn't toggled by this preference, don't requestFocus
|
// DND can also be toggled from QS. If DND wasn't toggled by this preference, don't
|
||||||
private boolean mButtonTriggered = false;
|
// reroute focus.
|
||||||
|
private boolean mRefocusButton = false;
|
||||||
private Button mZenButtonOn;
|
private Button mZenButtonOn;
|
||||||
private Button mZenButtonOff;
|
private Button mZenButtonOff;
|
||||||
|
|
||||||
@@ -75,7 +78,7 @@ public class ZenModeButtonPreferenceController extends AbstractZenModePreference
|
|||||||
mZenButtonOff = ((LayoutPreference) preference)
|
mZenButtonOff = ((LayoutPreference) preference)
|
||||||
.findViewById(R.id.zen_mode_settings_turn_off_button);
|
.findViewById(R.id.zen_mode_settings_turn_off_button);
|
||||||
mZenButtonOff.setOnClickListener(v -> {
|
mZenButtonOff.setOnClickListener(v -> {
|
||||||
mButtonTriggered = true;
|
mRefocusButton = true;
|
||||||
writeMetrics(preference, false);
|
writeMetrics(preference, false);
|
||||||
mBackend.setZenMode(Settings.Global.ZEN_MODE_OFF);
|
mBackend.setZenMode(Settings.Global.ZEN_MODE_OFF);
|
||||||
});
|
});
|
||||||
@@ -91,9 +94,9 @@ public class ZenModeButtonPreferenceController extends AbstractZenModePreference
|
|||||||
case Settings.Global.ZEN_MODE_NO_INTERRUPTIONS:
|
case Settings.Global.ZEN_MODE_NO_INTERRUPTIONS:
|
||||||
mZenButtonOff.setVisibility(View.VISIBLE);
|
mZenButtonOff.setVisibility(View.VISIBLE);
|
||||||
mZenButtonOn.setVisibility(View.GONE);
|
mZenButtonOn.setVisibility(View.GONE);
|
||||||
if (mButtonTriggered) {
|
if (mRefocusButton) {
|
||||||
mButtonTriggered = false;
|
mRefocusButton = false;
|
||||||
mZenButtonOff.requestFocus();
|
mZenButtonOff.sendAccessibilityEvent(TYPE_VIEW_FOCUSED);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case Settings.Global.ZEN_MODE_OFF:
|
case Settings.Global.ZEN_MODE_OFF:
|
||||||
@@ -101,16 +104,16 @@ public class ZenModeButtonPreferenceController extends AbstractZenModePreference
|
|||||||
mZenButtonOff.setVisibility(View.GONE);
|
mZenButtonOff.setVisibility(View.GONE);
|
||||||
updateZenButtonOnClickListener(preference);
|
updateZenButtonOnClickListener(preference);
|
||||||
mZenButtonOn.setVisibility(View.VISIBLE);
|
mZenButtonOn.setVisibility(View.VISIBLE);
|
||||||
if (mButtonTriggered) {
|
if (mRefocusButton) {
|
||||||
mButtonTriggered = false;
|
mRefocusButton = false;
|
||||||
mZenButtonOn.requestFocus();
|
mZenButtonOn.sendAccessibilityEvent(TYPE_VIEW_FOCUSED);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateZenButtonOnClickListener(Preference preference) {
|
private void updateZenButtonOnClickListener(Preference preference) {
|
||||||
mZenButtonOn.setOnClickListener(v -> {
|
mZenButtonOn.setOnClickListener(v -> {
|
||||||
mButtonTriggered = true;
|
mRefocusButton = true;
|
||||||
writeMetrics(preference, true);
|
writeMetrics(preference, true);
|
||||||
int zenDuration = getZenDuration();
|
int zenDuration = getZenDuration();
|
||||||
switch (zenDuration) {
|
switch (zenDuration) {
|
||||||
|
Reference in New Issue
Block a user