iOS日历选取控件

作者: 千煌89 | 来源:发表于2014-12-01 14:39 被阅读12909次

    今天项目中遇到了这么一个需求:

    QQ20141201-1.png

    需要相当程度自定义的日历选取控件,以前没有做过日历,正好来研究一下。

    由图可知,做这么一个view需要以下几个数据,

    • 今天的日期
    • 这个月有几天
    • 本月第一天是星期几

    1、今天的日期好办,[NSDate date]什么都有了。
    2、这个月有几天

    - (NSInteger)totaldaysInThisMonth:(NSDate *)date{
        NSRange totaldaysInMonth = [[NSCalendar currentCalendar] rangeOfUnit:NSCalendarUnitDay inUnit:NSCalendarUnitMonth forDate:date];
        return totaldaysInMonth.length;
    }
    

    3、第一天是周几

    - (NSInteger)firstWeekdayInThisMonth:(NSDate *)date{
        NSCalendar *calendar = [NSCalendar currentCalendar];
        
        [calendar setFirstWeekday:1];//1.Sun. 2.Mon. 3.Thes. 4.Wed. 5.Thur. 6.Fri. 7.Sat.
        NSDateComponents *comp = [calendar components:(NSCalendarUnitYear | NSCalendarUnitMonth | NSCalendarUnitDay) fromDate:date];
        [comp setDay:1];
        NSDate *firstDayOfMonthDate = [calendar dateFromComponents:comp];
        
        NSUInteger firstWeekday = [calendar ordinalityOfUnit:NSCalendarUnitWeekday inUnit:NSCalendarUnitWeekOfMonth forDate:firstDayOfMonthDate];
        return firstWeekday - 1;
    }
    

    表格使用collectionView,十分简单,demo地址
    https://github.com/StephenZhuang/SZCalendarPicker

    最后做好的效果如下:

    SZCalendarPicker.gif

    相关文章

      网友评论

      • 烟雨痕:@千煌89 http://www.jianshu.com/p/c89479cb5370, 这个人跟你的一样。。。
        千煌89:谢谢,已举报
      • 西贝人立口:报错啊
      • 真爱要有你才完美:为一下你的方法中- (NSInteger)firstWeekdayInThisMonth:(NSDate *)date{
        NSCalendar *calendar = [NSCalendar currentCalendar];

        [calendar setFirstWeekday:1];//1.Sun. 2.Mon. 3.Thes. 4.Wed. 5.Thur. 6.Fri. 7.Sat.
        NSDateComponents *comp = [calendar components:(NSCalendarUnitYear | NSCalendarUnitMonth | NSCalendarUnitDay) fromDate:date];
        [comp setDay:1];
        NSDate *firstDayOfMonthDate = [calendar dateFromComponents:comp];

        NSUInteger firstWeekday = [calendar ordinalityOfUnit:NSCalendarUnitWeekday inUnit:NSCalendarUnitWeekOfMonth forDate:firstDayOfMonthDate];
        return firstWeekday - 1;
        } 这个firstweekday - 1 是为了什么呢
        千煌89:@真爱要有你才完美 这么久了其实我也有点忘了,得看源码才知道,现在人在外面手头不太方便,不过我猜是为了index的,因为返回的是1-7而collectionview的indexPath用的0-6
      • 28ee642ad938:你好,我想问一下,如何能让年份也可以直接选择,不知道这个demo中有没有这个功能.
        千煌89:@Szhixing丶 是个委托,重写了,跟collectionView的delegate写在一起,找一找
        28ee642ad938:@千煌89 请问怎么让所有日期都能选择, 楼上说的should select这个属性没找到...
        千煌89:@Szhixing丶 讲道理年份也要直接选,为何不用datepicker?
      • iOS_Programmer:你好 请问一下,有没有方法是根据日期来获取集合视图的indexpath.row ? 现在想实现的效果是要选择时间段,并且这个时间段内的日期(row)都变颜色,求助博主。。
        iOS_Programmer:@千煌89 现在可以记录下两端的日期 ,但是刷新的时候怎么知道这两个日期对应的row?
        iOS_Programmer:@千煌89 嗯 如果选择的日期是跨月份,也就是这个时间段的起止点是在不同的两个月,该是什么样的思路?
        千煌89:@无他唯手熟尔 如果用这些个demo改的话,我的建议是取消选中效果,点击事件储存两个值,并比较大小,作为起始与结束,然后在绘制的时候每个日期与这俩值比较,在区间内的给予选中效果
      • Rchongg:有一个问题想问 比如 今天是 2016.10.10 8:10 如何求出明天这个8:10 (重点在月份30 31号)
        Rchongg:@千煌89 好 我试试
        千煌89:@Rchongg 先转nsdate再加上一天的timeinterval,再转成日期
      • cfa214d17e4d:设置多选后 切换下个月 就出问题了
        千煌89:@失落的沙洲 你要多选,就要换写法了,我没提供这个功能,所以不是我的问题。
      • 0x00chen:谢谢,找到了 :blush:
      • 小可蛮:我怎么修改让他什么日期都能选取呢??
        0x00chen:我怎么找不到这个方法啊,层主你解决了吗?? :joy:
        小可蛮:@千煌89
        谢谢,嘿嘿 给你100个赞 哈哈
        千煌89:@小可蛮 有个should select 的方法,直接返回yes就行了
      • August24:谢谢分享,准备学习一下
      • qBryant:参考学习了。。

      本文标题:iOS日历选取控件

      本文链接:https://www.haomeiwen.com/subject/fdsgtttx.html