Android日历选择控件

Calendar_Select

日历选择这个库支持单选日期以及选择时间段,可以设置时间段的天数,
并且可以设置第一次进入 是选中第一天,还是当天, 还是最后一天。
废话少说了,直接上效果图

效果图

AS下载

implementation 'com.zxn.calendar:calendar-select:1.0.4'

使用

示例

  • 单选日历:
    xml布局:
<?xml version="1.0" encoding="utf-8"?>
<com.zxn.calendar.CalendarSelectView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/calendar_select"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:clickable="true"
    app:locate_position="today"
    app:select_type="single"
    app:weekend_color="@color/colorAccent" />

代码中初始化:

//Calendar startCalendar = Calendar.getInstance();
//从本年上个月日历开始.
//startCalendar.add(Calendar.MONTH, -1);
//设置可以选择的起止日期.
Calendar startCalendar = CalendarSelectView.getCalendar(2019, 3, 29);
calendarSelect.setCalendarRange(startCalendar);
  • 多选日历:
    布局
<com.zxn.calendar.CalendarSelectView
    android:id="@+id/calendar_select"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_below="@id/tv_select_result"
    android:clickable="true"
    app:interval_select_color="@color/c_ff9800"
    app:locate_position="today"
    app:max_select_days="7"
    app:select_bg="@drawable/bg_sp_circle_c_fa753a_select"
    app:select_type="mult" />

select_type 属性有如下:

  • mult(选择时间段)
  • single (单选日期)

locate_position属性如下:

  • start (初始选中开始)
  • today(初始选中当天,如果当天不在范围之内,则选中最后一天)
  • end (初始选中最后一天)
  • max_select_days属性:设置时间段的最大天数间隔.
  • select_bg属性:设置选中日期的背景
  • interval_select_color属性:设置选中日期中间日期的背景颜色
  • weekend_color属性:设置周末日期的背景颜色

代码初始化:

Calendar startCalendar = CalendarSelectView.getCalendar(2016, 6, 1);

Calendar endCalendar = Calendar.getInstance();

DayTimeEntity startDayTime
                = new DayTimeEntity(startCalendar.get(Calendar.YEAR),
                startCalendar.get(Calendar.MONTH),
                0,
                0,
                0);

DayTimeEntity endDayTime
                = new DayTimeEntity(endCalendar.get(Calendar.YEAR),
                endCalendar.get(Calendar.MONTH),
                endCalendar.get(Calendar.DAY_OF_MONTH),//endCalendar.get(Calendar.DAY_OF_MONTH),
                0,
                0);
calendarSelect.setCalendarRange(startCalendar, endCalendar, startDayTime, endDayTime);
calendarSelect.setMultSelectedErrorCallback(new CalendarSelectView.MultSelectedErrorCallback() {
    @Override
    public void onMultSelectedError(int days, int maxDays) {
        Toast.makeText(MultCalendarAcitivity.this, "最多查询跨度" + (maxDays + 1) + "天内的交易", Toast.LENGTH_SHORT).show();
    }
});

该控件默认的时间区间是:
向前一年,向后三个月,
如果需要更改控件的时间区间,请调用如下方法:

/**
 * 更改控件的时间区间
 *
 * @param startCalendar 该控件展示的起始月份
 * @param endCalendar   该控件展示的结束月份
 * @param startDayTime  控制能点击的日期,只有在startDayTime 和 endDayTime之前的日期是可点击的
 * @param endDayTime    控制能点击的日期,只有在startDayTime 和 endDayTime之前的日期是可点击的
 */
public void setCalendarRange(Calendar startCalendar, Calendar endCalendar, DayTimeEntity startDayTime, DayTimeEntity endDayTime) {
    if (startCalendar == null || endCalendar == null)
        throw new IllegalStateException("传入的日历是不能为空的");
    else if (endCalendar.getTimeInMillis() < startCalendar.getTimeInMillis())
        throw new IllegalStateException("结束日期不能早于开始日期");
    else {
        this.startCalendarDate.setTimeInMillis(startCalendar.getTimeInMillis());
        this.endCalendarDate.setTimeInMillis(endCalendar.getTimeInMillis());
        initStartEndCalendar();
        setStartEndTime(startDayTime, endDayTime);
        if (outAdapter != null)
            outAdapter.setData(Util.getTotalCount(startCalendar, endCalendar));
    }
} 
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,117评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,328评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,839评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,007评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,384评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,629评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,880评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,593评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,313评论 1 243
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,575评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,066评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,392评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,052评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,082评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,844评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,662评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,575评论 2 270

推荐阅读更多精彩内容

  • 1、窗体 1、常用属性 (1)Name属性:用来获取或设置窗体的名称,在应用程序中可通过Name属性来引用窗体。 ...
    Moment__格调阅读 4,323评论 0 11
  • 专业考题类型管理运行工作负责人一般作业考题内容选项A选项B选项C选项D选项E选项F正确答案 变电单选GYSZ本规程...
    小白兔去钓鱼阅读 8,892评论 0 13
  • HTML标签解释大全 一、HTML标记 标签:!DOCTYPE 说明:指定了 HTML 文档遵循的文档类型定义(D...
    米塔塔阅读 3,173评论 1 41
  • iOS 自定义日历(日期选择)控件 [TOC] 前言 作为一个程序员,当你开发的app越来越多的时候,或者当你浏览...
    yinxing29阅读 19,998评论 0 13
  • 已经 记不清 《杜拉拉升职记》电影版是什么时候看的了。 那个时候 只觉得他们的感情太曲折, 但是当结局他们再一次相...
    不骄傲的小花猫阅读 359评论 0 1