以字符串的形式显示当前时间
更多方法及属性请查看官方API
API17+
提供一个选择日期的窗口小部件
更多方法及属性请查看官方API
// 获取日历对象
Calendar calendar = Calendar.getInstance();
// 获取当前对应的年、月、日的信息
year = calendar.get(Calendar.YEAR);
month = calendar.get(Calendar.MONTH) + 1;
day = calendar.get(Calendar.DAY_OF_MONTH);
// 获取当前时间信息
hour=calendar.get(Calendar.HOUR_OF_DAY);
minute=calendar.get(Calendar.MINUTE);
//1.findViewById
DatePicker datePicker = (DatePicker) findViewById(R.id.dp_pro);
//2.使用init()方法初始化DatePicker在刷新Spinner之前显示的日期;并设置OnDateChangedListener,监听器可以为空。这里使用activity implements OnDateChangedListener
datePicker.init(year,monthOfYear,dayOfMonth,this);
//设置OnDateChangedListener后重写的方法,修改DatePicker里的年、月、日时触发
@Override
public void onDateChanged(DatePicker view, int year, int monthOfYear, int dayOfMonth) {
if (view.getId()==R.id.dp_pro){
datePro=year+"-"+(monthOfYear+1)+"-"+dayOfMonth+" ";//这里月份值+1,因为获取的月份值比正常月份值小1
tvTimePro.setText(datePro+timePro);
Log.d(TAG, "onDateChanged: "+datePro);
}else if (view.getId()==R.id.dp_custom){
dateCustom=year+"-"+(monthOfYear+1)+"-"+dayOfMonth+" ";
tvTimeCustom.setText(dateCustom+timeCustom);
Log.d(TAG, "onDateChanged: "+dateCustom);
}
}
另外DatePicker支持直接输入日期值(长按就可以,仅限于在spinner模式下)
提供一个选择时间的窗口小部件
更多方法及属性请查看官方API
timePicker_custom = (TimePicker) findViewById(R.id.tp_custom);
//24小时制
timePicker_custom.setIs24HourView(true);
//为timePicker添加监听器,不可为空。修改TimePicker里的时、分时触发
timePicker_custom.setOnTimeChangedListener(new TimePicker.OnTimeChangedListener() {
@Override
public void onTimeChanged(TimePicker view, int hourOfDay, int minute) {
timeCustom=hourOfDay+":"+minute;
tvTimeCustom.setText(dateCustom+timeCustom);
Log.d(TAG, "onTimeChanged: "+timeCustom);
}
});
TimePicker也支持直接输入日期值(长按就可以,仅限于在spinner模式下)
Class that implements a simple timer
更多方法及属性请查看官方API
Chronometer chron= (Chronometer) findViewById(R.id.chron);
//设置递增定时器参考的时间为系统时钟过去实时时间
chron.setBase(SystemClock.elapsedRealtime());
chron.start();
//设置当计时器更改时要调用的侦听器
chron.setOnChronometerTickListener(new Chronometer.OnChronometerTickListener() {
@Override
public void onChronometerTick(Chronometer chronometer) {
//action
}
});
ToggleButton tbn_chro = (ToggleButton) findViewById(R.id.tbn_chro);
tbn_chro.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
if (isChecked) {
// 开始计数。 这不影响从setBase(long)设置的基数,只是视图显示。
// 计时器通过定期将消息调度到处理程序,即使Widget不可见。 为了确保不会发生资源泄漏,
// 用户应确保每个start()调用都具有对stop()的相互调用。
chron.start();
} else {
// 停止计数。这不影响从setBase(long)设置的基数,只是视图显示。
// 这将停止向处理程序发送的消息,通过start()有效地释放将按照计时器运行的资源。
chron.stop();
}
}
});
CalendarView是用于显示和选择日期的日历小部件。此日历支持的日期范围是可配置的
CalendarView cal = (CalendarView) findViewById(R.id.cal_view);
cal.setOnDateChangeListener(new CalendarView.OnDateChangeListener() {
@Override
public void onSelectedDayChange(@NonNull CalendarView view, int year, int month, int dayOfMonth) {
//action
}
});
与DatePicker和TimePicker的区别在于DatePicker和TimePicker是显示在屏幕画面上的,而DatePickerDialog和TimePickerDialog对象则是以弹出Dialog的方式来显示
new DatePickerDialog(this, new DatePickerDialog.OnDateSetListener() {
@Override
public void onDateSet(DatePicker view, int year, int month, int dayOfMonth) {
Toast.makeText(MainActivity.this, "DatePickerDialog "+year + "-" + (month + 1) + "-" + dayOfMonth, Toast.LENGTH_SHORT).show();
}
}, year, month, day).show();
new TimePickerDialog(this, new TimePickerDialog.OnTimeSetListener() {
@Override
public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
Toast.makeText(MainActivity.this, "TimePickerDialog " + hourOfDay + ":" + minute, Toast.LENGTH_SHORT).show();
}
}, hour, minute, true).show();
用于数字选择
NumberPicker numberPicker= (NumberPicker) findViewById(R.id.num_pick);
// 设置NumberPicker属性
numberPicker.setMinValue(minNum);
numberPicker.setMaxValue(maxNum);
numberPicker.setValue(currentNum);
// 监听数值改变事件
numberPicker.setOnValueChangedListener(new NumberPicker.OnValueChangeListener() {
@Override
public void onValueChange(NumberPicker picker, int oldVal, int newVal) {
currentNum = newVal;
Toast.makeText(MainActivity.this, "currentNum= "+currentNum, Toast.LENGTH_SHORT).show();
}
});