1. 程式人生 > >Android顯示時間和日期的控制元件的使用總結

Android顯示時間和日期的控制元件的使用總結

獲取年月日,之前的日期不能選擇

日曆c = Calendar.getInstance(); //獲取系統的工具類【可以獲取時間】
                DatePickerDialog datePickerDialog = new DatePickerDialog(context,new DatePickerDialog.OnDateSetListener(){
                    @覆蓋
                    public void onDateSet(DatePicker view,int year,int month,int dayOfMonth){
                        月+ = 1;
                        yuyueTime.setText(year +“ - ”+ month +“ - ”+ dayOfMonth);
                    }
                },c.get(Calendar.YEAR),c.get(Calendar.MONTH),c.get(Calendar.DATE)); //設定預設時間
                。datePickerDialog.getDatePicker()setMinDate(c.getTime()的getTime()); //設定最小值
                datePickerDialog.show();

相關類的認識
選取器(的DatePicker,TimerPicker,NumberPicker)
其中的DatePicker和TimerPicker都有視窗的形式顯示日期和時間,再返回資料。

下面分別介紹這幾種時間類的使用方法。

一.DatePicker日期選擇類的使用

DatePicker的常用的XML屬性

XML屬性 描述
機器人:calendarViewShown 設定該日期選擇是否顯示CalendarView元件。
機器人:endYear 設定日期選擇器允許選擇的最後一年。
安卓的maxDate 設定該日期選擇器的最大日期。以MM / DD / YYYY格式指定最大日期。
安卓的minDate 設定該日期選擇器的最小日期。以MM / DD / YYYY格式指定最小日期。
機器人:spinnersShown 設定該日期選擇器是否顯示微調日期選擇元件。
機器人:startYear 設定日期選擇器允許選擇的第一年。


當用戶更改了的DatePicker裡的年,月,日時,將觸發OnDateChangedListener監聽器的onDateChange()事件。

二.TimePicker日期選擇類的使用


當用戶更改了TimePicker裡的時,分時,將觸發OnTimeChangedListener監聽器的onTimeChanged事件。

下面是日期選擇類和時間選擇類的一個使用示例:

(一)佈局檔案設計

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:text="顯示日期的控制元件" />

    <DatePicker
        android:id="@+id/main_dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:text="顯示時間的控制元件" />

    <TimePicker
        android:id="@+id/main_tp_showTime"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

    <TextView
        android:id="@+id/main_tv_showdate"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="顯示日期" />

    <TextView
        android:id="@+id/main_tv_showtime"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="顯示時間" />

</LinearLayout>
  • 1

(二)主程式碼設計

package com.example.timer;
import java.util.Calendar;
import android.app.Activity;
import android.os.Bundle;
import android.widget.DatePicker;
import android.widget.DatePicker.OnDateChangedListener;
import android.widget.TextView;
import android.widget.TimePicker;
import android.widget.TimePicker.OnTimeChangedListener;

public class MainActivity extends Activity {

    int year = 0;
    int monthOfYear = 0;
    int dayOfMonth = 0;
    int minute = 0;
    int houre = 0;
    TextView showDate = null;
    TextView showtime = null;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
        showDate(year, monthOfYear + 1, dayOfMonth);
        showTime(houre, minute);
    }

    private void initView() {
        // 日期控制元件物件
        DatePicker date = (DatePicker) findViewById(R.id.main_dp);
        // 獲得日曆物件
        Calendar c = Calendar.getInstance();
        // 獲取當前年份
        year = c.get(Calendar.YEAR);
        // 獲取當前月份
        monthOfYear = c.get(Calendar.MONTH);
        // 獲取當前月份的天數
        dayOfMonth = c.get(Calendar.DAY_OF_MONTH);
        // 獲取當前的小時數
        houre = c.get(Calendar.HOUR_OF_DAY);
        // 獲取當前的分鐘數
        minute = c.get(Calendar.MINUTE);

        // 時間顯示的文字物件
        showDate = (TextView) findViewById(R.id.main_tv_showdate);

        // 為日期設定監聽事件
        date.init(year, monthOfYear, dayOfMonth, new OnDateChangedListener() {

            @Override
            public void onDateChanged(DatePicker view, int year,
                    int monthOfYear, int dayOfMonth) {
                MainActivity.this.year = year;
                MainActivity.this.monthOfYear = monthOfYear;
                MainActivity.this.dayOfMonth = dayOfMonth;
                showDate(year, monthOfYear + 1, dayOfMonth);

            }

        });

        // 顯示時間的文字控制元件
        showtime = (TextView) findViewById(R.id.main_tv_showtime);

        // 時間顯示的控制元件
        TimePicker time = (TimePicker) findViewById(R.id.main_tp_showTime);
        // 為時間控制元件設定監聽事件
        time.setOnTimeChangedListener(new OnTimeChangedListener() {

            @Override
            public void onTimeChanged(TimePicker view, int hourOfDay, int minute) {
                showTime(hourOfDay, minute);
            }
        });

    }

        //顯示日期的方法
    private void showDate(int year, int monthOfYear, int dayOfMonth) {
        showDate.setText("日期是:" + year + "年" + monthOfYear + "月" + dayOfMonth
                + "日");

    }

    //顯示時間的方法
    private void showTime(int houre2, int minute2) {
        showtime.setText("時間是:" + houre2 + "時" + minute2 + "分");

    }

}
  • 1


