如何更改数字选择器以显示加号和减号按钮

how to change numberpicker to show plus and minus buttons

我有一个数字选择器 -

 <NumberPicker
                android:id="@+id/shopping_cart_holder_quantity_picker"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:fontFamily="@font/noto_sans"
                app:layout_constraintBottom_toBottomOf="parent"
                app:layout_constraintEnd_toEndOf="parent"
                app:layout_constraintHorizontal_bias="0.5"
                app:layout_constraintStart_toStartOf="parent"
                app:layout_constraintTop_toTopOf="parent" />

我正在尝试实现如下图所示的数字选择器 -

是的,这是在 iOS。我想知道如何在 Android 中实现同样的事情。

您只需使用 android 库即可实现此效果。我建议 this 一个。

只需将以下行添加到您的 gradle 文件中:

compile 'com.github.travijuu:numberpicker:1.0.7'

然后您可以像这样在 .xml 文件中实现号码选择器:

<com.travijuu.numberpicker.library.NumberPicker
    android:id="@+id/number_picker"
    android:layout_width="130dp"
    android:layout_height="40dp"
    numberpicker:min="0"
    numberpicker:max="10"
    numberpicker:value="-5"
    numberpicker:unit="1"
    numberpicker:focusable="false"
    numberpicker:custom_layout="@layout/number_picker_custom_layout" />

您可以像这样自定义您的选择器:

    NumberPicker numberPicker = (NumberPicker) findViewById(R.id.number_picker);
    numberPicker.setMax(15);
    numberPicker.setMin(5);
    numberPicker.setUnit(2);
    numberPicker.setValue(10);

您不需要使用任何库来实现此功能 android.You 可以使用您的自定义视图并编写最少的代码来增加和减少 quantity.i 有一个例子,请查看这个.

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<android.support.constraint.ConstraintLayout
    android:id="@+id/constraint_inner"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    app:layout_constraintTop_toTopOf="parent"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintEnd_toEndOf="parent">

   <ImageView
    android:id="@+id/imgMinus"
    android:layout_width="30dp"
    android:layout_height="30dp"
    android:padding="5dp"
    android:src="@drawable/minus"
    app:layout_constraintTop_toTopOf="parent"
    app:layout_constraintStart_toStartOf="parent"/>

    <TextView
        android:id="@+id/txtNumbers"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="0"
        android:textSize="24dp"
        android:layout_marginStart="24dp"
        android:inputType="number"
        android:textColor="@android:color/black"
        app:layout_constraintTop_toTopOf="@+id/imgMinus"
        app:layout_constraintBottom_toBottomOf="@id/imgMinus"
        app:layout_constraintStart_toEndOf="@+id/imgMinus"/>

    <ImageView
        android:id="@+id/imgPlus"
        android:layout_width="30dp"
        android:layout_height="30dp"
        android:layout_marginStart="24dp"
        android:src="@drawable/plus"
        android:padding="5dp"
        app:layout_constraintStart_toEndOf="@+id/txtNumbers"
        app:layout_constraintTop_toTopOf="parent" />
  </android.support.constraint.ConstraintLayout>
  </android.support.constraint.ConstraintLayout>

在您的 class 文件中获取一个全局变量以在您的 TextView 上设置新的数量并设置加号和减号图标的点击事件。

int num=0;(全局变量)

1-点击加号图标=>

       num++;
      setText();

2-点击减号图标=>

      if(num>0){
          num--;
         }
        setText();

setText 是一个用于在 textview 中更新数量的函数

   public void setText(){
     txtNumber.setText(num+"");
}