当前位置:   article > 正文

【Android从零单排系列十一】《Android视图控件——日历、日期、时间选择控件》_android 日历控件

android 日历控件

目录

一.日历、日期、时间组件基本介绍

二.几种常见的控件类型

1.CalendarView –日历控件

2. DatePicker –日期选择控件

3.TimePicker –时间选择控件

4.Chronometer—计时器控件

三.DEMO


前言

小伙伴们,在上文中我们介绍了Android视图控件ImageView控件,本文我们继续盘点,介绍一下视图控件的日历、日期、时间组件。

一.日历、日期、时间组件基本介绍

在 Android 应用开发中,CalendarView 、DatePicker和TimePicker实现选择日期时间、Chronometer实现计时器功能,本文结合实例形式分析了Android DatePicker和TimePicker、Chronometer组件的功能、常用函数、布局等。

二.几种常见的控件类型

1.CalendarView –日历控件

CalendarView是Android上一个优雅、高度自定义、性能高效的日历控件,完美支持周视图,支持标记、自定义颜色、农历等,任意控制月视图显示、任意日期拦截条件、自定义周起始等。

CalendarView 的特性
基于Canvas绘制,极速性能
热插拔思想,任意定制周视图、月视图,即插即用
支持单选、多选、范围选择、国内手机日历默认自动选择等选择模式
支持静态、动态设置周起始,一行代码搞定
支持静态、动态设置日历项高度、日历填充模式
支持设置任意日期范围、任意拦截日期
支持多点触控、手指平滑切换过渡,拒绝界面抖动
类NestedScrolling特性,嵌套滚动
既然这么多支持,那一定支持英语、繁体、简体,任意定制实现

android:firstDayOfWeek:设置一个星期的第一天
android:maxDate :最大的日期显示在这个日历视图mm / dd / yyyy格式
android:minDate:最小的日期显示在这个日历视图mm / dd / yyyy格式
android:weekDayTextAppearance:工作日的文本出现在日历标题缩写

2. DatePicker –日期选择控件

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:年列表选择的颜色

3.TimePicker –时间选择控件

calendarViewShown 设置其是否显示CalenderView组件

endYear 允许选择的最后一年

maxDate 支持的最大日期

minDate 允许选择的最小日期

spinnerShown 是否显示Spinner 日期选择组件

startYear 设置日期选择器 允许选择的第一年

4.Chronometer—计时器控件

Chronometer是一个简单的计时器。

主要配置

format,显示格式,默认是"MM:SS"或"H:MM:SS",以%s来格式化。
countDown,是否倒计时,与base时间相比较
主要方法

start(),开始计时
stop(),停止计时
setBase(long),设置计时基准时间
setFormat(String),设置显示格式
setCountDown(boolean),设置是否是倒计时,只有版本大于24才有效
setOnChronometerTickListener(OnChronometerTickListener),设置监听器

三.DEMO

activity

  1. package com.example.myfirtstproject;
  2. import android.app.Activity;
  3. import android.os.Bundle;
  4. import android.widget.CalendarView;
  5. import android.widget.DatePicker;
  6. import android.widget.TextView;
  7. import android.widget.TimePicker;
  8. import android.widget.Toast;
  9. import java.util.Calendar;
  10. public class MainActivity extends Activity {
  11. //定义五个当前时间的变量
  12. private int year ;
  13. private int month ;
  14. private int day ;
  15. private int hour ;
  16. private int minute ;
  17. @Override
  18. protected void onCreate(Bundle savedInstanceState) {
  19. super.onCreate(savedInstanceState);
  20. setContentView(R.layout.activity_main);
  21. DatePicker datePicker = (DatePicker) findViewById(R.id.datePicker);
  22. TimePicker timePicker = (TimePicker) findViewById(R.id.timePicker);
  23. //获取当前日期/时间
  24. Calendar calendar = Calendar.getInstance();
  25. year = calendar.get(Calendar.YEAR);
  26. month = calendar.get(Calendar.MONTH);
  27. day = calendar.get(Calendar.DAY_OF_MONTH);
  28. hour = calendar.get(Calendar.HOUR);
  29. minute = calendar.get(Calendar.MINUTE);
  30. //为DatePicker添加监听事件
  31. datePicker.init(year, month, day, new DatePicker.OnDateChangedListener() {
  32. @Override
  33. public void onDateChanged(DatePicker view, int year, int monthOfYear, int dayOfMonth) {
  34. MainActivity.this.year = year;
  35. MainActivity.this.month =month ;
  36. MainActivity.this.day = day;
  37. //显示用户选择的 日期 和 时间
  38. Toast.makeText(MainActivity.this,year+ "年"+month+ "月" + day+ "日"+hour+ "时"+minute+ "分",Toast.LENGTH_SHORT).show();
  39. }
  40. });
  41. //TimePicker选择监听器
  42. timePicker.setOnTimeChangedListener(new TimePicker.OnTimeChangedListener() {
  43. @Override
  44. public void onTimeChanged(TimePicker view, int hourOfDay, int minute) {
  45. MainActivity.this.hour = hourOfDay;
  46. MainActivity.this.minute = minute;
  47. }
  48. });
  49. CalendarView calendarview = (CalendarView) findViewById(R.id.calendarview);
  50. calendarview.setOnDateChangeListener(new CalendarView.OnDateChangeListener() {
  51. @Override
  52. public void onSelectedDayChange(CalendarView view, int year, int month, int dayOfMonth) {
  53. Toast.makeText(MainActivity.this,"您选择的时间是:"+ year + "年" + month + "月" + dayOfMonth + "日",Toast.LENGTH_SHORT).show();
  54. }
  55. });
  56. }
  57. }

xml

  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:gravity="center_horizontal">
  6. <LinearLayout
  7. android:layout_width="match_parent"
  8. android:layout_height="wrap_content"
  9. android:gravity="center"
  10. android:orientation="vertical">
  11. <TextView
  12. android:id="@+id/textview"
  13. android:layout_width="wrap_content"
  14. android:layout_height="wrap_content"
  15. android:text="再见孙悟空-【Android从零单排系列十一】《Android视图控件——日历、日期、时间选择控件》"/>
  16. <CalendarView
  17. android:id="@+id/calendarview"
  18. android:layout_width="wrap_content"
  19. android:layout_height="wrap_content"/>
  20. <DatePicker
  21. android:id="@+id/datePicker"
  22. android:layout_width="wrap_content"
  23. android:layout_height="wrap_content"
  24. android:layout_gravity="center_horizontal"
  25. android:startYear="1900"
  26. android:endYear="2080"
  27. android:calendarViewShown="true"
  28. android:spinnersShown="true">
  29. </DatePicker>
  30. <TimePicker
  31. android:id="@+id/timePicker"
  32. android:layout_width="wrap_content"
  33. android:layout_height="100dp"
  34. android:layout_gravity="center_horizontal">
  35. </TimePicker>
  36. </LinearLayout>
  37. </ScrollView>

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/534779
推荐阅读
相关标签
  

闽ICP备14008679号