2010-07-06 15:46:45 +08:00
|
|
|
/****************************************************************************
|
2011-03-19 10:59:01 +08:00
|
|
|
Copyright (c) 2010-2011 cocos2d-x.org
|
|
|
|
Copyright (c) 2008-2010 Ricardo Quesada
|
2011-07-05 14:51:17 +08:00
|
|
|
Copyright (c) 2011 Zynga Inc.
|
2010-07-06 15:46:45 +08:00
|
|
|
|
2010-07-06 20:55:05 +08:00
|
|
|
http://www.cocos2d-x.org
|
|
|
|
|
2010-07-06 15:46:45 +08:00
|
|
|
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.
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
|
2010-07-06 10:19:51 +08:00
|
|
|
#ifndef __CCDRAWING_PRIMITIVES__
|
|
|
|
#define __CCDRAWING_PRIMITIVES__
|
2010-07-06 15:46:45 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
@file
|
|
|
|
Drawing OpenGL ES primitives.
|
2010-12-28 15:05:55 +08:00
|
|
|
- ccDrawPoint
|
|
|
|
- ccDrawLine
|
|
|
|
- ccDrawPoly
|
|
|
|
- ccDrawCircle
|
|
|
|
- ccDrawQuadBezier
|
|
|
|
- ccDrawCubicBezier
|
2010-07-06 15:46:45 +08:00
|
|
|
|
|
|
|
You can change the color, width and other property by calling the
|
2011-07-05 14:51:17 +08:00
|
|
|
glColor4ub(), glLineWidth(), glPointSize().
|
2010-07-06 15:46:45 +08:00
|
|
|
|
|
|
|
@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.
|
|
|
|
*/
|
2012-03-14 14:55:17 +08:00
|
|
|
#include "ccTypes.h"
|
|
|
|
#include "ccMacros.h"
|
2011-03-07 17:11:57 +08:00
|
|
|
#include "CCGeometry.h" // for CCPoint
|
2012-03-14 18:11:25 +08:00
|
|
|
|
|
|
|
NS_CC_BEGIN
|
2010-07-06 15:46:45 +08:00
|
|
|
|
2012-04-17 17:55:26 +08:00
|
|
|
/** initlialize context */
|
|
|
|
void CC_DLL ccDrawInit();
|
|
|
|
|
2010-12-28 15:05:55 +08:00
|
|
|
/** draws a point given x and y coordinate measured in points */
|
2011-08-17 21:19:57 +08:00
|
|
|
void CC_DLL ccDrawPoint( const CCPoint& point );
|
2010-07-06 15:46:45 +08:00
|
|
|
|
|
|
|
/** draws an array of points.
|
|
|
|
@since v0.7.2
|
|
|
|
*/
|
2011-03-07 17:11:57 +08:00
|
|
|
void CC_DLL ccDrawPoints( const CCPoint *points, unsigned int numberOfPoints );
|
2010-07-06 15:46:45 +08:00
|
|
|
|
2010-12-28 15:05:55 +08:00
|
|
|
/** draws a line given the origin and destination point measured in points */
|
2011-08-17 21:19:57 +08:00
|
|
|
void CC_DLL ccDrawLine( const CCPoint& origin, const CCPoint& destination );
|
2010-07-06 15:46:45 +08:00
|
|
|
|
2011-03-07 17:11:57 +08:00
|
|
|
/** draws a poligon given a pointer to CCPoint coordiantes and the number of vertices measured in points.
|
2010-12-28 15:05:55 +08:00
|
|
|
The polygon can be closed or open
|
|
|
|
*/
|
2012-03-14 18:11:25 +08:00
|
|
|
void CC_DLL ccDrawPoly( const CCPoint *vertices, unsigned int numOfVertices, bool closePolygon );
|
2011-10-05 16:50:00 +08:00
|
|
|
|
2012-03-16 13:42:53 +08:00
|
|
|
/** draws a filled polygon given a pointer to CGPoint coordiantes, the number of vertices measured in points, and a color.
|
|
|
|
*/
|
|
|
|
void CC_DLL ccDrawFilledPoly( const CCPoint *poli, unsigned int numberOfPoints, ccColor4F color );
|
|
|
|
|
2010-07-06 15:46:45 +08:00
|
|
|
/** draws a circle given the center, radius and number of segments. */
|
2011-08-17 21:19:57 +08:00
|
|
|
void CC_DLL ccDrawCircle( const CCPoint& center, float radius, float angle, int segments, bool drawLineToCenter);
|
2010-07-06 15:46:45 +08:00
|
|
|
|
|
|
|
/** draws a quad bezier path
|
|
|
|
@since v0.8
|
|
|
|
*/
|
2011-08-17 21:19:57 +08:00
|
|
|
void CC_DLL ccDrawQuadBezier(const CCPoint& origin, const CCPoint& control, const CCPoint& destination, int segments);
|
2010-07-06 15:46:45 +08:00
|
|
|
|
|
|
|
/** draws a cubic bezier path
|
|
|
|
@since v0.8
|
|
|
|
*/
|
2011-08-17 21:19:57 +08:00
|
|
|
void CC_DLL ccDrawCubicBezier(const CCPoint& origin, const CCPoint& control1, const CCPoint& control2, const CCPoint& destination, int segments);
|
2012-03-14 14:55:17 +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
|
|
|
|
*/
|
2012-03-16 13:42:53 +08:00
|
|
|
void CC_DLL ccDrawColor4F( GLfloat r, GLfloat g, GLfloat b, GLfloat a );
|
2012-03-14 14:55:17 +08:00
|
|
|
|
|
|
|
/** set the point size in points. Default 1.
|
|
|
|
@since v2.0
|
|
|
|
*/
|
|
|
|
void CC_DLL ccPointSize( GLfloat pointSize );
|
|
|
|
|
2012-03-14 18:11:25 +08:00
|
|
|
NS_CC_END
|
2010-07-06 15:46:45 +08:00
|
|
|
|
2010-07-06 10:19:51 +08:00
|
|
|
#endif // __CCDRAWING_PRIMITIVES__
|