(一)在Android 4.0以上系统的某些手机(如本人的测试机红米Note(系统4.4.4),以及模拟器(系统4.0)),使用如下代码创建时间选择器时,页面效果如图:
Calendar cal = Calendar.getInstance(); DatePickerDialog dialog = new DatePickerDialog(this, new DatePickerDialog.OnDateSetListener() { @Override public void onDateSet(DatePicker view, int year, int monthOfYear, int dayOfMonth) { System.out.println("onDateSet~~onDateSet~~"); } }, cal.get(Calendar.YEAR), cal.get(Calendar.MONTH), cal.get(Calendar.DAY_OF_MONTH));效果图:
问题来了,对话框上没有“取消”按钮!而且,即使通过返回键或者点击空白区域关闭了对话框,onDateSet方法依然会被回调,也就是上述代码中的onDateSet~~onDateSet~~这个log依然会输出!
仔细测试后会发现,点击返回键或者空白区域以关闭对话框时,onDateSet会被回调一次;点击“完成”按钮时,onDateSet会被回调两次。奇葩!!!
后来又测试发现,这段代码在基于android 5.0的CM系统上是没有问题的:对话框上面有“完成”按钮和“取消”按钮,点击“完成”时onDateSet被回调一次,点击“取消”时onDateSet不会被回调。这才是最好的效果!
(二)其实,想在对话框上加一个取消按钮很简单,加上如下代码即可:
dialog.setButton(DialogInterface.BUTTON_NEGATIVE,"取消",new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { System.out.println("cancel~~cancel~~"); } });然后效果图:
但是,问题并没有解决。因为即使点击取消按钮,onDateSet方法依然会被回调。也就是说,点击“取消”、点击手机返回键、点击空白区域 这3种操作的结果是一样的!
(三)解决方案:
很简单,不使用OnDateSetListener,而直接手动设置“完成”按钮和“取消”按钮的事件。完整代码如下:
public void pickDate(View view) { Calendar cal = Calendar.getInstance(); final DatePickerDialog mDialog = new DatePickerDialog(this, null, cal.get(Calendar.YEAR), cal.get(Calendar.MONTH), cal.get(Calendar.DAY_OF_MONTH)); //手动设置按钮 mDialog.setButton(DialogInterface.BUTTON_POSITIVE, "完成", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { //通过mDialog.getDatePicker()获得dialog上的DatePicker组件,然后可以获取日期信息 DatePicker datePicker = mDialog.getDatePicker(); int year = datePicker.getYear(); int month = datePicker.getMonth(); int day = datePicker.getDayOfMonth(); System.out.println(year + "," + month + "," + day); } }); //取消按钮,如果不需要直接不设置即可 mDialog.setButton(DialogInterface.BUTTON_NEGATIVE, "取消", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { System.out.println("BUTTON_NEGATIVE~~"); } }); mDialog.show(); }