Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/skyfe79/leaves
An iBooks-like page-turning interface for iPhone and iPad apps using only public APIs.
https://github.com/skyfe79/leaves
Last synced: 3 months ago
JSON representation
An iBooks-like page-turning interface for iPhone and iPad apps using only public APIs.
- Host: GitHub
- URL: https://github.com/skyfe79/leaves
- Owner: skyfe79
- License: other
- Fork: true (brow/leaves)
- Created: 2011-05-11T03:57:51.000Z (over 13 years ago)
- Default Branch: master
- Last Pushed: 2010-12-09T18:16:24.000Z (about 14 years ago)
- Last Synced: 2024-04-16T12:09:45.976Z (10 months ago)
- Language: Objective-C
- Homepage: http://groups.google.com/group/leaves-developers
- Size: 3.58 MB
- Stars: 1
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.markdown
- License: LICENSE
Awesome Lists containing this project
- awesome - leaves - An iBooks-like page-turning interface for iPhone and iPad apps using only public APIs. (etc)
- awesome - leaves - An iBooks-like page-turning interface for iPhone and iPad apps using only public APIs. (etc)
README
#Leaves
Leaves is a simple way to present a page-turning interface similar to Apple's iBooks. It comprises two classes, `LeavesView` and `LeavesViewController`, and occupies less than 100 kB compiled. It uses only public APIs, sacrificing a portion of iBooks' visual flair to ensure that your application is safe for submission to the App Store.
Leaves supports:
- Text, images, PDFs -- anything that can be rendered in a graphics context
- Drag or tap to turn the page
- iPad- and iPhone-sized display areasLeaves does *not* currently support:
- Interactive elements on the page
- Swipe gestures
- Two-page landscape viewLeaves requires iPhone OS 3.0 or later.
#Installation
Add the files in the `Leaves` subdirectory to your Xcode project and ensure that you are linking against `QuartzCore.framework`.
#Getting Started
Creating a page-turning interface is as simple as subclassing `LeavesViewController`:
@interface ColorSwatchViewController : LeavesViewController
@end...and implementing the `LeavesViewDataSource` protocol:
@implementation ColorSwatchViewController
- (NSUInteger) numberOfPagesInLeavesView:(LeavesView*)leavesView {
return 10;
}- (void) renderPageAtIndex:(NSUInteger)index inContext:(CGContextRef)ctx {
CGContextSetFillColorWithColor(ctx, [[UIColor colorWithHue:index/10.0
saturation:0.8
brightness:0.8
alpha:1.0] CGColor]);
CGContextFillRect(ctx, CGContextGetClipBoundingBox(ctx));
}@end
For more sophisticated examples, build the Xcode project included with Leaves.
#Notes
The best way to get an answer to your question about programming with Leaves is the [Leaves Developers mailing list](http://groups.google.com/group/leaves-developers), which I keep an eye on. But if you find a bug, be sure to visit the [tracker](http://github.com/brow/leaves/issues) or message me directly.