2016-05-31 33 views
1

我可以通过简单的方式将箭头稍微靠近文本吗?当它透明的时候,不要把它理解为默认的目的。Android Spinner箭头更接近?

enter image description here

<Spinner 
    android:id="@+id/spinner_months" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content"/> 
+0

“全部”和箭头之间存在空格,因为必须在宽度较大的微调器中有一个项目。让它看起来更好的一种方法是在两个Spinners之间放置一个分隔符。 – Sharj

回答

2

我已经回答了类似的问题在这里:https://stackoverflow.com/a/42596698/1260126

这可以通过创建所选项目飞旋一个custom_spinner_item.xml自定义布局来实现。我添加了一个显示当前选定的微调项目的TextView。箭头图标添加到ImageView中。您可以使用任何图标。箭头图标根据文本的长度而移动。实际上,您可以在此布局中完全修改微调器的外观。

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_gravity="center_vertical" 
    android:orientation="horizontal"> 
    <TextView 
     android:id="@+id/spinner_item_text" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_gravity="center_vertical" 
     android:paddingLeft="10dp" 
     android:paddingRight="10dp"/> 
    <ImageView 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_gravity="center_vertical" 
     android:src="@mipmap/ic_arrow_down"/> 
</LinearLayout> 

创建一个自定义的微调控制器适配器并膨胀上述视图。通过重写默认的getView()方法,还可以从列表中设置选定微调项目的文本。

public class CustomSpinnerAdapter extends ArrayAdapter<String> { 
    LayoutInflater inflater; 
    List<String> spinnerItems; 

    public CustomSpinnerAdapter(Context applicationContext, int resource, List<String> spinnerItems) { 
     super(applicationContext, resource, spinnerItems); 
     this.spinnerItems = spinnerItems; 
     inflater = (LayoutInflater.from(applicationContext)); 
    } 
    @Override 
    public View getView(int i, View view, ViewGroup viewGroup) { 
     view = inflater.inflate(R.layout.custom_spinner_item, null); 
     TextView type = (TextView) view.findViewById(R.id.spinner_item_text); 
     type.setText(spinnerItems.get(i)); 
     return view; 
    } 
} 

然后实例化CustomSpinnerAdapter类并将其设置为您的微调器的适配器。 spinnerList是要在微调器中显示的项目列表。

CustomSpinnerAdapter customSpinnerAdapter = new CustomSpinnerAdapter(getContext(), android.R.layout.simple_spinner_item, spinnerList); 
spinner.setAdapter(customSpinnerAdapter); 
+1

“xml”中的“TextView”ID与Java类中的不匹配。 fwiw,这个方法在原始的'Spinner'背景上显示了'LinearLayout'(每个样式规格);通过设置'android:background =“@ null”解决了这个问题''谢谢 –

+1

做了必要的修正。谢谢@TomHoward –