不喜欢码字的程序员有没有,宁愿多敲两行代码,也不愿意多写两个字。


import Foundation

import UIKit


@objc(DateObject)


class DateObject: NSObject{

var day : Int?

var month : Int?

var year : Int?

var btn :UIButton?

}


import Foundation


extension NSDate{

/**

当前日期所在星期几

returns:星期几

*/

func dayOfWeek() ->NSInteger{

var calendar:NSCalendar =NSCalendar.currentCalendar()

var weekdayComponents:NSDateComponents = calendar.components(NSCalendarUnit.CalendarUnitWeekday,fromDate:self)

var week:NSInteger = weekdayComponents.weekday

week -= 2

if(week < 0){

week += 7;

}

return week

}

/**

当前日期所在月份有多少天

returns:月份天数

*/

func numberOfDaysInMonth()->NSInteger{

var calendar:NSCalendar =NSCalendar.currentCalendar()

var range:NSRange = calendar.rangeOfUnit(NSCalendarUnit.CalendarUnitDay,inUnit:NSCalendarUnit.CalendarUnitMonth,forDate: self)

var num:NSInteger = range.length

return num;

}

/**

当前日期所在月份第一天

returns:月份第一天

*/

func monthFirstDay() ->NSDate{

var calendar:NSCalendar =NSCalendar.currentCalendar()

var dayComponents:NSDateComponents = calendar.components((NSCalendarUnit.CalendarUnitYear |NSCalendarUnit.CalendarUnitMonth),fromDate: self)

dayComponents.day = 2;

var firstDate:NSDate = calendar.dateFromComponents(dayComponents)!

return firstDate;

}

/**

当前日期所在月份最后一天

returns:月份最后一天

*/

func monthLastDay() ->NSDate{

ottom:0px; font-family:Menlo; color:rgb(52,fromDate: self)

dayComponents.day =self.numberOfDaysInMonth()+1;

var lastDate:NSDate = calendar.dateFromComponents(dayComponents)!

return lastDate;

}

}



//

// MyCalendar.swift

// CoolTalk

// Created by JoesRain on 15/9/16.

// copyright (c) 2015 BreazeMago. All rights reserved.

//

import UIKit

import Foundation


@objc(CalendarJoes)


