将文本设置为居中适用于一个微调器,但不适用于其他微调器
Setting the text to be in the center works for one spinner, but not for other
在我的应用程序中,我有 3 个微调器 - 一个在顶部,使用时为用户提供另外 2 个在其下方对齐。
我查看了 this question,在那里我找到了我正在寻找的答案,但只找到了一半。现在两个辅助微调器的文本显示在中间,但第一个 - 没有。
查看微调器的 .xml,我只能看到关于居中的一个区别,那就是两个补充的具有 android:layout_gravity="center"
属性,由于某种原因,该属性不适用到第一个微调器。为什么会这样?这可能是原因吗?不适用我的意思是它不在设计视图中微调器的属性中,当我在 .xml 中手动添加它时,没有任何变化。
所以我正在寻找的理想答案是 为什么 2 个补充微调器的文本居中,但第一个 - 不是? 注意我对居中不感兴趣弹出窗口中的元素,这完全是可选的。我只想让选中的选项居中。
下面是红色问题的屏幕截图:
这是我正在使用的.xml
:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/some_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:context="packagename"
tools:showIn="@layout/specific_activity_layout"
android:gravity="center_horizontal"
android:background="#FF9800">
<Spinner
android:layout_width="fill_parent"
android:layout_height="50dp"
android:id="@+id/spinner1"
android:entries="@array/spinner1entries"
android:layout_centerHorizontal="true"
android:layout_marginBottom="15dp"
android:gravity="center|top"
android:background="@drawable/rounded_corners"
android:paddingTop="4dp"
android:paddingBottom="4dp"
android:popupBackground="#FFB74D"
android:layout_alignParentEnd="false"
android:textAlignment="center" />
<LinearLayout
android:id="@+id/horizontal_layout_spinners"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentEnd="false"
android:layout_alignParentStart="false"
android:visibility="invisible"
android:layout_below="@+id/spinner1">
<Spinner
android:layout_width="wrap_content"
android:layout_height="50dp"
android:id="@+id/spinner2"
android:visibility="visible"
android:background="@drawable/rounded_corners"
android:layout_marginRight="5dp"
android:popupBackground="#FFB74D"
android:textAlignment="center"
android:gravity="center|top"
android:layout_weight="0.5"
android:layout_gravity="center" />
<Spinner
android:layout_width="wrap_content"
android:layout_height="50dp"
android:id="@+id/spinner3"
android:visibility="visible"
android:layout_marginLeft="5dp"
android:background="@drawable/rounded_corners"
android:popupBackground="#FFB74D"
android:textAlignment="center"
android:gravity="center|top"
android:layout_weight="0.5"
android:layout_gravity="center" />
</LinearLayout>
</RelativeLayout>
rounded_corners
文件:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="#FFB74D"/>
<stroke android:width="0dip" android:color="#B1BCBE" />
<corners android:radius="10dip"/>
<padding android:left="0dip" android:top="0dip" android:right="0dip" android:bottom="0dip" />
</shape>
尝试添加:
android:dropDownWidth="wrap_content"
到旋转器。
您可以尝试在从微调器中选择一个项目后以编程方式设置文本样式。设置一个 setOnItemSelectedListener
并在其中设置 TextView 居中。
Spinner spinner1 = (Spinner) findViewById(R.id.spinner1);
spinner1.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
@Override
public void onItemSelected(AdapterView<?> arg0, View view, int arg2, long arg3) {
// Set the text style after item is selected.
setSpinnerSelectedItemParams(spinner1, getActivity());
}
@Override
public void onNothingSelected(AdapterView<?> parent) {
}
});
/**
* Sets the spinner text style to a different one after one value has been chosen.
* @param spinner Spinner currently in use
*/
public void setSpinnerSelectedItemParams(Spinner spinner, Context context) {
if (spinner.getChildCount() > 0){
TextView tvSpinner = ((TextView) spinner.getChildAt(0));
tvSpinner.setPadding(0, 0, 0, 0);
tvSpinner.setGravity(Gravity.CENTER);
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
params.gravity = Gravity.CENTER;
params.setMargins(0, 0, 0, 0);
tvSpinner.setLayoutParams(params);
}
}
如果您希望文本在选择之前也居中,请尝试在创建适配器时设置自定义资源。
在 Activity 或片段中:
ArrayAdapter<String> yourAdapter = new ArrayAdapter(activity, R.layout.default_spinner_adapter_view, yourDataToFillTheSpinner);
"default_spinner_adapter_view.xml" 文件:
<?xml version="1.0" encoding="utf-8"?>
<!-- This is the view for each individual item of the spinner-->
<CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/tv_default_spinner"
style="?android:attr/spinnerItemStyle"
android:layout_width="match_parent
android:layout_height="wrap_content"
android:layout_gravity="center"
android:ellipsize="marquee"
android:gravity="center"
android:singleLine="true"
android:textAppearance="?android:attr/textAppearanceMedium"
android:textColor="@android:color/black" />
如果您想自定义下拉列表项,您需要创建一个新的布局文件。我们称它为 spinner_dropdown_item.xml:
<?xml version="1.0" encoding="utf-8"?>
<CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
style="?android:attr/spinnerDropDownItemStyle"
android:singleLine="true"
android:layout_width="match_parent"
android:layout_height="?android:attr/listPreferredItemHeight"
android:ellipsize="marquee"
android:textColor="#aa66cc"/>
微调器声明的另一个变化:
ArrayAdapter adapter = ArrayAdapter.createFromResource(this,R.array.planets_array, R.layout.spinner_item);
adapter.setDropDownViewResource(R.layout.spinner_dropdown_item);
spinner.setAdapter(adapter);
制作你的微调器自定义列表项并根据需要进行设置,它应该有一个 TextView id text1 并像下面这样使用这个list_item.xml
Spinner spinner = (Spinner) findViewById(R.id.spinner);
// Create an ArrayAdapter using the string array and a default spinner
layout
ArrayAdapter<CharSequence> adapter = ArrayAdapter.createFromResource(this,
R.array.planets_array, android.R.layout.your_list_item);
// Specify the layout to use when the list of choices appears
adapter.setDropDownViewResource(android.R.layout.your_drop_down_list_item);
// Apply the adapter to the spinner
spinner.setAdapter(adapter);
将相对布局更改为垂直线性布局,微调器的宽度应为 match_parent。
确保所有微调器都使用相同类型的适配器——或至少使用相同项目布局的另一个适配器——适配器提供布局。
在我的应用程序中,我有 3 个微调器 - 一个在顶部,使用时为用户提供另外 2 个在其下方对齐。
我查看了 this question,在那里我找到了我正在寻找的答案,但只找到了一半。现在两个辅助微调器的文本显示在中间,但第一个 - 没有。
查看微调器的 .xml,我只能看到关于居中的一个区别,那就是两个补充的具有 android:layout_gravity="center"
属性,由于某种原因,该属性不适用到第一个微调器。为什么会这样?这可能是原因吗?不适用我的意思是它不在设计视图中微调器的属性中,当我在 .xml 中手动添加它时,没有任何变化。
所以我正在寻找的理想答案是 为什么 2 个补充微调器的文本居中,但第一个 - 不是? 注意我对居中不感兴趣弹出窗口中的元素,这完全是可选的。我只想让选中的选项居中。
下面是红色问题的屏幕截图:
这是我正在使用的.xml
:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/some_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:context="packagename"
tools:showIn="@layout/specific_activity_layout"
android:gravity="center_horizontal"
android:background="#FF9800">
<Spinner
android:layout_width="fill_parent"
android:layout_height="50dp"
android:id="@+id/spinner1"
android:entries="@array/spinner1entries"
android:layout_centerHorizontal="true"
android:layout_marginBottom="15dp"
android:gravity="center|top"
android:background="@drawable/rounded_corners"
android:paddingTop="4dp"
android:paddingBottom="4dp"
android:popupBackground="#FFB74D"
android:layout_alignParentEnd="false"
android:textAlignment="center" />
<LinearLayout
android:id="@+id/horizontal_layout_spinners"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentEnd="false"
android:layout_alignParentStart="false"
android:visibility="invisible"
android:layout_below="@+id/spinner1">
<Spinner
android:layout_width="wrap_content"
android:layout_height="50dp"
android:id="@+id/spinner2"
android:visibility="visible"
android:background="@drawable/rounded_corners"
android:layout_marginRight="5dp"
android:popupBackground="#FFB74D"
android:textAlignment="center"
android:gravity="center|top"
android:layout_weight="0.5"
android:layout_gravity="center" />
<Spinner
android:layout_width="wrap_content"
android:layout_height="50dp"
android:id="@+id/spinner3"
android:visibility="visible"
android:layout_marginLeft="5dp"
android:background="@drawable/rounded_corners"
android:popupBackground="#FFB74D"
android:textAlignment="center"
android:gravity="center|top"
android:layout_weight="0.5"
android:layout_gravity="center" />
</LinearLayout>
</RelativeLayout>
rounded_corners
文件:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="#FFB74D"/>
<stroke android:width="0dip" android:color="#B1BCBE" />
<corners android:radius="10dip"/>
<padding android:left="0dip" android:top="0dip" android:right="0dip" android:bottom="0dip" />
</shape>
尝试添加:
android:dropDownWidth="wrap_content"
到旋转器。您可以尝试在从微调器中选择一个项目后以编程方式设置文本样式。设置一个
setOnItemSelectedListener
并在其中设置 TextView 居中。Spinner spinner1 = (Spinner) findViewById(R.id.spinner1); spinner1.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() { @Override public void onItemSelected(AdapterView<?> arg0, View view, int arg2, long arg3) { // Set the text style after item is selected. setSpinnerSelectedItemParams(spinner1, getActivity()); } @Override public void onNothingSelected(AdapterView<?> parent) { } }); /** * Sets the spinner text style to a different one after one value has been chosen. * @param spinner Spinner currently in use */ public void setSpinnerSelectedItemParams(Spinner spinner, Context context) { if (spinner.getChildCount() > 0){ TextView tvSpinner = ((TextView) spinner.getChildAt(0)); tvSpinner.setPadding(0, 0, 0, 0); tvSpinner.setGravity(Gravity.CENTER); LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT); params.gravity = Gravity.CENTER; params.setMargins(0, 0, 0, 0); tvSpinner.setLayoutParams(params); } }
如果您希望文本在选择之前也居中,请尝试在创建适配器时设置自定义资源。
在 Activity 或片段中:
ArrayAdapter<String> yourAdapter = new ArrayAdapter(activity, R.layout.default_spinner_adapter_view, yourDataToFillTheSpinner);
"default_spinner_adapter_view.xml" 文件:
<?xml version="1.0" encoding="utf-8"?> <!-- This is the view for each individual item of the spinner--> <CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/tv_default_spinner" style="?android:attr/spinnerItemStyle" android:layout_width="match_parent android:layout_height="wrap_content" android:layout_gravity="center" android:ellipsize="marquee" android:gravity="center" android:singleLine="true" android:textAppearance="?android:attr/textAppearanceMedium" android:textColor="@android:color/black" />
如果您想自定义下拉列表项,您需要创建一个新的布局文件。我们称它为 spinner_dropdown_item.xml:
<?xml version="1.0" encoding="utf-8"?>
<CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
style="?android:attr/spinnerDropDownItemStyle"
android:singleLine="true"
android:layout_width="match_parent"
android:layout_height="?android:attr/listPreferredItemHeight"
android:ellipsize="marquee"
android:textColor="#aa66cc"/>
微调器声明的另一个变化:
ArrayAdapter adapter = ArrayAdapter.createFromResource(this,R.array.planets_array, R.layout.spinner_item);
adapter.setDropDownViewResource(R.layout.spinner_dropdown_item);
spinner.setAdapter(adapter);
制作你的微调器自定义列表项并根据需要进行设置,它应该有一个 TextView id text1 并像下面这样使用这个list_item.xml
Spinner spinner = (Spinner) findViewById(R.id.spinner);
// Create an ArrayAdapter using the string array and a default spinner layout
ArrayAdapter<CharSequence> adapter = ArrayAdapter.createFromResource(this,
R.array.planets_array, android.R.layout.your_list_item);
// Specify the layout to use when the list of choices appears
adapter.setDropDownViewResource(android.R.layout.your_drop_down_list_item);
// Apply the adapter to the spinner
spinner.setAdapter(adapter);
将相对布局更改为垂直线性布局,微调器的宽度应为 match_parent。
确保所有微调器都使用相同类型的适配器——或至少使用相同项目布局的另一个适配器——适配器提供布局。