通过单击 EditText 打开微调器

Opening spinner by clicking on EditText

很抱歉打扰你们,但我一直在努力让它发挥作用。

我想要它做什么:

编辑文本以显示提示。

用户点击 EditText,打开微调器并选择他们的性别。然后将其变成字符串并放入 EditText(gender)


它实际上在做什么: "Male" 在用户点击它之前,我的微调器中的第一个元素已经放入我的 EditText 中。(我从来没有看到我的提示:"Sex")......并且微调器不会打开当我尝试点击 EditText(gender)

怎么回事?

我的代码:

    private Spinner sexSpinner;
    String[] arrayForSpinner = {"Male", "Female"};


    //Inside OnCreate method:
    sexSpinner = (Spinner)findViewById(R.id.spinner);
    adapter = new ArrayAdapter<String>(this, R.layout.spinner_row, arrayForSpinner);
    sexSpinner.setAdapter(adapter);


sexSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {

        @Override
        public void onItemSelected(AdapterView<?> parent, View view,int position, long id) {
            gender.setText(sexSpinner.getSelectedItem().toString());

        }

gender.setOnFocusChangeListener(new View.OnFocusChangeListener() {

        @Override
        public void onFocusChange(View arg0, boolean hasFocus) {
            // TODO Auto-generated method stub
            if(hasFocus){
                sexSpinner.performClick();
            }
        }
    });

布局:

<EditText
        android:layout_width="75dp"
        android:layout_height="wrap_content"
        android:layout_marginBottom="12dp"
        android:focusable="false"
        android:longClickable="false"
        android:clickable="true"
        android:inputType="date"
        android:maxLines="1"
        android:singleLine="true"
        android:hint="Gender"
        android:textColorHint="@color/white"
        android:textColor="@color/white"
        android:ems="10"
        android:id="@+id/signup_input_gender"
        android:layout_below="@+id/signup_input_birthday"
        android:layout_centerHorizontal="true"
        android:backgroundTint="@android:color/white"/>

<Spinner
        android:background="@color/Blue"
        android:id="@+id/spinner"
        android:paddingLeft="0dp"
        android:layout_width="75dp"
        android:layout_height="40dp"
        android:layout_marginRight="40dp"
        android:layout_marginBottom="6dp"
        android:layout_below="@+id/linearlayout"
        android:visibility="invisible" />

你可以通过这个实现你想要的:

在您的 xml 中添加这个而不是编辑文本和微调器

<AutoCompleteTextView
   android:id="@+id/gender_list"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_alignParentTop="true"
   android:layout_centerHorizontal="true"
   android:layout_marginTop="65dp"
   android:ems="10"
   android:editable="false" >

这在您的 java 代码中

ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
                 android.R.layout.simple_dropdown_item_1line, GENDERLIST);
         AutoCompleteTextView textView = (AutoCompleteTextView)
                 findViewById(R.id.gender_list);
         textView.setAdapter(adapter);
textView.setOnTouchListener(new OnTouchListener() {

        @SuppressLint("ClickableViewAccessibility")
        @Override
        public boolean onTouch(View paramView, MotionEvent paramMotionEvent) {
            // TODO Auto-generated method stub
            textView.showDropDown();
            textView.requestFocus();
            return false;
        }
    });

你在点击它时没有让微调器可见,所以你看不到它

sexSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {

    @Override
    public void onItemSelected(AdapterView<?> parent, View view,int position, long id) {
sexSpinner.setVisibility(View.Invisible)
        gender.setText(sexSpinner.getSelectedItem().toString());

    }

gender.setOnFocusChangeListener(new View.OnFocusChangeListener() {

    @Override
    public void onFocusChange(View arg0, boolean hasFocus) {
        // TODO Auto-generated method stub
        if(hasFocus){
sexSpinner.setVisibility(View.Visible)
            sexSpinner.performClick();
        }
    }
});

显示Spinner(使用gender.setOnClickListener()),

gender.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                flag = true;              
                sexSpinner.performClick();
            }
        });

首次将提示显示为 'Sex' 定义布尔全局变量 'flag',

    boolean flag = false;        // Here
.
.
.
sexSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {

            @Override
            public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
                if (flag)        // Here
                    gender.setText(sexSpinner.getSelectedItem().toString());
            }
        });
.
.
.
gender.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                flag = true;        // Here
                sexSpinner.performClick();
            }
        });

在这里,我将展示如何为此使用 AutoCompleteTextView。此外,当我从项目中复制所有代码时,我还添加了 Imageview(删除按钮),用于重置 AutoCompleteTextView.

首先是 XML 代码(使用 ConstraintLayout:

<AutoCompleteTextView
        android:layout_width="200dp"
        android:layout_height="30dp"
        android:hint="Select Gender"
        android:id="@+id/acT1"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        android:background="#ffffff"
        android:textAlignment="center"            
        android:dropDownHeight="155dp"
        android:cursorVisible="false"
        android:maxLines="1"
        android:focusable="false"
        android:clickable="true"
        android:inputType="none"
        />
    <ImageView
        android:src="@drawable/clear"
        android:layout_width="wrap_content"
        android:layout_height="20dp"
        app:layout_constraintRight_toRightOf="@+id/acT1"
        app:layout_constraintBottom_toBottomOf="@+id/acT1"
        app:layout_constraintTop_toTopOf="@+id/acT1"
        android:alpha=".2"
        android:id="@+id/delButton"
        android:contentDescription="Delete Button" />

现在Java代码:

        AutoCompleteTextView acTV1 = findViewById(R.id.acT1);
        ImageView delButton = findViewById(R.id.delButton);
        final ArrayAdapter<String> arrayAdapter = new ArrayAdapter<>(
            this, android.R.layout.simple_list_item_1, getResources()
            .getStringArray(R.array.Gender_Names));
        String selection;
        acTV1.setAdapter(arrayAdapter);
        acTV1.setCursorVisible(false);
        acTV1.setOnItemClickListener(new AdapterView.OnItemClickListener() {

            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                acTV1.showDropDown();              
                selection = (String) parent.getItemAtPosition(position);
                Toast.makeText(getApplicationContext(), selection,
                Toast.LENGTH_SHORT);
                delButton.setAlpha(.8f);
            }
        });

        acTV1.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(final View arg0) {
                acTV1.showDropDown();
            }
        });

        delButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                acTV1.setText(null);
                delButton.setAlpha(.2f);
                selection = null;                               
            }
        });

和Gender_Names数组,在strings.xml中定义:

 <string-array name="Gender_Names">
    <item>Male</item>
    <item>Female</item>  
    <item>Other</item>      
</string-array>

这是它的样子:

  1. 选择了一些数据

除非您不使用 ConstraintLayout,否则整件事都是 copy-paste。

更改为 signup_input_gender 使用 AutoCompleteTextView,其 showDropDown() 将显示列表(在 R.array.Gender_Names 的资源中定义)

fun setupGenderWithDropdown() {
        val genderEditText = findViewById(R.id.signup_input_gender)
        val arrayAdapter = ArrayAdapter(
            this, android.R.layout.simple_list_item_1, resources.getStringArray(R.array.Gender_Names)
        )
        genderEditText.setAdapter(arrayAdapter)
        genderEditText.setOnClickListener {
            genderEditText.showDropDown()
        }
    }