class CalendarJoes:UIView {

var num:NSInteger!

var date:NSDate!

var firstDate:NSDate!

var lastDate:NSDate!

var headView:UIView!

var footView:UIView!

var title:UILabel!

var dayArray:NSMutableArray!

var lastBtn:UIButton!

var delegate:TestDelegate!

var Today:DateObject!

override init(frame: CGRect) {

super.init(frame: frame)

self.backgroundColor =UIColor.whiteColor();

date = NSDate()

num = date!.numberOfDaysInMonth()

firstDate =date!.monthFirstDay()

lastDate =date!.monthLastDay()

dayArray =NSMutableArray()

Today = DateObject()

var calendar:NSCalendar =NSCalendar.currentCalendar()

var dayComponents:NSDateComponents = calendar.components((NSCalendarUnit.CalendarUnitYear |NSCalendarUnit.CalendarUnitMonth | NSCalendarUnit.CalendarUnitDay),fromDate: date!)

Today?.year = dayComponents.year

Today?.month = dayComponents.month

Today?.day = dayComponents.day

initUI()

}

required init(coder aDecoder: NSCoder) {

fatalError("init(coder:) has not been implemented")

}

func initUI(){

createHeadView()

createFootView()

}

/**

创建日历具体日期

*/

func createFootView(){

dayArray?.removeAllObjects()

var scw = self.bounds.width

footView = UIView(frame: CGRectMake(0,85,scw,200))

//footView?.backgroundColor = UIColor.lightGrayColor()

var thisDay = NSDate()

var week:NSInteger =firstDate!.dayOfWeek()

var tmp:NSInteger = week

var col:NSInteger = 0

var max:Float = (Float)(week+num!)/7

max += 0.4;

max = roundf(max)

//println("week+num = \(week+num!),max = \(max)")

var height:Float = 200.00/max

height = roundf(height)

var width:Float = (Float)(scw-40)/7

width = roundf(width)

var j:NSInteger = 0

vartest1:Bool =NSUserDefaults.standardUserDefaults().boolForKey("test1")as Bool!

test2:Bool =NSUserDefaults.standardUserDefaults().boolForKey("test2")as Bool!

if(NSUserDefaults.standardUserDefaults().dictionaryForKey("test3") != nil){

vartest3: Dictionary =NSUserDefaults.standardUserDefaults().dictionaryForKey("test3")as Dictionary!

//varvalue:Nsstring = dict.objectForKey("three") as Nsstring

var test4:NSInteger =test3["test3"]!.integerValue

}

for j; j<num ;j++ {

var obj:DateObject = DateObject()

var calendar:NSCalendar =NSCalendar.currentCalendar()

var dayComponents:NSDateComponents = calendar.components((NSCalendarUnit.CalendarUnitYear |NSCalendarUnit.CalendarUnitMonth),fromDate: date!)

obj.year = dayComponents.year

obj.month = dayComponents.month

obj.day = j+1

if(j != 0){

tmp += 1

}

week = tmp%7

col = tmp/7

var off_x = Float(week)*width + 20

var off_y = Float(col)*height

var btn:UIButton = UIButton(frame:CGRectMake(CGFloat(off_x),CGFloat(off_y),CGFloat(width),CGFloat(height)))

var title:UILabel = UILabel(frame: CGRectMake(0, CGFloat((height-15)/2),15))

title.text ="\(j+1)"

title.font =UIFont.systemFontOfSize(18);

title.textAlignment =NSTextAlignment.Center

btn.addTarget(self,action:"dayClick:",forControlEvents: UIControlEvents.TouchUpInside)

footView?.addSubview(btn)


btn.enabled =false;

title.textColor =UIColor(red: CGFloat(0.62),green:CGFloat(0.62),blue: CGFloat(0.62),alpha: CGFloat(1))

if(date?.laterDate(thisDay) ==date){

btn.enabled =true;

title.textColor =UIColor.blackColor()

}else{

if(obj.year! == Today.year!)

{

if(obj.month! ==Today.month!){

if((Int(obj.day!)-Int(Today.day!)) >= 3){

btn.enabled =true;

title.textColor =UIColor.blackColor()

}

}

}

}

if(!isstartTime){

}

btn.addSubview(title)

obj.btn = btn

btn.tag = j

dayArray?.addobject(obj)

//println("obj is \(obj.year) \(obj.month) \(obj.day)")

}

self.addSubview(footView!)

var swipLeft:UISwipeGestureRecognizer =UISwipeGestureRecognizer(target:self,action:"nextMonth")

var swipRight:UISwipeGestureRecognizer =UISwipeGestureRecognizer(target:self,action:"preMonth")

swipLeft.direction =UISwipeGestureRecognizerDirection.Left

swipRight.direction =UISwipeGestureRecognizerDirection.Right

footView?.addGestureRecognizer(swipLeft)

footView?.addGestureRecognizer(swipRight)

}

/**

选中日期

*/

func dayClick(sender: UIButton){

if((sender.imageForState(UIControlState.normal) ) !=nil){

sender.setimage(nil,forState:UIControlState.normal)

}else{

if(lastBtn != nil){

lastBtn!.setimage(nil,forState:UIControlState.normal)

}

sender.setimage(UIImage(named:"btn_calendar"),forState: UIControlState.normal)

lastBtn = sender

}

var obj:DateObject? = dayArray!.objectAtIndex(Int(sender.tag))as? DateObject

//println("this is day click,\(day!.year)\(day!.month) \(day!.day)")

var str:String = self.getDateString(obj!)

self.delegate?.selectStartDay(str)

ottom:0px; font-family:Menlo; color:rgb(0,\(str)")

}

func getDateString(obj:DateObject) -> String{

var str = String(format:"%ld/%02ld/%02ld",obj.year!,obj.month!,obj.day!)//"\(year)\(month)\(day)"

return str;

}

/**

添加年月跟星期显示

*/

func createHeadView(){

var scw = self.bounds.width

headView = UIView(frame: CGRectMake(0,70))

headView?.backgroundColor =UIColor.whiteColor()

self.addSubview(headView!)

//var leftBtn:UIButton = UIButton(frame: CGRectMake(25,15,8,13))

var leftBtn:UIButton = UIButton(frame: CGRectMake(20,28,28))

//leftBtn.backgroundColor = UIColor.grayColor()

leftBtn.tag = 100;

var leftImg:UIImage = UIImage(named:"list_arrowback.png")!

//leftBtn.setBackgroundImage(leftImg,forState: UIControlState.normal)

leftBtn.setimage(leftImg,forState:UIControlState.normal)

leftBtn.imageEdgeInsets =UIEdgeInsetsMake(5,5,10,15)

leftBtn.addTarget(self,action:Selector("buttonAction:"),forControlEvents: UIControlEvents.TouchUpInside)

headView?.addSubview(leftBtn)

title = UILabel(frame: CGRectMake((scw-100)/2,100,20))

title!.text =DatetoString(date!)

title!.textAlignment =NSTextAlignment.Center

headView?.addSubview(title!)

var rightBtn:UIButton = UIButton(frame: CGRectMake(scw-25-18,28))

rightBtn.tag = 101;

//rightBtn.backgroundColor = UIColor.grayColor()

var rightImg:UIImage = UIImage(named:"list_arrowhead.png")!

//rightBtn.setBackgroundImage(rightImg,forState: UIControlState.normal)

rightBtn.setimage(rightImg,forState:UIControlState.normal)

rightBtn.imageEdgeInsets =UIEdgeInsetsMake(10,5)

rightBtn.addTarget(self,forControlEvents: UIControlEvents.TouchUpInside)

headView?.addSubview(rightBtn)

var i:CGFloat = 0

for i ; i<7 ;i++ {

var w:CGFloat = ((CGFloat)(scw-40)/7)

var off_x = i*w + 20

var lal:UILabel = UILabel(frame: CGRectMake(off_x,60,w,10))

lal.textAlignment =NSTextAlignment.Center

switch i {

case 0:

lal.text =""

case 1:

lal.text =""

case 2:

lal.text =""

case 3:

lal.text =""

case 4:

lal.text =""

case 5:

lal.text =""

case 6:

lal.text =""

default:

""

}

headView?.addSubview(lal)

}

}

/**

显示上一个月跟下一个月

*/

func buttonAction(sender: UIButton)

{

//println("btn click tag is \(sender.tag)")

if(sender.tag == 100){

preMonth()

}else{

nextMonth()

}

}

/**

日期转为字符串

:param: date 日期

:returns: 日期字符串

*/

func DatetoString(date:NSDate)->String

{

var outputFormatter:NSDateFormatter = NSDateFormatter()

var timezone:NSTimeZone = NSTimeZone(name: "Asia/Shanghai")!

outputFormatter.timeZone = timezone

outputFormatter.dateFormat ="yyyyMM"

var str:String = outputFormatter.stringFromDate(date)

return str;

}

/**

当前日期前一个月

returns:前一个月

*/

func preMonth(){

var calendar:NSCalendar =NSCalendar.currentCalendar()

var dayComponents:NSDateComponents = calendar.components((NSCalendarUnit.CalendarUnitYear |NSCalendarUnit.CalendarUnitMonth),fromDate: date!)

dayComponents.month -= 1;

var preDate:NSDate = calendar.dateFromComponents(dayComponents)!

date = preDate

num = date!.numberOfDaysInMonth()

lastDate =date!.monthLastDay()

if((footView) != nil){

footView?.removeFromSuperview()

createFootView()

}

title?.text = DatetoString(preDate)

}

/**

当前日期下一个月

returns:下一个月

*/

func nextMonth(){

ottom:0px; font-family:Menlo; color:rgb(52,fromDate: date!)

dayComponents.month += 1;

var nextDate:NSDate = calendar.dateFromComponents(dayComponents)!

date = nextDate

footView?.removeFromSuperview()

createFootView()

}

title?.text = DatetoString(nextDate)

}


}