執行後顯示的結果:

時間的DatePicker

可以從執行結果直接看到,控制元件的顯示,可以上下拖動選擇自己想要的日期和時間,但是,我們看到這樣做是比較佔螢幕空間的。所以後面介紹的用視窗選擇日期和時間是比較常用的。

三。DatePickerDialog

DatePickerDialog和TimePickerDialog,與的DatePicker和TimePicker,最大的區別是的DatePicker和TimePicker是直接顯示在螢幕畫面上的,而DatePickerDialog和TimePickerDialog物件則是以彈出對話方塊的方式來顯示。

建立DatePickerDialog的語法如下:

DatePickerDialog(Context context, DatePickerDialog.OnDateSetListener callBack, int year, int monthOfYear, int dayOfMonth)
  • 1

引數說明:
上下文:當前上下文;
回撥:OnDateSetListener日期改變監聽器;
年:初始化的年;
monthOfYear:初始化的月(從0開始計數,所以實際應用時需要加1);
請將dayOfMonth:初始化的日;
當用戶更改了DatePickerDialog裡的年,月,日時,將觸發OnDateSetListener監聽器的onDateSet()事件。

四。TimePickerDialog

建立TimePickerDialog的語法如下:

TimePickerDialog(Context context, TimePickerDialog.OnTimeSetListener listener, int hourOfDay, 
int minute, boolean is24HourView)
  • 1

引數說明:
上下文:當前上下文;
聽眾:時間改變監聽器;
hourOfDay:初始化的小時;
分鐘:
初始化的分鐘; is24HourView:是否以24小時顯示時間;
當用戶更改了TimePickerDialog裡的時,分時,將觸發OnTimeSetListener監聽器的onTimeSet()事件。

下面是日期和時間以視窗的形式顯示的示例:

(一)佈局檔案設計

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="getDate"
        android:text="設定日期" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="getTime"
        android:text="設定時間" />

    <TextView
        android:id="@+id/dialog_tv_date"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="getTime"
        android:text="日期:" />

    <TextView
        android:id="@+id/dialog_tv_time"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="時間:" />

</LinearLayout>
  • 1

(二)程式碼設計

package com.java.pickerDialog;
import com.example.timer.R;

import android.app.Activity;
import android.app.DatePickerDialog;
import android.app.TimePickerDialog;
import android.os.Bundle;
import android.view.View;
import android.widget.DatePicker;
import android.widget.TextView;
import android.widget.TimePicker;

public class PickerDialog extends Activity {

    TextView tv_date = null;
    TextView tv_time = null;
    int year = 2016;
    int month = 10;
    int day = 8;
    int houre = 15;
    int minute = 20;

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

    private void initView() {
        tv_date = (TextView) findViewById(R.id.dialog_tv_date);
        tv_time = (TextView) findViewById(R.id.dialog_tv_time);
    }

    // 點選事件,湖區日期
    public void getDate(View v) {

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

            @Override
            public void onDateSet(DatePicker view, int year, int monthOfYear,
                    int dayOfMonth) {
                PickerDialog.this.year = year;
                month = monthOfYear;
                day = dayOfMonth;

            }
        }, 2016, 10, 8).show();
        showDate();
    }

    // 點選事件,湖區日期
    public void getTime(View v) {
        new TimePickerDialog(this, new TimePickerDialog.OnTimeSetListener() {

            @Override
            public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
                houre = hourOfDay;
                PickerDialog.this.minute = minute;
            }
        }, 15, 20, true).show();
        showTime();
    }

    // 顯示選擇日期
    private void showDate() {
        tv_date.setText("你選擇的日期是:" + year + "年" + month + "月" + day + "日");
    }

    // 顯示選擇日期
    private void showTime() {
        tv_time.setText("你選擇的時間是:" + houre + "時" + minute + "分");
    }

}
  • 1


執行後顯示的介面:

對話方塊時間類1

點選日期按鈕後

點選日期類

點選時間按鈕後

點選時間類

之後顯示的效果

時間類顯示後結果

這個以對話方塊的形式來選擇時間還是比較常見的。而且使用者體驗也是比較好的。

五。NumberPicker

