You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
hl-notes/java/net/micode/notes/ui/DateTimePickerDialog.java

172 lines
6.1 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

/*
* Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* 文件: DateTimePickerDialog.java
* 描述: 日期时间选择对话框
* 作用: 提供一个对话框界面,让用户可以选择日期和时间
* 功能:
* 1. 基于AlertDialog集成DateTimePicker控件
* 2. 提供确定和取消按钮
* 3. 自动更新对话框标题为当前选择的日期时间
* 4. 支持回调接口通知外部日期时间的设置
*/
package net.micode.notes.ui;
import java.util.Calendar;
import net.micode.notes.R;
import net.micode.notes.ui.DateTimePicker;
import net.micode.notes.ui.DateTimePicker.OnDateTimeChangedListener;
import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;
import android.text.format.DateFormat;
import android.text.format.DateUtils;
/**
* 日期时间选择对话框类
*
* 基于AlertDialog集成DateTimePicker控件提供一个完整的日期时间选择界面。
* 用户可以通过此对话框设置日期和时间,并通过回调接口将选择结果通知给调用者。
* 对话框标题会自动更新为当前选择的日期时间的格式化字符串。
*/
public class DateTimePickerDialog extends AlertDialog implements OnClickListener {
/** 存储当前选择的日期时间 */
private Calendar mDate = Calendar.getInstance();
/** 是否使用24小时制显示 */
private boolean mIs24HourView;
/** 日期时间设置监听器 */
private OnDateTimeSetListener mOnDateTimeSetListener;
/** 日期时间选择器控件 */
private DateTimePicker mDateTimePicker;
/**
* 日期时间设置监听器接口
* 当用户点击对话框的确定按钮时,通过此接口通知调用者
*/
public interface OnDateTimeSetListener {
/**
* 当日期时间被设置时调用
*
* @param dialog 触发事件的对话框
* @param date 用户选择的日期时间(毫秒)
*/
void OnDateTimeSet(AlertDialog dialog, long date);
}
/**
* 构造函数
*
* @param context 上下文环境
* @param date 初始日期时间(毫秒)
*/
public DateTimePickerDialog(Context context, long date) {
super(context);
// 创建日期时间选择器控件
mDateTimePicker = new DateTimePicker(context);
// 将选择器设置为对话框的内容视图
setView(mDateTimePicker);
// 设置日期时间变更监听器
mDateTimePicker.setOnDateTimeChangedListener(new OnDateTimeChangedListener() {
public void onDateTimeChanged(DateTimePicker view, int year, int month,
int dayOfMonth, int hourOfDay, int minute) {
// 更新日期对象
mDate.set(Calendar.YEAR, year);
mDate.set(Calendar.MONTH, month);
mDate.set(Calendar.DAY_OF_MONTH, dayOfMonth);
mDate.set(Calendar.HOUR_OF_DAY, hourOfDay);
mDate.set(Calendar.MINUTE, minute);
// 更新对话框标题为当前选择的日期时间
updateTitle(mDate.getTimeInMillis());
}
});
// 设置初始日期时间
mDate.setTimeInMillis(date);
// 将秒设置为0
mDate.set(Calendar.SECOND, 0);
// 设置选择器的当前日期
mDateTimePicker.setCurrentDate(mDate.getTimeInMillis());
// 设置确定按钮
setButton(context.getString(R.string.datetime_dialog_ok), this);
// 设置取消按钮(不需要监听器,点击会自动关闭对话框)
setButton2(context.getString(R.string.datetime_dialog_cancel), (OnClickListener)null);
// 根据系统设置决定是否使用24小时制
set24HourView(DateFormat.is24HourFormat(this.getContext()));
// 更新对话框标题
updateTitle(mDate.getTimeInMillis());
}
/**
* 设置是否使用24小时制显示时间
*
* @param is24HourView 如果为true使用24小时制否则使用12小时制
*/
public void set24HourView(boolean is24HourView) {
mIs24HourView = is24HourView;
}
/**
* 设置日期时间设置监听器
*
* @param callBack 监听器回调接口
*/
public void setOnDateTimeSetListener(OnDateTimeSetListener callBack) {
mOnDateTimeSetListener = callBack;
}
/**
* 更新对话框标题为格式化的日期时间字符串
*
* @param date 要显示的日期时间(毫秒)
*/
private void updateTitle(long date) {
// 设置日期时间格式化标志
int flag =
DateUtils.FORMAT_SHOW_YEAR | // 显示年份
DateUtils.FORMAT_SHOW_DATE | // 显示日期
DateUtils.FORMAT_SHOW_TIME; // 显示时间
// 根据是否使用24小时制设置相应的格式
flag |= mIs24HourView ? DateUtils.FORMAT_24HOUR : DateUtils.FORMAT_24HOUR;
// 设置对话框标题为格式化的日期时间字符串
setTitle(DateUtils.formatDateTime(this.getContext(), date, flag));
}
/**
* 确定按钮点击事件处理
*
* @param arg0 对话框接口
* @param arg1 按钮ID
*/
public void onClick(DialogInterface arg0, int arg1) {
// 如果设置了监听器,通知日期时间已设置
if (mOnDateTimeSetListener != null) {
mOnDateTimeSetListener.OnDateTimeSet(this, mDate.getTimeInMillis());
}
}
}