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