ui代码注释

yanxingxv
STRIV1 8 months ago
parent 4110a39314
commit 5f14a22bde

@ -0,0 +1,98 @@
/*
* 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.
*/
package net.micode.notes.ui; // 定义类所在的包路径
import java.util.Calendar; // 引入Calendar类用于处理日期和时间
import net.micode.notes.R; // 引入R文件用于获取资源ID
import net.micode.notes.ui.DateTimePicker; // 引入自定义的DateTimePicker控件
import net.micode.notes.ui.DateTimePicker.OnDateTimeChangedListener; // 引入DateTimePicker控件的监听器
import android.app.AlertDialog; // 引入AlertDialog类用于创建对话框
import android.content.Context; // 引入Context类用于访问应用程序上下文
import android.content.DialogInterface; // 引入DialogInterface类用于处理对话框的按钮事件
import android.content.DialogInterface.OnClickListener; // 引入OnClickListener接口用于按钮点击事件
import android.text.format.DateFormat; // 引入DateFormat类用于格式化日期和时间
import android.text.format.DateUtils; // 引入DateUtils类用于时间格式化与操作
// 定义一个自定义的DateTimePickerDialog类继承自AlertDialog
public class DateTimePickerDialog extends AlertDialog implements OnClickListener {
private Calendar mDate = Calendar.getInstance(); // 用于保存当前日期和时间
private boolean mIs24HourView; // 标记是否为24小时制显示
private OnDateTimeSetListener mOnDateTimeSetListener; // 回调接口,用于在日期和时间设置后通知调用者
private DateTimePicker mDateTimePicker; // 自定义的日期时间选择器
// 定义回调接口,用于在用户设置日期时间后进行处理
public interface OnDateTimeSetListener {
void OnDateTimeSet(AlertDialog dialog, long date); // 回调方法,传递设置的日期时间
}
// 构造函数,初始化对话框,设置默认日期时间
public DateTimePickerDialog(Context context, long date) {
super(context); // 调用父类构造函数初始化AlertDialog
mDateTimePicker = new DateTimePicker(context); // 初始化DateTimePicker控件
setView(mDateTimePicker); // 设置对话框的内容视图为DateTimePicker控件
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); // 将传入的日期时间(毫秒)设置为当前日期
mDate.set(Calendar.SECOND, 0); // 将秒设置为0
mDateTimePicker.setCurrentDate(mDate.getTimeInMillis()); // 设置DateTimePicker控件的初始日期
setButton(context.getString(R.string.datetime_dialog_ok), this); // 设置“确认”按钮,并指定点击时的行为
setButton2(context.getString(R.string.datetime_dialog_cancel), (OnClickListener)null); // 设置“取消”按钮
set24HourView(DateFormat.is24HourFormat(this.getContext())); // 设置是否为24小时制显示
updateTitle(mDate.getTimeInMillis()); // 初始化时更新对话框的标题
}
// 设置是否使用24小时制
public void set24HourView(boolean is24HourView) {
mIs24HourView = is24HourView;
}
// 设置日期时间设置完成后的回调监听器
public void setOnDateTimeSetListener(OnDateTimeSetListener callBack) {
mOnDateTimeSetListener = callBack;
}
// 更新对话框标题,显示当前选中的日期时间
private void updateTitle(long date) {
// 设置日期时间显示的格式
int flag =
DateUtils.FORMAT_SHOW_YEAR | // 显示年份
DateUtils.FORMAT_SHOW_DATE | // 显示日期
DateUtils.FORMAT_SHOW_TIME; // 显示时间
flag |= mIs24HourView ? DateUtils.FORMAT_24HOUR : DateUtils.FORMAT_24HOUR; // 如果是24小时制显示24小时格式
setTitle(DateUtils.formatDateTime(this.getContext(), date, flag)); // 格式化日期时间并设置为对话框标题
}
// 确认按钮点击事件的处理
public void onClick(DialogInterface arg0, int arg1) {
if (mOnDateTimeSetListener != null) {
// 调用回调接口,传递设置的日期时间
mOnDateTimeSetListener.OnDateTimeSet(this, mDate.getTimeInMillis());
}
}
}
Loading…
Cancel
Save