Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/186.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何将Android微调器下拉箭头移近它';s发出文本_Android_Spinner_Android Spinner - Fatal编程技术网

如何将Android微调器下拉箭头移近它';s发出文本

如何将Android微调器下拉箭头移近它';s发出文本,android,spinner,android-spinner,Android,Spinner,Android Spinner,我需要在微调器中将下拉箭头设置为更靠近其发射文本元素。如何才能做到这一点 <Spinner android:id="@+id/spinner" android:layout_width="wrap_content" android:layout_height="wrap_content" /> 您可以通过在xml中定义自定义背景,然后从右侧设置箭头的边距来解决此问题 首先为箭头定义一个具有矩形背景和位图对象的图层列表。您可以通过设置箭头的重力

我需要在
微调器
中将下拉箭头设置为更靠近其发射文本元素。如何才能做到这一点

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


您可以通过在xml中定义自定义背景,然后从右侧设置箭头的边距来解决此问题

首先为箭头定义一个具有矩形背景和位图对象的图层列表。您可以通过设置箭头的重力使其与右侧的中心对齐,也可以通过安卓系统的“right”属性设置其右边距使其向中心移动。请注意,这不会根据文本长度动态移动箭头,但这应该是一个有用的第一步

spinner\u background.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape android:shape="rectangle">
            <solid android:color="@color/color_white" />
            <corners android:radius="2.5dp" />
        </shape>
    </item>
    <item android:right="64dp">
         <bitmap 
             android:gravity="right|center_vertical"  
             android:src="@drawable/ic_spinner" />
    </item>
</layer-list>

这可以通过为所选微调器项custom\u spinner\u 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>

这个布局会对你有很好的帮助

<FrameLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginTop="@dimen/dp5"
    android:background="@drawable/squre_gray_bg"
    android:paddingRight="@dimen/dp10">

    <Spinner
        android:id="@+id/ed_project_start"
        android:layout_width="match_parent"
        android:layout_height="@dimen/dp40"
        android:layout_marginTop="@dimen/dp5"
        android:textColor="@color/colorDarkGray" />
</FrameLayout>


以下两个方面可能值得关注:1.android:src=“@drawable/ic_spinner”之后缺少一个封闭的括号(>)。2.spinner_background.xml需要在drawable文件夹中创建。它在getView()方法的CustomSpinnerAdapter中用于创建视图-“view=inflater.inflate(R.layout.custom_spinner_item,null);”您面临什么问题@ParamjitSinghRanaThis为我工作。但在图标的右侧有一些填充或空白(下拉箭头)。如何摆脱它?@LuckMan:可能是父布局有问题。尝试更改不同版面的背景颜色,以确定哪个版面有多余的空间。我通过添加
android:background
属性来修复它,并使其透明(其他颜色也可以)。顺便问一下,有没有办法自定义下拉项样式?我想将其与我的应用程序主题匹配。目前,它使用的是默认样式:EDIT:没关系,
setDropDownViewResource
成功了。:)
CustomSpinnerAdapter customSpinnerAdapter = new CustomSpinnerAdapter(getContext(), android.R.layout.simple_spinner_item, spinnerList);
spinner.setAdapter(customSpinnerAdapter);
<FrameLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginTop="@dimen/dp5"
    android:background="@drawable/squre_gray_bg"
    android:paddingRight="@dimen/dp10">

    <Spinner
        android:id="@+id/ed_project_start"
        android:layout_width="match_parent"
        android:layout_height="@dimen/dp40"
        android:layout_marginTop="@dimen/dp5"
        android:textColor="@color/colorDarkGray" />
</FrameLayout>