如何在自定义微调项之间添加 space?
How to add space between custom spinner items?
我已经按照本教程 Android Widgets: Custom Spinner in Android 进行了自定义 Spinner
,其中有一个图像和一个文本视图作为项目,但由于某种原因,没有 space项目。
目前没有点击时的样子(没问题):
当我点击它时,它看起来像这样:
虽然默认的项目之间有很多 space:
这是微调器的 xml
代码:
<Spinner
android:id="@+id/languageSpinner"
style="@android:style/Widget.Holo.Light.Spinner"
android:layout_width="110dp"
android:layout_height="40dp"
android:layout_marginStart="30dp"
android:prompt="@string/select"
android:spinnerMode="dropdown"/>
这是自定义行布局的 xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/icon"
android:layout_width="wrap_content"
android:layout_gravity="center_vertical"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/language"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="18sp"
android:layout_gravity="center_vertical"
android:textColor="@color/black"
android:layout_marginStart="10dp"
android:layout_marginBottom="2dp"/>
</LinearLayout>
有人知道我做错了什么吗?
编辑:经过一些建议后,添加了项目之间的space,但是无法正确看到在微调器中选择的项目,我我附上一张图片:
试试这个方法
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<ImageView
android:id="@+id/icon"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="10dip"
android:layout_marginBottom="10dip"
android:layout_marginLeft="15dip"/>
<TextView
android:id="@+id/country"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="5dip"
android:layout_marginBottom="10dip"
android:layout_marginTop="10dip"
android:textColor="#000000" />
</LinearLayout>
您只需要在文本视图中添加属性 lineSpacingExtra。
示例:
<TextView
android:id="@+id/language"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="18sp"
android:layout_gravity="center_vertical"
android:textColor="@color/black"
android:layout_marginStart="10dp"
android:layout_marginBottom="2dp"
android:lineSpacingExtra="3dp/>
--> android:lineSpacingExtra="3dp
自定义行布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_margin="10dp">
<ImageView
android:id="@+id/icon"
android:layout_width="wrap_content"
android:layout_gravity="center_vertical"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/language"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="18sp"
android:layout_gravity="center_vertical"
android:textColor="@color/black"
android:layout_marginStart="10dp"
android:layout_marginBottom="2dp"/>
</LinearLayout>
</LinearLayout>
我已经按照本教程 Android Widgets: Custom Spinner in Android 进行了自定义 Spinner
,其中有一个图像和一个文本视图作为项目,但由于某种原因,没有 space项目。
目前没有点击时的样子(没问题):
当我点击它时,它看起来像这样:
虽然默认的项目之间有很多 space:
这是微调器的 xml
代码:
<Spinner
android:id="@+id/languageSpinner"
style="@android:style/Widget.Holo.Light.Spinner"
android:layout_width="110dp"
android:layout_height="40dp"
android:layout_marginStart="30dp"
android:prompt="@string/select"
android:spinnerMode="dropdown"/>
这是自定义行布局的 xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/icon"
android:layout_width="wrap_content"
android:layout_gravity="center_vertical"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/language"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="18sp"
android:layout_gravity="center_vertical"
android:textColor="@color/black"
android:layout_marginStart="10dp"
android:layout_marginBottom="2dp"/>
</LinearLayout>
有人知道我做错了什么吗?
编辑:经过一些建议后,添加了项目之间的space,但是无法正确看到在微调器中选择的项目,我我附上一张图片:
试试这个方法
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<ImageView
android:id="@+id/icon"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="10dip"
android:layout_marginBottom="10dip"
android:layout_marginLeft="15dip"/>
<TextView
android:id="@+id/country"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="5dip"
android:layout_marginBottom="10dip"
android:layout_marginTop="10dip"
android:textColor="#000000" />
</LinearLayout>
您只需要在文本视图中添加属性 lineSpacingExtra。
示例:
<TextView
android:id="@+id/language"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="18sp"
android:layout_gravity="center_vertical"
android:textColor="@color/black"
android:layout_marginStart="10dp"
android:layout_marginBottom="2dp"
android:lineSpacingExtra="3dp/>
--> android:lineSpacingExtra="3dp
自定义行布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_margin="10dp">
<ImageView
android:id="@+id/icon"
android:layout_width="wrap_content"
android:layout_gravity="center_vertical"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/language"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="18sp"
android:layout_gravity="center_vertical"
android:textColor="@color/black"
android:layout_marginStart="10dp"
android:layout_marginBottom="2dp"/>
</LinearLayout>
</LinearLayout>