/* * cocos2d for iPhone: http://www.cocos2d-iphone.org * * Copyright (c) 2008 Radu Gruian * * Copyright (c) 2011 Vit Valentin * * * 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. * * * Orignal code by Radu Gruian: http://www.codeproject.com/Articles/30838/Overhauser-Catmull-Rom-Splines-for-Camera-Animatio.So * * Adapted to cocos2d-x by Vit Valentin * * Adapted from cocos2d-x to cocos2d-iphone by Ricardo Quesada */ #import "CCActionInterval.h" /** An Array that contain control points. Used by CCCardinalSplineTo and (By) and CCCatmullRomTo (and By) actions. */ @interface CCPointArray : NSObject { NSMutableArray *_controlPoints; } /** Array that contains the control points */ @property (nonatomic,readwrite,retain) NSMutableArray *controlPoints; /** creates and initializes a Points array with capacity */ +(id) arrayWithCapacity:(NSUInteger)capacity; /** initializes a Catmull Rom config with a capacity hint */ -(id) initWithCapacity:(NSUInteger)capacity; /** appends a control point */ -(void) addControlPoint:(CGPoint)controlPoint; /** inserts a controlPoint at index */ -(void) insertControlPoint:(CGPoint)controlPoint atIndex:(NSUInteger)index; /** replaces an existing controlPoint at index */ -(void) replaceControlPoint:(CGPoint)controlPoint atIndex:(NSUInteger)index; /** get the value of a controlPoint at a given index */ -(CGPoint) getControlPointAtIndex:(NSInteger)index; /** deletes a control point at a given index */ -(void) removeControlPointAtIndex:(NSUInteger)index; /** returns the number of objects of the control point array */ -(NSUInteger) count; /** returns a new copy of the array reversed. User is responsible for releasing this copy */ -(CCPointArray*) reverse; /** reverse the current control point array inline, without generating a new one */ -(void) reverseInline; @end /** Cardinal Spline path. http://en.wikipedia.org/wiki/Cubic_Hermite_spline#Cardinal_spline */ @interface CCCardinalSplineTo : CCActionInterval { CCPointArray *_points; CGFloat _deltaT; CGFloat _tension; CGPoint _previousPosition; CGPoint _accumulatedDiff; } /** Array of control points */ @property (nonatomic,readwrite,retain) CCPointArray *points; /** creates an action with a Cardinal Spline array of points and tension */ +(id) actionWithDuration:(ccTime)duration points:(CCPointArray*)points tension:(CGFloat)tension; /** initializes the action with a duration and an array of points */ -(id) initWithDuration:(ccTime)duration points:(CCPointArray*)points tension:(CGFloat)tension; @end /** Cardinal Spline path. http://en.wikipedia.org/wiki/Cubic_Hermite_spline#Cardinal_spline */ @interface CCCardinalSplineBy : CCCardinalSplineTo { CGPoint _startPosition; } // XXX: To make BridgeSupport happy -(void) startWithTarget:(id)target; @end /** An action that moves the target with a CatmullRom curve to a destination point. A Catmull Rom is a Cardinal Spline with a tension of 0.5. http://en.wikipedia.org/wiki/Cubic_Hermite_spline#Catmull.E2.80.93Rom_spline */ @interface CCCatmullRomTo : CCCardinalSplineTo { } /** creates an action with a Cardinal Spline array of points and tension */ +(id) actionWithDuration:(ccTime)dt points:(CCPointArray*)points; /** initializes the action with a duration and an array of points */ -(id) initWithDuration:(ccTime)dt points:(CCPointArray*)points; @end /** An action that moves the target with a CatmullRom curve by a certain distance. A Catmull Rom is a Cardinal Spline with a tension of 0.5. http://en.wikipedia.org/wiki/Cubic_Hermite_spline#Catmull.E2.80.93Rom_spline */ @interface CCCatmullRomBy : CCCardinalSplineBy { } /** creates an action with a Cardinal Spline array of points and tension */ +(id) actionWithDuration:(ccTime)dt points:(CCPointArray*)points; /** initializes the action with a duration and an array of points */ -(id) initWithDuration:(ccTime)dt points:(CCPointArray*)points; @end #ifdef __cplusplus extern "C" { #endif /** Returns the Cardinal Spline position for a given set of control points, tension and time */ CGPoint ccCardinalSplineAt( CGPoint p0, CGPoint p1, CGPoint p2, CGPoint p3, CGFloat tension, ccTime t ); #ifdef __cplusplus } #endif