2012-04-19 14:35:52 +08:00
|
|
|
/****************************************************************************
|
2012-06-12 01:43:07 +08:00
|
|
|
Copyright (c) 2010-2012 cocos2d-x.org
|
2012-04-19 14:35:52 +08:00
|
|
|
Copyright (c) 2008-2010 Ricardo Quesada
|
|
|
|
Copyright (c) 2011 Zynga Inc.
|
|
|
|
|
|
|
|
http://www.cocos2d-x.org
|
|
|
|
|
|
|
|
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.
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef __CCDRAWING_PRIMITIVES__
|
|
|
|
#define __CCDRAWING_PRIMITIVES__
|
|
|
|
|
|
|
|
/**
|
|
|
|
@file
|
|
|
|
Drawing OpenGL ES primitives.
|
|
|
|
- ccDrawPoint
|
|
|
|
- ccDrawLine
|
|
|
|
- ccDrawPoly
|
|
|
|
- ccDrawCircle
|
|
|
|
- ccDrawQuadBezier
|
|
|
|
- ccDrawCubicBezier
|
|
|
|
|
|
|
|
You can change the color, width and other property by calling the
|
|
|
|
glColor4ub(), glLineWidth(), glPointSize().
|
|
|
|
|
|
|
|
@warning These functions draws the Line, Point, Polygon, immediately. They aren't batched. If you are going to make a game that depends on these primitives, I suggest creating a batch.
|
|
|
|
*/
|
|
|
|
#include "ccTypes.h"
|
|
|
|
#include "ccMacros.h"
|
2012-06-19 13:50:11 +08:00
|
|
|
#include "cocoa/CCGeometry.h" // for CCPoint
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
NS_CC_BEGIN
|
|
|
|
|
2012-06-20 18:09:11 +08:00
|
|
|
/**
|
|
|
|
* @addtogroup global
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2012-06-12 01:43:07 +08:00
|
|
|
class CCPointArray;
|
|
|
|
|
2012-09-16 05:19:14 +08:00
|
|
|
/** initialize context */
|
2012-04-19 14:35:52 +08:00
|
|
|
void CC_DLL ccDrawInit();
|
|
|
|
|
|
|
|
/** draws a point given x and y coordinate measured in points */
|
|
|
|
void CC_DLL ccDrawPoint( const CCPoint& point );
|
|
|
|
|
|
|
|
/** draws an array of points.
|
|
|
|
@since v0.7.2
|
|
|
|
*/
|
|
|
|
void CC_DLL ccDrawPoints( const CCPoint *points, unsigned int numberOfPoints );
|
|
|
|
|
|
|
|
/** draws a line given the origin and destination point measured in points */
|
|
|
|
void CC_DLL ccDrawLine( const CCPoint& origin, const CCPoint& destination );
|
|
|
|
|
2012-06-14 05:26:28 +08:00
|
|
|
/** draws a rectangle given the origin and destination point measured in points. */
|
|
|
|
void CC_DLL ccDrawRect( CCPoint origin, CCPoint destination );
|
|
|
|
|
|
|
|
/** draws a solid rectangle given the origin and destination point measured in points.
|
|
|
|
@since 1.1
|
|
|
|
*/
|
2012-06-12 01:43:07 +08:00
|
|
|
void CC_DLL ccDrawSolidRect( CCPoint origin, CCPoint destination, ccColor4F color );
|
|
|
|
|
2012-09-16 05:19:14 +08:00
|
|
|
/** draws a polygon given a pointer to CCPoint coordinates and the number of vertices measured in points.
|
2012-04-19 14:35:52 +08:00
|
|
|
The polygon can be closed or open
|
|
|
|
*/
|
|
|
|
void CC_DLL ccDrawPoly( const CCPoint *vertices, unsigned int numOfVertices, bool closePolygon );
|
|
|
|
|
2012-09-16 05:19:14 +08:00
|
|
|
/** draws a solid polygon given a pointer to CGPoint coordinates, the number of vertices measured in points, and a color.
|
2012-04-19 14:35:52 +08:00
|
|
|
*/
|
2012-06-12 01:43:07 +08:00
|
|
|
void CC_DLL ccDrawSolidPoly( const CCPoint *poli, unsigned int numberOfPoints, ccColor4F color );
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
/** draws a circle given the center, radius and number of segments. */
|
2012-05-29 17:11:33 +08:00
|
|
|
void CC_DLL ccDrawCircle( const CCPoint& center, float radius, float angle, unsigned int segments, bool drawLineToCenter);
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
/** draws a quad bezier path
|
2012-06-12 01:43:07 +08:00
|
|
|
@warning This function could be pretty slow. Use it only for debugging purposes.
|
2012-04-19 14:35:52 +08:00
|
|
|
@since v0.8
|
|
|
|
*/
|
2012-05-29 17:11:33 +08:00
|
|
|
void CC_DLL ccDrawQuadBezier(const CCPoint& origin, const CCPoint& control, const CCPoint& destination, unsigned int segments);
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
/** draws a cubic bezier path
|
2012-06-12 01:43:07 +08:00
|
|
|
@warning This function could be pretty slow. Use it only for debugging purposes.
|
2012-04-19 14:35:52 +08:00
|
|
|
@since v0.8
|
|
|
|
*/
|
2012-05-29 17:11:33 +08:00
|
|
|
void CC_DLL ccDrawCubicBezier(const CCPoint& origin, const CCPoint& control1, const CCPoint& control2, const CCPoint& destination, unsigned int segments);
|
2012-04-19 14:35:52 +08:00
|
|
|
|
2012-06-14 05:26:28 +08:00
|
|
|
/** draws a Catmull Rom path.
|
|
|
|
@warning This function could be pretty slow. Use it only for debugging purposes.
|
|
|
|
@since v2.0
|
|
|
|
*/
|
|
|
|
void CC_DLL ccDrawCatmullRom( CCPointArray *arrayOfControlPoints, unsigned int segments );
|
|
|
|
|
|
|
|
/** draws a Cardinal Spline path.
|
|
|
|
@warning This function could be pretty slow. Use it only for debugging purposes.
|
|
|
|
@since v2.0
|
|
|
|
*/
|
2012-08-01 15:30:12 +08:00
|
|
|
void CC_DLL ccDrawCardinalSpline( CCPointArray *config, float tension, unsigned int segments );
|
2012-06-12 01:43:07 +08:00
|
|
|
|
2012-04-19 14:35:52 +08:00
|
|
|
/** set the drawing color with 4 unsigned bytes
|
|
|
|
@since v2.0
|
|
|
|
*/
|
|
|
|
void CC_DLL ccDrawColor4B( GLubyte r, GLubyte g, GLubyte b, GLubyte a );
|
|
|
|
|
|
|
|
/** set the drawing color with 4 floats
|
|
|
|
@since v2.0
|
|
|
|
*/
|
|
|
|
void CC_DLL ccDrawColor4F( GLfloat r, GLfloat g, GLfloat b, GLfloat a );
|
|
|
|
|
|
|
|
/** set the point size in points. Default 1.
|
|
|
|
@since v2.0
|
|
|
|
*/
|
|
|
|
void CC_DLL ccPointSize( GLfloat pointSize );
|
|
|
|
|
2012-06-20 18:09:11 +08:00
|
|
|
// end of global group
|
|
|
|
/// @}
|
|
|
|
|
2012-04-19 14:35:52 +08:00
|
|
|
NS_CC_END
|
|
|
|
|
|
|
|
#endif // __CCDRAWING_PRIMITIVES__
|