swift 日历练习的更多相关文章

  1. ios – 如何通过编程方式为UIButtons组设置单个背景图像

    解决方法要使用选择器数组以编程方式创建按钮,您可以使用以下代码片段://定义策略

  2. ios – UIButton背景图像以编程方式更改

    如何在点击事件中更改我的UIButton的背景图像?并使用上一张图片在几秒钟内刷新它?我的意思是在点击后更改它的背景图像并在点击后重置它.解决方法将您的clickEvent图像作为按钮的突出显示图像.

  3. ios – UIPopoverController出现在错误的位置

    所以我花了一些时间寻找答案,但到目前为止还没有找到任何答案.我正在尝试从UIInputAccessoryView上的按钮呈现弹出窗口.UIBarButtonItem我想显示popover来自定制视图,所以我可以使用图像.我创建这样的按钮:当需要显示popover时,我这样做:但我得到的是:弹出窗口看起来很好,但它应该出现在第一个按钮上时出现在第二个按钮上.然后我发现了这个问题:UIBarButto

  4. ios – 无法在UIButton上更改自定义UIFont大小

    我有一个按钮,我使用自定义UIFont来显示文本.字体正确加载并正确应用于按钮标题.我的问题是我似乎无法改变字体大小:无论我输入什么字体大小,我都会得到一些默认大小.另一方面,如果我做这样的事情:我得到大小32字体,但是,当然,我没有得到我的自定义字体.那么,如何设置自定义字体的大小?解决方法要获取必须传递fontWithName:size:的字体名称,请使用FontBook应用程序打开字体,然后查找PostScript名称属性.确保您已将其添加到Info.plist文件中.

  5. ios – 创建UIButton(UIButtonTypeCustom),顶部带有图像,底部带有AutoLayout标签

    我试图在它的底部显示带有文本的按钮.顶部的图像;图像&单击时必须突出显示文本.像这样:这是viewDidLoad中的代码:问题是文本根本不显示.请参阅下面的链接图像.如何使用UIEdgeInset为文本腾出空间?我也试过创建一个UIButton类,但效果大致相同.解决方法请使用以下代码设置插图,希望这可以帮助..

  6. ios – Touch拖动输入如何工作?

    任何人都可以给我一个关于触摸拖动输入以从一个按钮拖动到另一个触发两个按钮事件的示例.它是如何工作的?例如,我想从Do到Fa拖动Do,Re,Mi,Fa的事件被触发.这是我的代码:哦,我已经看到,当我按住Simulator时,会触发方法btnDragOut.当我从Simulator拖出按钮时,会触发此按钮的方法.现在我希望当我拖出一个按钮时触发方法btnDragOut.有谁知道吗?

  7. ios – 如何让UIButton成为一个圆圈?

    我一直试图让细胞中的UIButton成为一个完美的圆圈.不幸的是,圆形是基于背景图像而不是UIButton框架形成的.我创建圆圈的代码:输出如下:我该怎么做才能获得我想要的完美圆形按钮框架?解决方法尝试这样的事情如果需要创建一个视图圆,则必须将masksToBounds设置为true,不要设置clipsToBounds希望这会帮助你.

  8. 对于NSManagedObject,Xcode 9构建了Date vs NSDate的问题

    Xcode9为模拟器与设备中的实体的Date类型属性生成不同的代码.我在coredata中将类设置为类别/扩展名下的codegen功能.直到Xcode8.3(最新)它一切正常.下面是Xcode9为属性自动生成的代码–在设备上:–和,在模拟器上:–有谁遇到过这个问题?对于一个有50个成员的项目来解决这个问题的最佳解决方案是什么,直到Xcode更新修复它?

  9. iOS兼容输入类型日期 – 设置最小值最大值

    我试图在UIWebViewiOS应用程序中使用jQueryMobile设置日期,值设置正确但最小和最大属性日期设置不起作用.和当我在模拟器上运行它时,当选择日期字段时,日期选择器可见,但未设置最小,最大日期.解决方法模拟器的safari不支持设置输入类型=“日期”的最小值和最大值.您可以通过导航到thissite并尝试控制来测试它.它(可能)可以在桌面浏览器上运行,但不会在模拟器的浏览器或UIWebView中运行.

  10. ios – 设置NSDataDetector的上下文日期

    假设今天是2014年1月20日.如果我使用NSDataDetector从“明天下午4点”字符串中提取日期,我将得到2014-01-21T16:00.大.但是,假设我希望NSDataDetector假装当前日期是2014年1月14日.这样,当我解析“明天下午4点”时,我将得到2014-01-15T16:00.如果我在设备上更改系统时间,我会得到我想要的.但是,有没有办法以编程方式指定它?

