Canvas is a project to simplify iOS development for both designers and developers. It had been difficult for designers to get hands on building the product with the lack of objective-c and Xcode experience, and a hard time for developer to use reasonable amount of time and lines of code just to achieve really simple effects.
With Canvas, creating stunning animations requires zero lines of code, trendy effects like the Parallax headers, Sticky sections, Blurred Backgrounds, will be as simple as few lines of code changes.
The demo app in this project uses CocoaPods, please run
pod install after you download this project, then open
See this screencast in action:
Unable to build demo?
If you're getting some errors like Accelerate.framework not include, please update your CocoaPods version:
$ [sudo] gem install cocoapods
We also have a live demo avaliable at homepage.
If you're already on CocoaPods, installing our library is easy:
$ edit Podfile platform :ios, '7.0' pod 'Canvas', '~> 0.1'
Make sure you also update the dependencies by running this command afterwards:
Then you should now have the Xcode workspace (
That's it and you are good to go! See our blog posts for hands on tutorial.
How to Use
Using Interface Builder (no code required)
Specify the class
CSAnimationView, and configurate the runtime attributes
Please also get started with our more detailed explaination on what Canvas can do.
It's very similar to using Interface Builder, instead you just setup the custom view in code.
CSAnimationView *animationView = [[CSAnimationView alloc] initWithFrame:CGRectMake(0, 0, 100, 100)]; animationView.backgroundColor = [UIColor whiteColor]; animationView.duration = 0.5; animationView.delay = 0; animationView.type = CSAnimationTypeMorph; [self.view addSubview:animationView]; // Add your subviews into animationView // [animationView addSubview:<#(UIView *)#>] // Kick start the animation immediately [animationView startCanvasAnimation];
It has been reported that current version doesn't work very well with AutoLayout. Canvas animates view frame/position but autolayout requires manipulating constraints. I am not sure if there's any quick way without changing from the ground up. Our discussion here has some proposed solution but seems imperfect (but it works under iOS 8 tho). Please join our conversation or make pull request if you know a better solution!
v0.1.2 - 9 new animations, thanks for Jake-Piatkowski adding those awesome effects!
v0.1.1 - Minor fixes
v0.1 - Initial release
iOS 7, Xcode 5
Canvas is available under the MIT license. See the LICENSE file for more info.