/* * cocos2d for iPhone: http://www.cocos2d-iphone.org * * Copyright (c) 2008-2009 Jason Booth * Copyright (c) 2013 Nader Eloshaiker * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. * */ #import "CCActionInterval.h" /** Base class for Easing actions */ @interface CCActionEase : CCActionInterval { CCActionInterval *_inner; } /** The inner action */ @property (nonatomic, readonly) CCActionInterval *inner; /** creates the action */ +(id) actionWithAction: (CCActionInterval*) action; /** initializes the action */ -(id) initWithAction: (CCActionInterval*) action; @end /** Base class for Easing actions with rate parameters */ @interface CCEaseRateAction : CCActionEase { float _rate; } /** rate value for the actions */ @property (nonatomic,readwrite,assign) float rate; /** Creates the action with the inner action and the rate parameter */ +(id) actionWithAction: (CCActionInterval*) action rate:(float)rate; /** Initializes the action with the inner action and the rate parameter */ -(id) initWithAction: (CCActionInterval*) action rate:(float)rate; @end /** CCEaseIn action with a rate */ @interface CCEaseIn : CCEaseRateAction {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** CCEaseOut action with a rate */ @interface CCEaseOut : CCEaseRateAction {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** CCEaseInOut action with a rate */ @interface CCEaseInOut : CCEaseRateAction {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** CCEase Exponential In */ @interface CCEaseExponentialIn : CCActionEase {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** Ease Exponential Out */ @interface CCEaseExponentialOut : CCActionEase {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** Ease Exponential InOut */ @interface CCEaseExponentialInOut : CCActionEase {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** CCEase Polynomial abstract class @since v2.1 */ @interface CCEasePolynomial : CCActionEase { @protected NSUInteger _polynomialOrder; CGFloat _intersetValue; //Used for InOut mid point time calculation BOOL _hasInflection; //odd numbered polynomial orders will display a point of inflection where the curve will invert } /** Used to determine the steepness of the timing curve. As the value increases, so does the steepness/rate of the curve. Default value is 6, gives a similar curve to EaseExponential. Values less than 6, produces a softer ease action. Values greater than 6, produces a more pronounced action. @warning Value must be greater than 1 */ @property (nonatomic, readwrite, assign) NSUInteger polynomialOrder; @end /** CCEase Polynomial In @since v2.1 */ @interface CCEasePolynomialIn : CCEasePolynomial {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** Ease Polynomial Out @since v2.1 */ @interface CCEasePolynomialOut : CCEasePolynomial {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** Ease Polynomial InOut @since v2.1 */ @interface CCEasePolynomialInOut : CCEasePolynomial {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** Ease Sine In */ @interface CCEaseSineIn : CCActionEase {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** Ease Sine Out */ @interface CCEaseSineOut : CCActionEase {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** Ease Sine InOut */ @interface CCEaseSineInOut : CCActionEase {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** Ease Elastic abstract class @since v0.8.2 */ @interface CCEaseElastic : CCActionEase { float _period; } /** period of the wave in radians. default is 0.3 */ @property (nonatomic,readwrite) float period; /** Creates the action with the inner action and the period in radians (default is 0.3) */ +(id) actionWithAction: (CCActionInterval*) action period:(float)period; /** Initializes the action with the inner action and the period in radians (default is 0.3) */ -(id) initWithAction: (CCActionInterval*) action period:(float)period; @end /** Ease Elastic In action. @warning This action doesn't use a bijective function. Actions like Sequence might have an unexpected result when used with this action. @since v0.8.2 */ @interface CCEaseElasticIn : CCEaseElastic {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** Ease Elastic Out action. @warning This action doesn't use a bijective function. Actions like Sequence might have an unexpected result when used with this action. @since v0.8.2 */ @interface CCEaseElasticOut : CCEaseElastic {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** Ease Elastic InOut action. @warning This action doesn't use a bijective function. Actions like Sequence might have an unexpected result when used with this action. @since v0.8.2 */ @interface CCEaseElasticInOut : CCEaseElastic {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** CCEaseBounce abstract class. @since v0.8.2 */ @interface CCEaseBounce : CCActionEase {} // Needed for BridgeSupport -(ccTime) bounceTime:(ccTime) t; @end /** CCEaseBounceIn action. @warning This action doesn't use a bijective function. Actions like Sequence might have an unexpected result when used with this action. @since v0.8.2 */ @interface CCEaseBounceIn : CCEaseBounce {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** EaseBounceOut action. @warning This action doesn't use a bijective function. Actions like Sequence might have an unexpected result when used with this action. @since v0.8.2 */ @interface CCEaseBounceOut : CCEaseBounce {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** CCEaseBounceInOut action. @warning This action doesn't use a bijective function. Actions like Sequence might have an unexpected result when used with this action. @since v0.8.2 */ @interface CCEaseBounceInOut : CCEaseBounce {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** CCEaseBackIn action. @warning This action doesn't use a bijective function. Actions like Sequence might have an unexpected result when used with this action. @since v0.8.2 */ @interface CCEaseBackIn : CCActionEase {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** CCEaseBackOut action. @warning This action doesn't use a bijective function. Actions like Sequence might have an unexpected result when used with this action. @since v0.8.2 */ @interface CCEaseBackOut : CCActionEase {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end /** CCEaseBackInOut action. @warning This action doesn't use a bijective function. Actions like Sequence might have an unexpected result when used with this action. @since v0.8.2 */ @interface CCEaseBackInOut : CCActionEase {} // Needed for BridgeSupport -(void) update: (ccTime) t; @end