我有一个带有自定义文本视图的微调器:
下面是代码:
<Spinner
android:id="@+id/spnr"
android:layout_width="fill_parent"
android:layout_height="30dp"
android:prompt="@string/list" />
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
style="?android:attr/spinnerItemStyle"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="#3D98E1"
在Android 5.0+(棒棒糖设备)上,文本切成两半并显示。
我只需要微调器高度为 30dp,如何解决此问题?
实际上我无法理解您的要求,但是如果您想完全控制微调器,请使用此技术。
您可以使用 ListPopupWindow 创建自定义微调框,以文本视图表示当单击文本视图时,ListPopupWindow 会像微调器下拉列表一样打开,您可以选择一个元素。如果你需要,我会帮助你。
ListPopupWindow numberList;
TextView spDays;
ArrayList<Map<String, String>>() listTrans;
in oncreate() spDays.setonclicklistner(this);spDays.setText("Select");
setNumberListSpinnerView();
in onclick(){
when spDays clicked :- numberList.show();
}
void setNumberListSpinnerView() {
numberList= new ListPopupWindow(this);
numberList.setAnchorView(spDays);
numberList.setOnItemClickListener((new AdapterView.OnItemClickListener() {
@Override
getListItem();
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
Map map = listTrans.get(position);
spDays.setText(map.get("circle_name").toString());
circle_name = map.get("circle_name") + "";
circle_id = map.get("circle_id").toString();
circleList.dismiss();
Log.d("Circle id:", circle_id + "");
getRetails();
}
}));
}
void getListItem(){
String[] numbers = {"1","2","3","4","5","6"};
listTrans = new ArrayList<Map<String, String>>();
LinkedHashMap<String, String> tran = new LinkedHashMap<String, String>();
for (String number : numbers) {
tran.put("numbers", number);
listTrans.add(tran);
}
SimpleAdapter adapter = new SimpleAdapter(AddRetailSurvey.this, listTrans,
android.R.layout.simple_spinner_dropdown_item,
new String[]{"numbers"},
new int[]{android.R.id.text1});
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
numberList.setAdapter(adapter);
}
检查此代码并根据您的要求对其进行修改。如果您发现任何问题,我会在这里为您提供帮助。:)
我不知道
为什么,但是当我添加 1dp 的虚拟填充时,文本不再被剪切。
<style name="YourSpinnerStyle" parent="Widget.AppCompat.Spinner.Underlined">
<item name="android:gravity">center|start</item>
<item name="android:layout_width">match_parent</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:padding">1dp</item>
<item name="android:textColor">@android:color/black</item>
<item name="android:textCursorDrawable">@null</item>
<item name="android:textSize">18sp</item>
</style>