Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ocrickard/OCCalendar

CoreGraphics date-range picking calendar
https://github.com/ocrickard/OCCalendar

Last synced: 2 months ago
JSON representation

CoreGraphics date-range picking calendar

Awesome Lists containing this project

README

        

#OCCalendarController#

##DEPRECATED: This code is old and unsupported. You're probably better off looking elsewhere

##Introduction##

OCCalendar is a very simple component for iPhone/iPad that provides a "Popover" date picker controller. It is very easy to add to your project, and is 100% CoreGraphics code, so it uses no images, and is resolution independent. I realize that I need to cut down the size for iPhone a bit more. I originally wrote it just for iPad, and my paths and sizing are all just slightly too wide for the iPhone. I'll fix it when I get a chance.

![Screenshot](https://github.com/ocrickard/OCCalendar/raw/master/demo.png)

##License##

OCCalendar is granted under the BSD license, for use with or without attribution. Have fun!

##Usage##

Drag the following files into your project:

* OCCalendarViewController.h
* OCCalendarViewController.m
* OCCalendarView.h
* OCCalendarView.m
* OCSelectionView.h
* OCSelectionView.m
* OCDaysView.h
* OCDaysView.m

Then implement the OCCalendarDelegate protocol in the class you wish to call from. The only method in this protocol specifies a way for the calendar to report back the beginning and ending ranges of dates. These are returnes as NSDate objects for convenience. In the demo app, we do the following:

```
- (void)completedWithStartDate:(NSDate *)startDate endDate:(NSDate *)endDate {
NSDateFormatter *df = [[NSDateFormatter alloc] init];
[df setDateStyle:NSDateFormatterShortStyle];

[self showToolTip:[NSString stringWithFormat:@"%@ - %@", [df stringFromDate:startDate], [df stringFromDate:endDate]]];

calVC.delegate = nil;
[calVC release];
calVC = nil;
}
```

Now, you should be able to show the calendar by alloc'ing and init'ing it, then adding to your view.

```
//Here's where the magic happens
calVC = [[OCCalendarViewController alloc] initAtPoint:CGPointMake(150, 50) inView:self.view];
calVC.delegate = self;
[self.view addSubview:calVC.view];
```

##Customization##
You can customize the look and feel of the controller by tweaking the CoreGraphics rendering code. I realize that this is not very pretty at the moment, but I'll eventually refactor it to make sure it's all neat and tidy. You can change the placement of the little arrow to either the right or left side of the popover by changing the "arrowPosition" enum in the initializer.

```
[[OCCalendarViewController alloc] initAtPoint:insertPoint inView:self.view arrowPosition:OCArrowPositionRight] //Right position
[[OCCalendarViewController alloc] initAtPoint:insertPoint inView:self.view arrowPosition:OCArrowPositionCenter] //Center position
[[OCCalendarViewController alloc] initAtPoint:insertPoint inView:self.view arrowPosition:OCArrowPositionLeft] //Left position
```