diff options
| author | Heemin Seog <hseog@google.com> | 2021-03-15 16:09:22 +0000 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2021-03-15 16:09:22 +0000 |
| commit | 1fcb030d0e8831def81e2e2c8ccfa4145b72ca96 (patch) | |
| tree | 1a2f4c89ed9916e1a85f5aa1a3a0f6704e4b807b | |
| parent | 1f9f16f880586576176237e42c454934e2c2e0c2 (diff) | |
| parent | b7788214e52c3b981ab7dfb14e2f1f507c974114 (diff) | |
Merge "Fix broken keyguard in car sysui" into sc-dev
3 files changed, 47 insertions, 15 deletions
diff --git a/packages/SystemUI/src/com/android/keyguard/NumPadButton.java b/packages/SystemUI/src/com/android/keyguard/NumPadButton.java index 5db3349b646a..1635c49b5668 100644 --- a/packages/SystemUI/src/com/android/keyguard/NumPadButton.java +++ b/packages/SystemUI/src/com/android/keyguard/NumPadButton.java @@ -17,6 +17,7 @@ package com.android.keyguard; import android.content.Context; import android.content.res.ColorStateList; +import android.graphics.drawable.Drawable; import android.graphics.drawable.LayerDrawable; import android.graphics.drawable.VectorDrawable; import android.util.AttributeSet; @@ -24,6 +25,8 @@ import android.view.ContextThemeWrapper; import android.view.MotionEvent; import android.view.ViewGroup; +import androidx.annotation.Nullable; + import com.android.settingslib.Utils; import com.android.systemui.R; @@ -32,13 +35,19 @@ import com.android.systemui.R; */ public class NumPadButton extends AlphaOptimizedImageButton { + @Nullable private NumPadAnimator mAnimator; public NumPadButton(Context context, AttributeSet attrs) { super(context, attrs); - mAnimator = new NumPadAnimator(context, (LayerDrawable) getBackground(), - attrs.getStyleAttribute()); + Drawable background = getBackground(); + if (background instanceof LayerDrawable) { + mAnimator = new NumPadAnimator(context, (LayerDrawable) background, + attrs.getStyleAttribute()); + } else { + mAnimator = null; + } } @Override @@ -93,9 +102,11 @@ public class NumPadButton extends AlphaOptimizedImageButton { * By default, the new layout will be enabled. Invoking will revert to the old style */ public void disableNewLayout() { - mAnimator = null; - ContextThemeWrapper ctw = new ContextThemeWrapper(getContext(), R.style.NumPadKey); - setBackground(getContext().getResources().getDrawable( - R.drawable.ripple_drawable_pin, ctw.getTheme())); + if (mAnimator != null) { + mAnimator = null; + ContextThemeWrapper ctw = new ContextThemeWrapper(getContext(), R.style.NumPadKey); + setBackground(getContext().getResources().getDrawable( + R.drawable.ripple_drawable_pin, ctw.getTheme())); + } } } diff --git a/packages/SystemUI/src/com/android/keyguard/NumPadKey.java b/packages/SystemUI/src/com/android/keyguard/NumPadKey.java index e6a9d4fdd547..96fceeeb8397 100644 --- a/packages/SystemUI/src/com/android/keyguard/NumPadKey.java +++ b/packages/SystemUI/src/com/android/keyguard/NumPadKey.java @@ -18,6 +18,7 @@ package com.android.keyguard; import android.content.Context; import android.content.res.TypedArray; +import android.graphics.drawable.Drawable; import android.graphics.drawable.LayerDrawable; import android.os.PowerManager; import android.os.SystemClock; @@ -31,6 +32,8 @@ import android.view.ViewGroup; import android.view.accessibility.AccessibilityManager; import android.widget.TextView; +import androidx.annotation.Nullable; + import com.android.internal.widget.LockPatternUtils; import com.android.settingslib.Utils; import com.android.systemui.R; @@ -48,6 +51,7 @@ public class NumPadKey extends ViewGroup { private int mTextViewResId; private PasswordTextView mTextView; + @Nullable private NumPadAnimator mAnimator; private View.OnClickListener mListener = new View.OnClickListener() { @@ -127,8 +131,13 @@ public class NumPadKey extends ViewGroup { setContentDescription(mDigitText.getText().toString()); - mAnimator = new NumPadAnimator(context, (LayerDrawable) getBackground(), - R.style.NumPadKey); + Drawable background = getBackground(); + if (background instanceof LayerDrawable) { + mAnimator = new NumPadAnimator(context, (LayerDrawable) background, + R.style.NumPadKey); + } else { + mAnimator = null; + } } /** @@ -136,10 +145,12 @@ public class NumPadKey extends ViewGroup { */ public void disableNewLayout() { findViewById(R.id.klondike_text).setVisibility(View.VISIBLE); - mAnimator = null; - ContextThemeWrapper ctw = new ContextThemeWrapper(getContext(), R.style.NumPadKey); - setBackground(getContext().getResources().getDrawable( - R.drawable.ripple_drawable_pin, ctw.getTheme())); + if (mAnimator != null) { + mAnimator = null; + ContextThemeWrapper ctw = new ContextThemeWrapper(getContext(), R.style.NumPadKey); + setBackground(getContext().getResources().getDrawable( + R.drawable.ripple_drawable_pin, ctw.getTheme())); + } } /** diff --git a/packages/SystemUI/src/com/android/keyguard/PasswordTextView.java b/packages/SystemUI/src/com/android/keyguard/PasswordTextView.java index 5ffc2836b9e3..b80f8bd64dcf 100644 --- a/packages/SystemUI/src/com/android/keyguard/PasswordTextView.java +++ b/packages/SystemUI/src/com/android/keyguard/PasswordTextView.java @@ -121,9 +121,19 @@ public class PasswordTextView extends View { public PasswordTextView(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) { super(context, attrs, defStyleAttr, defStyleRes); - setFocusableInTouchMode(true); - setFocusable(true); - TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.PasswordTextView); + TypedArray a = context.obtainStyledAttributes(attrs, android.R.styleable.View); + try { + // If defined, use the provided values. If not, set them to true by default. + boolean isFocusable = a.getBoolean(android.R.styleable.View_focusable, + /* defValue= */ true); + boolean isFocusableInTouchMode = a.getBoolean( + android.R.styleable.View_focusableInTouchMode, /* defValue= */ true); + setFocusable(isFocusable); + setFocusableInTouchMode(isFocusableInTouchMode); + } finally { + a.recycle(); + } + a = context.obtainStyledAttributes(attrs, R.styleable.PasswordTextView); try { mTextHeightRaw = a.getInt(R.styleable.PasswordTextView_scaledTextSize, 0); mGravity = a.getInt(R.styleable.PasswordTextView_android_gravity, Gravity.CENTER); |