NumberPicker是數值選擇器,用於讓使用者輸入數值,使用者既可以通過鍵盤輸入數值,也可以通過拖動來選擇數值。

NumberPicker的常用方法如下:

方法 描述
setMinValue(int minVal) 設定該元件支援的最小值。
setMaxValue(int maxVal) 設定該元件支援的最大值。
setValue(int value) 設定該元件的當前值。
getMaxValue() 獲得該元件設定的最大值。
getMinValue() 獲得該元件設定的最小值。
的getValue() 獲得當前元件顯示的值。
setValue(int value) 設定當前元件顯示的值。

使用NumberPicker讓使用者選擇年月日的示例:

(一)佈局檔案設計

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <TableLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center" >

        <TableRow
            android:layout_width="match_parent"
            android:layout_height="wrap_content" >

            <TextView
                android:layout_margin="5dp"
                android:background="#e2a617"
                android:gravity="center"
                android:text="年"
                android:textSize="20sp" />

            <TextView
                android:layout_margin="5dp"
                android:background="#0d637f"
                android:gravity="center"
                android:text="月"
                android:textSize="20sp" />

            <TextView
                android:layout_margin="5dp"
                android:background="#aa2266"
                android:gravity="center"
                android:text="日"
                android:textSize="20sp" />
        </TableRow>

        <TableRow
            android:layout_width="match_parent"
            android:layout_height="wrap_content" >

            <NumberPicker
                android:id="@+id/number_np_year"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content" />

            <NumberPicker
                android:id="@+id/number_np_month"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content" />

            <NumberPicker
                android:id="@+id/number_np_day"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content" />
        </TableRow>
    </TableLayout>

    <TextView
        android:id="@+id/number_tv_year"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="日期:" />

</LinearLayout>
  • 1

(二)的Java程式碼的設計

package com.java.timepicker;
import android.app.Activity;
import android.os.Bundle;
import android.widget.NumberPicker;
import android.widget.NumberPicker.OnValueChangeListener;
import android.widget.TextView;

import com.example.timer.R;

public class NumberPickerActivity extends Activity {

    NumberPicker num_year = null;
    NumberPicker num_month = null;
    NumberPicker num_day = null;
    TextView tv_year = null;
    int year = 2016;
    int month = 10;
    int day = 8;

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

    }

    private void initView() {
        // 例項化NumberPicker物件
        num_year = (NumberPicker) findViewById(R.id.number_np_year);
        num_month = (NumberPicker) findViewById(R.id.number_np_month);
        num_day = (NumberPicker) findViewById(R.id.number_np_day);
        // 例項化顯示年份的文字物件F
        tv_year = (TextView) findViewById(R.id.number_tv_year);
        initYear();
        initMonth();
        initDay();
    }

    private void initYear() {
        // 設定NumberPicker物件的相關屬性
        num_year.setMaxValue(100000);
        num_year.setMinValue(1900);
        num_year.setValue(2016);
        // 為NumberPicker設定監聽事件
        num_year.setOnValueChangedListener(new OnValueChangeListener() {

            @Override
            public void onValueChange(NumberPicker picker, int oldVal,
                    int newVal) {
                year = newVal;
                showDate();
            }
        });

    }

    private void initMonth() {
        // 設定NumberPicker物件的相關屬性
        num_month.setMaxValue(12);
        num_month.setMinValue(1);
        num_month.setValue(10);
        // 為NumberPicker設定監聽事件
        num_month.setOnValueChangedListener(new OnValueChangeListener() {

            @Override
            public void onValueChange(NumberPicker picker, int oldVal,
                    int newVal) {
                month = newVal;
                showDate();
            }
        });

    }

    private void initDay() {
        // 設定NumberPicker物件的相關屬性
        num_day.setMaxValue(31);
        num_day.setMinValue(1);
        num_day.setValue(8);
        // 為NumberPicker設定監聽事件
        num_day.setOnValueChangedListener(new OnValueChangeListener() {
            @Override
            public void onValueChange(NumberPicker picker, int oldVal,
                    int newVal) {
                day = newVal;
                showDate();
            }
        });

    }

    void showDate() {
        tv_year.setText("你選擇的日期是:" + year + "年" + month + "月" + day + "日");

    }

}
  • 1


程式執行後的效果:

NumberPicker執行後


選擇日期之後的效果

NumberPicker選擇後

可以看到同樣可以顯示出日期。
這裡是用來三個NumberPicker控制元件才能有這個效果,如果要具體時間要多加兩個NumberPicker控制元件,就可以了。
但是這樣做相對來的要出來的資料還是比較多一點的。


以上就是時間控制元件的使用的方法和簡單使用,總的來的還是以視窗的形式來顯示還是比較符合設計思想的,也是我們要重點掌握的。