Android入门第23天-日历选择组件与时间选择组件

Posted TGITCIC

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android入门第23天-日历选择组件与时间选择组件相关的知识,希望对你有一定的参考价值。

介绍

DatePicker日期选择器,自带spinner和calendar两种模式,相关属性:

  • android:calendarTextColor : 日历列表的文本的颜色
  • android:calendarViewShown:是否显示日历视图
  • android:datePickerMode:组件外观,可选值:spinner,calendar 前者效果如下,默认效果是后者
  • android:dayOfWeekBackground:顶部星期几的背景颜色
  • android:dayOfWeekTextAppearance:顶部星期几的文字颜色
  • android:endYear:去年(内容)比如2010
  • android:firstDayOfWeek:设置日历列表以星期几开头
  • android:headerBackground:整个头部的背景颜色
  • android:headerDayOfMonthTextAppearance:头部日期字体的颜色
  • android:headerMonthTextAppearance:头部月份的字体颜色
  • android:headerYearTextAppearance:头部年的字体颜色
  • android:maxDate:最大日期显示在这个日历视图mm / dd / yyyy格式
  • android:minDate:最小日期显示在这个日历视图mm / dd / yyyy格式
  • android:spinnersShown:是否显示spinner
  • android:startYear:设置第一年(内容),比如19940年
  • android:yearListItemTextAppearance:列表的文本出现在列表中。
  • android:yearListSelectorColor:年列表选择的颜色
  • TimePicker时间选择器,只有一个属性android:timePickerMode设置spinner和clock(默认);
  • CalendarView日历选择器,相关属性:
  • android:firstDayOfWeek:设置一个星期的第一天
  • android:maxDate :最大的日期显示在这个日历视图mm/ dd /yyyy格式
  • android:minDate:最小的日期显示在这个日历视图mm/ dd /yyyy格式
  • android:weekDayTextAppearance:工作日的文本出现在日历标题缩写

DatePicker有两种Style

第一种:android:datePickerMode="calendar" 

第二种:android:datePickerMode="spinner" ,巨丑无比,就不要用了。

TimePicker同样也有两种Style

第一种:android:timePickerMode="clock" ,巨丑无比,就不要用了。

第二种:android:timePickerMode="spinner" 

 

这两个控件常常会在项目里被自定义,因为系统自带的不怎么好看。

另外就是它们支持的事件很简单。就是选择完日期、时间后的onDateChanged和onTimeChanged。

下面我们来看代码。

课程目标

  • 纵向摆放一个TimePicker,一个DatePicker;
  • 选择后系统打印用户选择的时间、日期至LogCat;

主界面代码 

 

<?xml version="1.0" encoding="utf-8"?>
<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"
    tools:context=".MainActivity">
 
    <TimePicker
        android:id="@+id/timePickerSpinner"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:timePickerMode="spinner" />
 
    <DatePicker
        android:id="@+id/datepickerCalendar"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:datePickerMode="calendar" />
 
 
</LinearLayout>

 后台交互代码

package org.mk.android.demo.demodatepicker;
 
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
 
import android.os.Bundle;
import android.util.Log;
import android.widget.DatePicker;
import android.widget.TimePicker;
 
import java.util.Calendar;
 
public class MainActivity extends AppCompatActivity 
    private DatePicker dp;
    private TimePicker tp;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        dp = (DatePicker) findViewById(R.id.datepickerCalendar);
        tp=(TimePicker) findViewById(R.id.timePickerSpinner);
        dp.setOnDateChangedListener(new OnDateChanged());
        tp.setOnTimeChangedListener(new OnTimeChanged());
    
 
    private class OnDateChanged implements DatePicker.OnDateChangedListener 
        @Override
        public void onDateChanged(DatePicker view, int year, int monthOfYear, int dayOfMonth) 
            StringBuffer selectedDateStr = new StringBuffer();
            selectedDateStr.append("您选择的日期是:").append(year).append("年").append(monthOfYear + 1).append("月").append(dayOfMonth).append("日");
            Log.i("app", selectedDateStr.toString());
        
    
 
    private class OnTimeChanged implements TimePicker.OnTimeChangedListener 
        @Override
        public void onTimeChanged(TimePicker view, int hourOfDay, int minute) 
            StringBuffer selectedTimeStr = new StringBuffer();
            selectedTimeStr.append("您选择的时间是:").append(hourOfDay).append("时").append(minute).append("分");
            Log.i("app", selectedTimeStr.toString());
        
    

 运行效果

请自己动动手试试吧。 

以上是关于Android入门第23天-日历选择组件与时间选择组件的主要内容,如果未能解决你的问题,请参考以下文章

Android入门第29天-Android里如何巧用Spinner做弹出选择对话框

Android入门第12天-CheckBox的使用

Android零基础入门第60节:日历视图CalendarView和定时器Chronometer

Android零基础入门第57节:日期选择器DatePicker和时间选择器TimePicker

Android零基础入门第58节:数值选择器NumberPicker

Android入门第34天-Android的Menu组件使用大全