Bootstrap

android NumberPicker隐藏分割线或修改颜色

在 Android 中,可以通过以下几种方法隐藏 NumberPicker 的分割线:

使用 XML 属性设置

在布局文件中的 NumberPicker 标签内添加 android:selectionDividerHeight="0dp" 属性,将分割线的高度设置为 0,从而达到隐藏分割线的效果,示例代码如下 :

<NumberPicker
    android:id="@+id/number_picker"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:selectionDividerHeight="0dp" />

通过代码动态设置

在 Java 代码中,可以使用 NumberPickersetSelectionDividerHeight 方法将分割线高度设置为 0,示例代码如下 :

NumberPicker numberPicker = findViewById(R.id.number_picker);
numberPicker.setSelectionDividerHeight(0);

使用反射机制

通过反射获取 NumberPicker 中的 mSelectionDivider 字段,并将其设置为 null,从而隐藏分割线。以下是一个示例代码 :

import android.content.Context;
import android.util.AttributeSet;
import android.widget.NumberPicker;
import java.lang.reflect.Field;

public class ExtendedNumberPicker extends NumberPicker {
    public ExtendedNumberPicker(Context context, AttributeSet attrs) {
        super(context, attrs);
        try {
            Class<?> numberPickerClass = Class.forName("android.widget.NumberPicker");
            Field selectionDivider = numberPickerClass.getDeclaredField("mSelectionDivider");
            selectionDivider.setAccessible(true);
            selectionDivider.set(this, null);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

使用主题样式设置

styles.xml 文件中定义一个新的主题样式,将 colorControlNormal 属性设置为透明色,然后将该主题应用到 NumberPicker 上,示例代码如下 :

<style name="DefaultNumberPickerTheme" parent="AppTheme">
    <item name="colorControlNormal">@color/transparent</item>
</style>
<NumberPicker
    android:id="@+id/number_picker"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:theme="@style/DefaultNumberPickerTheme" />
;