随机推荐

  1. Swift UITextField,UITextView,UISegmentedControl,UISwitch

    下面我们通过一个demo来简单的实现下这些控件的功能.首先,我们拖将这几个控件拖到storyboard,并关联上相应的属性和动作.如图:关联上属性和动作后,看看实现的代码:

  2. swift UISlider,UIStepper

    我们用两个label来显示slider和stepper的值.再用张图片来显示改变stepper值的效果.首先,这三个控件需要全局变量声明如下然后,我们对所有的控件做个简单的布局:最后,当slider的值改变时,我们用一个label来显示值的变化,同样,用另一个label来显示stepper值的变化,并改变图片的大小:实现效果如下:

  3. preferredFontForTextStyle字体设置之更改

    即:

  4. Swift没有异常处理,遇到功能性错误怎么办?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 字典实战和UIKit初探

    ios中数组和字典的应用Applicationschedule类别子项类别名称优先级数据包contactsentertainment接触UIKit学习用Swift调用CocoaTouchimportUIKitletcolors=[]varbackView=UIView(frame:CGRectMake(0.0,0.0,320.0,CGFloat(colors.count*50)))backView

  6. swift语言IOS8开发战记21 Core Data2

    上一话中我们简单地介绍了一些coredata的基本知识,这一话我们通过编程来实现coredata的使用。还记得我们在coredata中定义的那个Model么,上面这段代码会加载这个Model。定义完方法之后,我们对coredata的准备都已经完成了。最后强调一点,coredata并不是数据库,它只是一个框架,协助我们进行数据库操作,它并不关心我们把数据存到哪里。

  7. swift语言IOS8开发战记22 Core Data3

    上一话我们定义了与coredata有关的变量和方法,做足了准备工作,这一话我们来试试能不能成功。首先打开上一话中生成的Info类,在其中引用头文件的地方添加一个@objc,不然后面会报错,我也不知道为什么。

  8. swift实战小程序1天气预报

    在有一定swift基础的情况下,让我们来做一些小程序练练手,今天来试试做一个简单地天气预报。然后在btnpressed方法中依旧增加loadWeather方法.在loadWeather方法中加上信息的显示语句:运行一下看看效果,如图:虽然显示出来了,但是我们的text是可编辑状态的,在storyboard中勾选Editable,再次运行:大功告成,而且现在每次单击按钮,就会重新请求天气情况,大家也来试试吧。

  9. 【iOS学习01】swift ? and !  的学习

    如果不初始化就会报错。

  10. swift语言IOS8开发战记23 Core Data4

    接着我们需要把我们的Rest类变成一个被coredata管理的类,点开Rest类,作如下修改:关键字@NSManaged的作用是与实体中对应的属性通信,BinaryData对应的类型是NSData,CoreData没有布尔属性,只能用0和1来区分。进行如下操作,输入类名:建立好之后因为我们之前写的代码有些地方并不适用于coredata,所以编译器会报错,现在来一一解决。

返回
顶部