アンドロイドの日付時刻選択ダイアログ

Androidアプリでよく使用されるのは、Android Date Time pickerです。このチュートリアルでは、AndroidアプリケーションでのDate PickerとTime Pickerダイアログの使用方法を示します。これらのコンポーネントは、カスタマイズされたユーザーインターフェースで日付と時間を選択するために使用されます。このために、DatePickerDialogクラスとTimePickerDialogクラスをCalendarクラスと組み合わせてAndroidアプリケーションのコードで使用します。

AndroidのDatePickerDialogとTimePickerDialog

デートピッカーやタイムピッカーは独立したウィジェットとして使用することができますが、画面上でより多くのスペースを占有します。そのため、それらをダイアログの中に使用することが良い選択です。幸いにも、Androidには自身のDatePickerDialogとTimePickerDialogクラスが提供されています。DatePickerDialogとTimePickerDialogクラスには、それぞれonDateSetListener()とonTimeSetListener()のコールバックメソッドが備わっています。これらのコールバックメソッドは、ユーザーが日付や時間を入力し終えた時に呼び出されます。DatePickerDialogクラスは、以下にリストされたパラメータを持つ5つの引数を受け取るコンストラクタから構成されています。

    1. 文脈: アプリケーションのコンテキストが必要です

 

    コールバック関数: onDateSet()は、ユーザーが日付を設定したときに以下のパラメーターを使用して呼び出されます。
  • int year : It will be store the current selected year from the dialog
  • int monthOfYear : It will be store the current selected month from the dialog
  • int dayOfMonth : It will be store the current selected day from the dialog
    1. int mYear: ダイアログが表示される際に表示される現在の年を示します。

 

    1. int mMonth: ダイアログが表示される際に表示される現在の月を示します。

 

    int mDay: ダイアログが表示される際に表示される現在の日を示します。

TimePickerDialogクラスは、以下にリストされているパラメータを持つ5つの引数のコンストラクタで構成されています。

    1. 文脈:アプリケーションのコンテキストが必要です

 

    コールバック関数:onTimeSet()は、ユーザーが次のパラメータで時間を設定したときに呼び出されます。
  • int hourOfDay : It will be store the current selected hour of the day from the dialog
  • int minute : It will be store the current selected minute from the dialog
    1. int mHours : ダイアログが表示されるときに表示される現在の時間を示します。

 

    1. int mMinute : ダイアログが表示されるときに表示される現在の分を示します。

 

    boolean false : falseに設定されている場合、24時間形式で時刻が表示されます。それ以外の場合は表示されません。

Androidの日付時刻ピッカーの例のプロジェクト構造

Androidの日付と時刻の選択ダイアログのプロジェクトコード

activity_main.xmlには、日付と時刻のピッカーダイアログを呼び出すための2つのボタンと、ユーザーが選択した時間を2つのEditTextビューに設定する機能が含まれています。以下に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.scdev.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テーマです。以下は、私たちのAndroidの日時ピッカーの例アプリケーションによって生成される出力です。これでAndroidの日時ピッカーダイアログの例チュートリアルは終わりです。最終的なAndroid DateTimePickerDialogプロジェクトは、以下のリンクからダウンロードできます。

Androidの日時ピッカープロジェクトをダウンロードしてください。

コメントを残す 0

Your email address will not be published. Required fields are marked *