fix(text preference): fix preview block ui broken in SUW
As previous cl ag/25185014 we increased the preview block horizontal padding when landscape mode. However, in setup wizard it uses GlifPreferenceLayout so the settings page only has half screen width when landscape mode, so the preview block ui is squished due to limited width. Also, setup wizard package has overlay the paddings to larger than our prevoius adjust. Therefore, we rollback the changes in accessibility_text_reading_preview.xml to get the default padding, then add checker to increase the paddings if needed at runtime. Bug: 309590083 Test: manually Test: atest TextReadingPreviewPreferenceTest Test: atest TextReadingPreferenceFragmentForSetupWizardTest Change-Id: Ib907f4182eed272b84a4ab6208ea2d8a89ba96c4
This commit is contained in:
@@ -19,11 +19,14 @@ package com.android.settings.accessibility;
|
||||
import android.content.Context;
|
||||
import android.util.AttributeSet;
|
||||
import android.view.View;
|
||||
import android.widget.FrameLayout;
|
||||
import android.widget.LinearLayout;
|
||||
|
||||
import androidx.preference.Preference;
|
||||
import androidx.preference.PreferenceViewHolder;
|
||||
import androidx.viewpager.widget.ViewPager;
|
||||
|
||||
import com.android.internal.annotations.VisibleForTesting;
|
||||
import com.android.internal.util.Preconditions;
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.display.PreviewPagerAdapter;
|
||||
@@ -37,6 +40,9 @@ public class TextReadingPreviewPreference extends Preference {
|
||||
private int mLastLayerIndex;
|
||||
private PreviewPagerAdapter mPreviewAdapter;
|
||||
|
||||
private int mLayoutMinHorizontalPadding = 0;
|
||||
private int mBackgroundMinHorizontalPadding = 0;
|
||||
|
||||
private final ViewPager.OnPageChangeListener mPageChangeListener =
|
||||
new ViewPager.OnPageChangeListener() {
|
||||
@Override
|
||||
@@ -80,6 +86,10 @@ public class TextReadingPreviewPreference extends Preference {
|
||||
public void onBindViewHolder(PreferenceViewHolder holder) {
|
||||
super.onBindViewHolder(holder);
|
||||
|
||||
FrameLayout previewLayout = (FrameLayout) holder.itemView;
|
||||
LinearLayout backgroundView = previewLayout.findViewById(R.id.preview_background);
|
||||
adjustPaddings(previewLayout, backgroundView);
|
||||
|
||||
final ViewPager viewPager = (ViewPager) holder.findViewById(R.id.preview_pager);
|
||||
viewPager.addOnPageChangeListener(mPageChangeListener);
|
||||
final DotsPageIndicator pageIndicator =
|
||||
@@ -88,6 +98,36 @@ public class TextReadingPreviewPreference extends Preference {
|
||||
updatePagerAndIndicator(viewPager, pageIndicator);
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the minimum preview layout horizontal inner padding.
|
||||
*/
|
||||
void setLayoutMinHorizontalPadding(int layoutMinHorizontalPadding) {
|
||||
mLayoutMinHorizontalPadding = layoutMinHorizontalPadding;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the minimum preview background view horizontal inner padding.
|
||||
*/
|
||||
void setBackgroundMinHorizontalPadding(int backgroundMinHorizontalPadding) {
|
||||
mBackgroundMinHorizontalPadding = backgroundMinHorizontalPadding;
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
void adjustPaddings(FrameLayout previewLayout, LinearLayout backgroundView) {
|
||||
previewLayout.setPadding(
|
||||
Math.max(previewLayout.getPaddingStart(), mLayoutMinHorizontalPadding),
|
||||
previewLayout.getPaddingTop(),
|
||||
Math.max(previewLayout.getPaddingEnd(), mLayoutMinHorizontalPadding),
|
||||
previewLayout.getPaddingBottom()
|
||||
);
|
||||
backgroundView.setPadding(
|
||||
Math.max(backgroundView.getPaddingStart(), mBackgroundMinHorizontalPadding),
|
||||
backgroundView.getPaddingTop(),
|
||||
Math.max(backgroundView.getPaddingEnd(), mBackgroundMinHorizontalPadding),
|
||||
backgroundView.getPaddingBottom()
|
||||
);
|
||||
}
|
||||
|
||||
void setPreviewAdapter(PreviewPagerAdapter previewAdapter) {
|
||||
if (previewAdapter != mPreviewAdapter) {
|
||||
mPreviewAdapter = previewAdapter;
|
||||
@@ -142,6 +182,12 @@ public class TextReadingPreviewPreference extends Preference {
|
||||
}
|
||||
|
||||
private void init() {
|
||||
// set up the minimum horizontal paddings
|
||||
setLayoutMinHorizontalPadding(getContext().getResources().getDimensionPixelSize(
|
||||
R.dimen.text_reading_preview_layout_padding_horizontal_min));
|
||||
setBackgroundMinHorizontalPadding(getContext().getResources().getDimensionPixelSize(
|
||||
R.dimen.text_reading_preview_background_padding_horizontal_min));
|
||||
|
||||
setLayoutResource(R.layout.accessibility_text_reading_preview);
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user