Android日期时间选择器对话框

时间:2020-02-23 14:28:52  来源:igfitidea点击:

Android日期时间选择器在android应用程序中经常使用。
在本教程中,我们将演示在Android应用程序中如何使用日期选择器和计时器选择器对话框。
这些组件用于在自定义的用户界面中选择日期和时间。
我们将在我们的android应用程序代码中将DatePickerDialogTimePickerDialog类与Calendar类结合使用。

Android DatePickerDialog和TimePickerDialog

尽管可以将Date Picker和Time Picker用作独立的小部件,但是它们在屏幕上占据了更多空间。
因此,在对话框中使用它们是更好的选择。
幸运的是,android提供了自己的DatePickerDialog和TimePickerDialog类。

DatePickerDialog和TimePickerDialog类分别具有onDateSetListener()和onTimeSetListener()回调方法。
当用户分别填写日期和时间后,将调用这些回调方法。

DatePickerDialog类包含5个参数的构造函数,并带有下面列出的参数。

  • Context:它需要应用程序上下文
  • CallBack函数:onDateSet():用户使用以下参数设置日期时,会调用
  • int year:它将存储对话框中当前选择的年份
  • int monthOfYear:它将存储对话框中当前选择的月份
  • int dayOfMonth:它将存储对话框中当前选择的日期
  • int mYear:当对话框弹出时,它显示当前年份
  • int mMonth:显示弹出对话框时显示的当前月份
  • int mDay:显示弹出对话框时显示的当前日期

TimePickerDialog类由5个参数的构造函数以及下面列出的参数组成。

  • Context:它需要应用程序上下文
  • CallBack Function:当用户使用以下参数设置时间时,调用onTimeSet():
  • int hourOfDay:它将存储对话框中当前选定的一天中的小时
  • int minutes:它将存储对话框中当前选择的分钟
  • int mHours:当对话框弹出时,它显示当前的小时数
  • int mMinute:显示弹出对话框时显示的当前分钟
  • boolean false:如果将其设置为false,则将以24小时格式显示时间,否则不显示

Android日期时间选择器对话框项目代码

" activity_main.xml"由两个按钮组成,以调用"日期和时间选择器"对话框并在两个EditText视图中设置用户选择的时间。
xml代码如下。

activity_main.xml

<RelativeLayout xmlns:android="https://schemas.android.com/apk/res/android"
  xmlns:tools="https://schemas.android.com/tools" android:layout_width="match_parent"
  android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
  android:paddingRight="@dimen/activity_horizontal_margin"
  android:paddingTop="@dimen/activity_vertical_margin"
  android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">

  <EditText
      android:layout_width="200dp"
      android:layout_height="wrap_content"
      android:id="@+id/in_date"
      android:layout_marginTop="82dp"
      android:layout_alignParentTop="true"
      android:layout_alignParentLeft="true"
      android:layout_alignParentStart="true" 

  <Button
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="SELECT DATE"
      android:id="@+id/btn_date"
      android:layout_alignBottom="@+id/in_date"
      android:layout_toRightOf="@+id/in_date"
      android:layout_toEndOf="@+id/in_date" 

  <EditText
      android:layout_width="200dp"
      android:layout_height="wrap_content"
      android:id="@+id/in_time"
      android:layout_below="@+id/in_date"
      android:layout_alignParentLeft="true"
      android:layout_alignParentStart="true" 

  <Button
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="SELECT TIME"
      android:id="@+id/btn_time"
      android:layout_below="@+id/btn_date"
      android:layout_alignLeft="@+id/btn_date"
      android:layout_alignStart="@+id/btn_date" 

</RelativeLayout>

MainActivity.java类如下所示:

package com.theitroad.datetimepickerdialog;

import android.app.DatePickerDialog;
import android.app.TimePickerDialog;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.DatePicker;
import android.widget.EditText;
import android.widget.TimePicker;

import java.util.Calendar;

public class MainActivity extends AppCompatActivity implements
      View.OnClickListener {

  Button btnDatePicker, btnTimePicker;
  EditText txtDate, txtTime;
  private int mYear, mMonth, mDay, mHour, mMinute;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);

      btnDatePicker=(Button)findViewById(R.id.btn_date);
      btnTimePicker=(Button)findViewById(R.id.btn_time);
      txtDate=(EditText)findViewById(R.id.in_date);
      txtTime=(EditText)findViewById(R.id.in_time);

      btnDatePicker.setOnClickListener(this);
      btnTimePicker.setOnClickListener(this);

  }

  @Override
  public void onClick(View v) {

      if (v == btnDatePicker) {

          //Get Current Date
          final Calendar c = Calendar.getInstance();
          mYear = c.get(Calendar.YEAR);
          mMonth = c.get(Calendar.MONTH);
          mDay = c.get(Calendar.DAY_OF_MONTH);

          DatePickerDialog datePickerDialog = new DatePickerDialog(this,
                  new DatePickerDialog.OnDateSetListener() {

                      @Override
                      public void onDateSet(DatePicker view, int year,
                                            int monthOfYear, int dayOfMonth) {

                          txtDate.setText(dayOfMonth + "-" + (monthOfYear + 1) + "-" + year);

                      }
                  }, mYear, mMonth, mDay);
          datePickerDialog.show();
      }
      if (v == btnTimePicker) {

          //Get Current Time
          final Calendar c = Calendar.getInstance();
          mHour = c.get(Calendar.HOUR_OF_DAY);
          mMinute = c.get(Calendar.MINUTE);

          //Launch Time Picker Dialog
          TimePickerDialog timePickerDialog = new TimePickerDialog(this,
                  new TimePickerDialog.OnTimeSetListener() {

                      @Override
                      public void onTimeSet(TimePicker view, int hourOfDay,
                                            int minute) {

                          txtTime.setText(hourOfDay + ":" + minute);
                      }
                  }, mHour, mMinute, false);
          timePickerDialog.show();
      }
  }
}

在上面的代码中,我们使用" Calendar.getInstance()"创建了一个Calendar对象,以使用相应的静态字段显示当前日期和时间。

注意:显示日历和时钟是AppCompat主题中提供的默认UI主题。