Canvas

Animate in Xcode without code

  • Owner: CanvasPod/Canvas
  • Platform:
  • License:: MIT License
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

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.

Demo App

The demo app in this project uses CocoaPods, please run pod install after you download this project, then open Canvas.xcworkspace.

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.

Getting Started

If you're already on CocoaPods, installing our library is easy:

$ edit Podfile
platform :ios, '7.0'
pod 'Canvas', '~> 0.1.2'

Make sure you also update the dependencies by running this command afterwards:

pod install

Then you should now have the Xcode workspace (.xcworkspace) ready.

$open App.xcworkspace

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 duration, delay, and type.

Please also get started with our more detailed explaination on what Canvas can do.

Using Code

It's very similar to using Interface Builder, instead you just setup the custom view in code.

#import "Canvas.h"
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];

Issues

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!

Updates

v0.1.2 - 9 new animations, thanks for
Jake-Piatkowski adding those
awesome effects!

v0.1.1 - Minor fixes

v0.1 - Initial release

Requirements

iOS 7, Xcode 5

Who's behind?

LICENSE

Canvas is available under the MIT license. See the LICENSE file for more info.

Main metrics

Overview
Name With OwnerCanvasPod/Canvas
Primary LanguageObjective-C
Program languageRuby (Language Count: 2)
Platform
License:MIT License
所有者活动
Created At2013-12-05 04:40:14
Pushed At2019-07-14 10:23:50
Last Commit At2015-03-10 16:25:42
Release Count3
Last Release Name0.1.2 (Posted on 2014-07-27 19:02:09)
First Release Name0.1 (Posted on 2013-12-05 15:17:19)
用户参与
Stargazers Count5.3k
Watchers Count189
Fork Count494
Commits Count81
Has Issues Enabled
Issues Count51
Issue Open Count34
Pull Requests Count7
Pull Requests Open Count2
Pull Requests Close Count1
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private