NumberPicker是Android3.0出的,在不同版本中的显示大概是这样的
如果要使得显示的小于10的数字显示两位,需要加上这样一个方法:
Formatter formatter = new Formatter() { @Override public String format(int value) { String tmpStr = String.valueOf(value); if (value < 10) { tmpStr = "0" + tmpStr; } return tmpStr; } }; numberPicker.setFormatter(formatter);
这是设置最小值
numberPicker.setMinValue(0); numberPicker.setMaxValue(23); numberPicker.setValue(17);
这是监听滑动,基本用不到
numberPicker.setOnValueChangedListener(new OnValueChangeListener() { @Override public void onValueChange(NumberPicker picker, int oldVal, int newVal) { Log.e("", "oldVal:" + oldVal + "newVal:" + newVal); } });
获取当前值
int value = numberPicker.getValue();
然后网上找了点教程,通过新建类来继承NumberPicker,但只能修改字体颜色和大小,没法改变中间那两条线的颜色,尺寸.
就是重写所有addView方法,然后在addView()中添加自定义的方法
public void addView(View child) { super.addView(child); updateView(child); } @Override public void addView(View child, int index, android.view.ViewGroup.LayoutParams params) { super.addView(child, index, params); updateView(child); } @Override public void addView(View child, android.view.ViewGroup.LayoutParams params) { super.addView(child, params); updateView(child); } public void updateView(View view) { if (view instanceof EditText) { // 这里修改字体的属性 ((EditText) ((EditText) view).setTextSize(12); ((EditText) view).setTextColor(Color.RED); } }
因为这样还是没法随心所欲,所以只好网上找了些例子,都是通过copy源代码的NumberPicker类的代码来自定义,直接继承的LinearLayout.当然少不了declare-styleable style之类的,比较麻烦.
首先,这个比较简单
然后还有一个比较好的,完全可以改一下当时间 日期 选择器
但有点问题要自己改,这是博主传的文件
http://download.csdn.net/detail/the_path/7713987