diff --git a/cocos/2d/CCClippingNode.cpp b/cocos/2d/CCClippingNode.cpp index 2557af5204..b4e8320e30 100644 --- a/cocos/2d/CCClippingNode.cpp +++ b/cocos/2d/CCClippingNode.cpp @@ -28,6 +28,7 @@ #include "2d/CCClippingNode.h" #include "2d/CCDrawingPrimitives.h" #include "renderer/CCGLProgramCache.h" +#include "renderer/ccGLStateCache.h" #include "renderer/CCRenderer.h" #include "base/CCDirector.h" @@ -200,12 +201,40 @@ void ClippingNode::drawFullScreenQuadClearStencil() director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_PROJECTION); director->loadIdentityMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_PROJECTION); + Vec2 vertices[] = { + Vec2(-1, -1), + Vec2(1, -1), + Vec2(1, 1), + Vec2(-1, 1) + }; - DrawPrimitives::drawSolidRect(Vec2(-1,-1), Vec2(1,1), Color4F(1, 1, 1, 1)); + auto glProgram = GLProgramCache::getInstance()->getGLProgram(GLProgram::SHADER_NAME_POSITION_U_COLOR); + glProgram->retain(); + + int colorLocation = glProgram->getUniformLocation("u_color"); + CHECK_GL_ERROR_DEBUG(); + + Color4F color(1, 1, 1, 1); + + glProgram->use(); + glProgram->setUniformsForBuiltins(); + glProgram->setUniformLocationWith4fv(colorLocation, (GLfloat*) &color.r, 1); + + GL::enableVertexAttribs( GL::VERTEX_ATTRIB_FLAG_POSITION ); + + GLuint vbo; + glGenBuffers(1, &vbo); + glBindBuffer(GL_ARRAY_BUFFER, vbo); + glBufferData(GL_ARRAY_BUFFER, sizeof(Vec2)*4, vertices, GL_STREAM_DRAW); + + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_POSITION, 2, GL_FLOAT, GL_FALSE, 0, 0); + glDrawArrays(GL_TRIANGLE_FAN, 0, 4); + glBindBuffer(GL_ARRAY_BUFFER, 0); + + CC_INCREMENT_GL_DRAWN_BATCHES_AND_VERTICES(1, 4); director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_PROJECTION); director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - } void ClippingNode::visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags) diff --git a/cocos/2d/CCDrawNode.cpp b/cocos/2d/CCDrawNode.cpp index 3094221cc0..55005e10f7 100644 --- a/cocos/2d/CCDrawNode.cpp +++ b/cocos/2d/CCDrawNode.cpp @@ -27,9 +27,11 @@ #include "renderer/CCRenderer.h" #include "renderer/ccGLStateCache.h" #include "renderer/CCGLProgramState.h" +#include "renderer/CCGLProgramCache.h" #include "base/CCDirector.h" #include "base/CCEventListenerCustom.h" #include "base/CCEventDispatcher.h" +#include "2d/CCActionCatmullRom.h" #include "platform/CCGL.h" NS_CC_BEGIN @@ -108,6 +110,20 @@ DrawNode::DrawNode() , _bufferCount(0) , _buffer(nullptr) , _dirty(false) +, _vaoGLPoint(0) +, _vboGLPoint(0) +, _bufferCapacityGLPoint(0) +, _bufferCountGLPoint(0) +, _bufferGLPoint(nullptr) +, _pointColor(1,1,1,1) +, _pointSize(1) +, _dirtyGLPoint(false) +, _vaoGLLine(0) +, _vboGLLine(0) +, _bufferCapacityGLLine(0) +, _bufferCountGLLine(0) +, _bufferGLLine(nullptr) +, _dirtyGLLine(false) { _blendFunc = BlendFunc::ALPHA_PREMULTIPLIED; } @@ -116,9 +132,17 @@ DrawNode::~DrawNode() { free(_buffer); _buffer = nullptr; + free(_bufferGLPoint); + _bufferGLPoint = nullptr; + free(_bufferGLLine); + _bufferGLLine = nullptr; glDeleteBuffers(1, &_vbo); + glDeleteBuffers(1, &_vboGLLine); + glDeleteBuffers(1, &_vboGLPoint); _vbo = 0; + _vboGLPoint = 0; + _vboGLLine = 0; if (Configuration::getInstance()->supportsShareableVAO()) { @@ -154,6 +178,28 @@ void DrawNode::ensureCapacity(int count) } } +void DrawNode::ensureCapacityGLPoint(int count) +{ + CCASSERT(count>=0, "capacity must be >= 0"); + + if(_bufferCountGLPoint + count > _bufferCapacityGLPoint) + { + _bufferCapacityGLPoint += MAX(_bufferCapacityGLPoint, count); + _bufferGLPoint = (V2F_C4B_T2F*)realloc(_bufferGLPoint, _bufferCapacityGLPoint*sizeof(V2F_C4B_T2F)); + } +} + +void DrawNode::ensureCapacityGLLine(int count) +{ + CCASSERT(count>=0, "capacity must be >= 0"); + + if(_bufferCountGLLine + count > _bufferCapacityGLLine) + { + _bufferCapacityGLLine += MAX(_bufferCapacityGLLine, count); + _bufferGLLine = (V2F_C4B_T2F*)realloc(_bufferGLLine, _bufferCapacityGLLine*sizeof(V2F_C4B_T2F)); + } +} + bool DrawNode::init() { _blendFunc = BlendFunc::ALPHA_PREMULTIPLIED; @@ -161,27 +207,63 @@ bool DrawNode::init() setGLProgramState(GLProgramState::getOrCreateWithGLProgramName(GLProgram::SHADER_NAME_POSITION_LENGTH_TEXTURE_COLOR)); ensureCapacity(512); + ensureCapacityGLPoint(64); + ensureCapacityGLLine(256); if (Configuration::getInstance()->supportsShareableVAO()) { glGenVertexArrays(1, &_vao); GL::bindVAO(_vao); } - glGenBuffers(1, &_vbo); glBindBuffer(GL_ARRAY_BUFFER, _vbo); glBufferData(GL_ARRAY_BUFFER, sizeof(V2F_C4B_T2F)* _bufferCapacity, _buffer, GL_STREAM_DRAW); - + // vertex glEnableVertexAttribArray(GLProgram::VERTEX_ATTRIB_POSITION); glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_POSITION, 2, GL_FLOAT, GL_FALSE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, vertices)); - + // color glEnableVertexAttribArray(GLProgram::VERTEX_ATTRIB_COLOR); glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_COLOR, 4, GL_UNSIGNED_BYTE, GL_TRUE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, colors)); - + // texcood glEnableVertexAttribArray(GLProgram::VERTEX_ATTRIB_TEX_COORD); glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_TEX_COORD, 2, GL_FLOAT, GL_FALSE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, texCoords)); - glBindBuffer(GL_ARRAY_BUFFER, 0); + if (Configuration::getInstance()->supportsShareableVAO()) + { + glGenVertexArrays(1, &_vaoGLLine); + GL::bindVAO(_vaoGLLine); + } + glGenBuffers(1, &_vboGLLine); + glBindBuffer(GL_ARRAY_BUFFER, _vboGLLine); + glBufferData(GL_ARRAY_BUFFER, sizeof(V2F_C4B_T2F)*_bufferCapacityGLLine, _bufferGLLine, GL_STREAM_DRAW); + // vertex + glEnableVertexAttribArray(GLProgram::VERTEX_ATTRIB_POSITION); + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_POSITION, 2, GL_FLOAT, GL_FALSE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, vertices)); + // color + glEnableVertexAttribArray(GLProgram::VERTEX_ATTRIB_COLOR); + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_COLOR, 4, GL_UNSIGNED_BYTE, GL_TRUE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, colors)); + // texcood + glEnableVertexAttribArray(GLProgram::VERTEX_ATTRIB_TEX_COORD); + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_TEX_COORD, 2, GL_FLOAT, GL_FALSE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, texCoords)); + + if (Configuration::getInstance()->supportsShareableVAO()) + { + glGenVertexArrays(1, &_vaoGLPoint); + GL::bindVAO(_vaoGLPoint); + } + glGenBuffers(1, &_vboGLPoint); + glBindBuffer(GL_ARRAY_BUFFER, _vboGLPoint); + glBufferData(GL_ARRAY_BUFFER, sizeof(V2F_C4B_T2F)*_bufferCapacityGLPoint, _bufferGLPoint, GL_STREAM_DRAW); + // vertex + glEnableVertexAttribArray(GLProgram::VERTEX_ATTRIB_POSITION); + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_POSITION, 2, GL_FLOAT, GL_FALSE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, vertices)); + // color + glEnableVertexAttribArray(GLProgram::VERTEX_ATTRIB_COLOR); + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_COLOR, 4, GL_UNSIGNED_BYTE, GL_TRUE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, colors)); + // texcood + glEnableVertexAttribArray(GLProgram::VERTEX_ATTRIB_TEX_COORD); + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_TEX_COORD, 2, GL_FLOAT, GL_FALSE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, texCoords)); + if (Configuration::getInstance()->supportsShareableVAO()) { @@ -191,6 +273,8 @@ bool DrawNode::init() CHECK_GL_ERROR_DEBUG(); _dirty = true; + _dirtyGLLine = true; + _dirtyGLPoint = true; #if CC_ENABLE_CACHE_TEXTURE_DATA // Need to listen the event only when not use batchnode, because it will use VBO @@ -207,9 +291,26 @@ bool DrawNode::init() void DrawNode::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) { - _customCommand.init(_globalZOrder); - _customCommand.func = CC_CALLBACK_0(DrawNode::onDraw, this, transform, flags); - renderer->addCommand(&_customCommand); + if(_bufferCount) + { + _customCommand.init(_globalZOrder); + _customCommand.func = CC_CALLBACK_0(DrawNode::onDraw, this, transform, flags); + renderer->addCommand(&_customCommand); + } + + if(_bufferCountGLPoint) + { + _customCommandGLPoint.init(_globalZOrder); + _customCommandGLPoint.func = CC_CALLBACK_0(DrawNode::onDrawGLPoint, this, transform, flags); + renderer->addCommand(&_customCommandGLPoint); + } + + if(_bufferCountGLLine) + { + _customCommandGLLine.init(_globalZOrder); + _customCommandGLLine.func = CC_CALLBACK_0(DrawNode::onDrawGLLine, this, transform, flags); + renderer->addCommand(&_customCommandGLLine); + } } void DrawNode::onDraw(const Mat4 &transform, uint32_t flags) @@ -217,13 +318,14 @@ void DrawNode::onDraw(const Mat4 &transform, uint32_t flags) auto glProgram = getGLProgram(); glProgram->use(); glProgram->setUniformsForBuiltins(transform); - + GL::blendFunc(_blendFunc.src, _blendFunc.dst); if (_dirty) { glBindBuffer(GL_ARRAY_BUFFER, _vbo); glBufferData(GL_ARRAY_BUFFER, sizeof(V2F_C4B_T2F)*_bufferCapacity, _buffer, GL_STREAM_DRAW); + _dirty = false; } if (Configuration::getInstance()->supportsShareableVAO()) @@ -237,21 +339,287 @@ void DrawNode::onDraw(const Mat4 &transform, uint32_t flags) glBindBuffer(GL_ARRAY_BUFFER, _vbo); // vertex glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_POSITION, 2, GL_FLOAT, GL_FALSE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, vertices)); - // color glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_COLOR, 4, GL_UNSIGNED_BYTE, GL_TRUE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, colors)); - // texcood glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_TEX_COORD, 2, GL_FLOAT, GL_FALSE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, texCoords)); } - + glBindBuffer(GL_ARRAY_BUFFER, _vbo); glDrawArrays(GL_TRIANGLES, 0, _bufferCount); glBindBuffer(GL_ARRAY_BUFFER, 0); - - CC_INCREMENT_GL_DRAWN_BATCHES_AND_VERTICES(1,_bufferCount); + + CC_INCREMENT_GL_DRAWN_BATCHES_AND_VERTICES(1, _bufferCount); CHECK_GL_ERROR_DEBUG(); } +void DrawNode::onDrawGLLine(const Mat4 &transform, uint32_t flags) +{ + auto glProgram = GLProgramCache::getInstance()->getGLProgram(GLProgram::SHADER_NAME_POSITION_LENGTH_TEXTURE_COLOR); + glProgram->use(); + glProgram->setUniformsForBuiltins(transform); + + if (_dirtyGLLine) + { + glBindBuffer(GL_ARRAY_BUFFER, _vboGLLine); + glBufferData(GL_ARRAY_BUFFER, sizeof(V2F_C4B_T2F)*_bufferCapacityGLLine, _bufferGLLine, GL_STREAM_DRAW); + _dirtyGLLine = false; + } + if (Configuration::getInstance()->supportsShareableVAO()) + { + GL::bindVAO(_vaoGLLine); + } + else + { + glBindBuffer(GL_ARRAY_BUFFER, _vboGLLine); + GL::enableVertexAttribs(GL::VERTEX_ATTRIB_FLAG_POS_COLOR_TEX); + // vertex + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_POSITION, 2, GL_FLOAT, GL_FALSE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, vertices)); + // color + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_COLOR, 4, GL_UNSIGNED_BYTE, GL_TRUE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, colors)); + // texcood + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_TEX_COORD, 2, GL_FLOAT, GL_FALSE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, texCoords)); + } + glLineWidth(2); + glBindBuffer(GL_ARRAY_BUFFER, _vboGLLine); + glDrawArrays(GL_LINES, 0, _bufferCountGLLine); + glBindBuffer(GL_ARRAY_BUFFER, 0); + + CC_INCREMENT_GL_DRAWN_BATCHES_AND_VERTICES(1,_bufferCountGLLine); + CHECK_GL_ERROR_DEBUG(); +} + +void DrawNode::onDrawGLPoint(const Mat4 &transform, uint32_t flags) +{ + auto glProgram = GLProgramCache::getInstance()->getGLProgram(GLProgram::SHADER_NAME_POSITION_U_COLOR); + glProgram->use(); + glProgram->setUniformsForBuiltins(transform); + + glProgram->setUniformLocationWith4fv(glProgram->getUniformLocation("u_color"), (GLfloat*) &_pointColor.r, 1); + glProgram->setUniformLocationWith1f(glProgram->getUniformLocation("u_pointSize"), _pointSize); + + glBindBuffer(GL_ARRAY_BUFFER, _vboGLPoint); + glBufferData(GL_ARRAY_BUFFER, sizeof(V2F_C4B_T2F)*_bufferCapacityGLPoint, _bufferGLPoint, GL_STREAM_DRAW); + + GL::enableVertexAttribs( GL::VERTEX_ATTRIB_FLAG_POSITION | GL::VERTEX_ATTRIB_FLAG_COLOR); + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_POSITION, 2, GL_FLOAT, GL_FALSE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, vertices)); + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_COLOR, 4, GL_UNSIGNED_BYTE, GL_TRUE, sizeof(V2F_C4B_T2F), (GLvoid *)offsetof(V2F_C4B_T2F, colors)); + + glDrawArrays(GL_POINTS, 0, _bufferCountGLPoint); + glBindBuffer(GL_ARRAY_BUFFER, 0); + + CC_INCREMENT_GL_DRAWN_BATCHES_AND_VERTICES(1,_bufferCountGLPoint); + CHECK_GL_ERROR_DEBUG(); +} + +void DrawNode::drawPoint(const Vec2& position, const float pointSize, const Color4F &color) +{ + V2F_C4B_T2F *point = (V2F_C4B_T2F*)(_bufferGLPoint + _bufferCountGLPoint); + V2F_C4B_T2F a = {position, Color4B(color), Tex2F(0.0, 0.0) }; + *point = a; + + _pointSize = pointSize; + _pointColor = color; + + _bufferCountGLPoint += 1; +} + +void DrawNode::drawPoints(const Vec2 *position, unsigned int numberOfPoints, const Color4F &color) +{ + ensureCapacityGLPoint(numberOfPoints); + + V2F_C4B_T2F *point = (V2F_C4B_T2F*)(_bufferGLPoint + _bufferCountGLPoint); + + for(int i=0; icount(); + + for( unsigned int i=0; i < segments+1;i++) { + + float dt = (float)i / segments; + + // border + if( dt == 1 ) { + p = config->count() - 1; + lt = 1; + } else { + p = dt / deltaT; + lt = (dt - deltaT * (float)p) / deltaT; + } + + // Interpolate + Vec2 pp0 = config->getControlPointAtIndex(p-1); + Vec2 pp1 = config->getControlPointAtIndex(p+0); + Vec2 pp2 = config->getControlPointAtIndex(p+1); + Vec2 pp3 = config->getControlPointAtIndex(p+2); + + Vec2 newPos = ccCardinalSplineAt( pp0, pp1, pp2, pp3, tension, lt); + vertices[i].x = newPos.x; + vertices[i].y = newPos.y; + } + + drawPoly(vertices, segments+1, false, color); + + CC_SAFE_DELETE_ARRAY(vertices); +} + +void DrawNode::drawCatmullRom(PointArray *points, unsigned int segments, const Color4F &color) +{ + drawCardinalSpline( points, 0.5f, segments, color); +} + void DrawNode::drawDot(const Vec2 &pos, float radius, const Color4F &color) { unsigned int vertex_count = 2*3; @@ -273,6 +641,27 @@ void DrawNode::drawDot(const Vec2 &pos, float radius, const Color4F &color) _dirty = true; } +void DrawNode::drawRect(const Vec2 &lb, const Vec2 <, const Vec2 &rt, const Vec2& rb, const Color4F &color) +{ + unsigned int vertex_count = 2*3; + ensureCapacity(vertex_count); + + V2F_C4B_T2F a = {lb, Color4B(color), Tex2F(-1.0, -1.0) }; + V2F_C4B_T2F b = {lt, Color4B(color), Tex2F(-1.0, 1.0) }; + V2F_C4B_T2F c = {rt, Color4B(color), Tex2F( 1.0, 1.0) }; + V2F_C4B_T2F d = {rb, Color4B(color), Tex2F( 1.0, -1.0) }; + + V2F_C4B_T2F_Triangle *triangles = (V2F_C4B_T2F_Triangle *)(_buffer + _bufferCount); + V2F_C4B_T2F_Triangle triangle0 = {a, b, c}; + V2F_C4B_T2F_Triangle triangle1 = {a, c, d}; + triangles[0] = triangle0; + triangles[1] = triangle1; + + _bufferCount += vertex_count; + + _dirty = true; +} + void DrawNode::drawSegment(const Vec2 &from, const Vec2 &to, float radius, const Color4F &color) { unsigned int vertex_count = 6*3; @@ -346,7 +735,7 @@ void DrawNode::drawSegment(const Vec2 &from, const Vec2 &to, float radius, const _dirty = true; } -void DrawNode::drawPolygon(Vec2 *verts, int count, const Color4F &fillColor, float borderWidth, const Color4F &borderColor) +void DrawNode::drawPolygon(const Vec2 *verts, int count, const Color4F &fillColor, float borderWidth, const Color4F &borderColor) { CCASSERT(count >= 0, "invalid count value"); @@ -454,9 +843,54 @@ void DrawNode::drawPolygon(Vec2 *verts, int count, const Color4F &fillColor, flo free(extrude); } +void DrawNode::drawSolidRect(const Vec2 &origin, const Vec2 &destination, const Color4F &color) +{ + Vec2 vertices[] = { + origin, + Vec2(destination.x, origin.y), + destination, + Vec2(origin.x, destination.y) + }; + + drawSolidPoly(vertices, 4, color ); +} + +void DrawNode::drawSolidPoly(const Vec2 *poli, unsigned int numberOfPoints, const Color4F &color) +{ + drawPolygon(poli, numberOfPoints, color, 0.0, Color4F(0.0, 0.0, 0.0, 0.0)); +} + +void DrawNode::drawSolidCircle(const Vec2& center, float radius, float angle, unsigned int segments, float scaleX, float scaleY, const Color4F &color) +{ + const float coef = 2.0f * (float)M_PI/segments; + + Vec2 *vertices = new (std::nothrow) Vec2[segments]; + if( ! vertices ) + return; + + for(unsigned int i = 0;i < segments; i++) + { + float rads = i*coef; + GLfloat j = radius * cosf(rads + angle) * scaleX + center.x; + GLfloat k = radius * sinf(rads + angle) * scaleY + center.y; + + vertices[i].x = j; + vertices[i].y = k; + } + + drawSolidPoly(vertices, segments, color); + + CC_SAFE_DELETE_ARRAY(vertices); +} + +void DrawNode::drawSolidCircle( const Vec2& center, float radius, float angle, unsigned int segments, const Color4F& color) +{ + drawSolidCircle(center, radius, angle, segments, 1.0f, 1.0f, color); +} + void DrawNode::drawTriangle(const Vec2 &p1, const Vec2 &p2, const Vec2 &p3, const Color4F &color) { - unsigned int vertex_count = 2*3; + unsigned int vertex_count = 3; ensureCapacity(vertex_count); Color4B col = Color4B(color); @@ -472,72 +906,19 @@ void DrawNode::drawTriangle(const Vec2 &p1, const Vec2 &p2, const Vec2 &p3, cons _dirty = true; } -void DrawNode::drawCubicBezier(const Vec2& from, const Vec2& control1, const Vec2& control2, const Vec2& to, unsigned int segments, const Color4F &color) -{ - unsigned int vertex_count = (segments + 1) * 3; - ensureCapacity(vertex_count); - - Tex2F texCoord = Tex2F(0.0, 0.0); - Color4B col = Color4B(color); - Vec2 vertex; - Vec2 firstVertex = Vec2(from.x, from.y); - Vec2 lastVertex = Vec2(to.x, to.y); - - float t = 0; - for(unsigned int i = segments + 1; i > 0; i--) - { - float x = powf(1 - t, 3) * from.x + 3.0f * powf(1 - t, 2) * t * control1.x + 3.0f * (1 - t) * t * t * control2.x + t * t * t * to.x; - float y = powf(1 - t, 3) * from.y + 3.0f * powf(1 - t, 2) * t * control1.y + 3.0f * (1 - t) * t * t * control2.y + t * t * t * to.y; - vertex = Vec2(x, y); - - V2F_C4B_T2F a = {firstVertex, col, texCoord }; - V2F_C4B_T2F b = {lastVertex, col, texCoord }; - V2F_C4B_T2F c = {vertex, col, texCoord }; - V2F_C4B_T2F_Triangle triangle = {a, b, c}; - ((V2F_C4B_T2F_Triangle *)(_buffer + _bufferCount))[0] = triangle; - - lastVertex = vertex; - t += 1.0f / segments; - _bufferCount += 3; - } - _dirty = true; -} - void DrawNode::drawQuadraticBezier(const Vec2& from, const Vec2& control, const Vec2& to, unsigned int segments, const Color4F &color) { - unsigned int vertex_count = (segments + 1) * 3; - ensureCapacity(vertex_count); - - Tex2F texCoord = Tex2F(0.0, 0.0); - Color4B col = Color4B(color); - Vec2 vertex; - Vec2 firstVertex = Vec2(from.x, from.y); - Vec2 lastVertex = Vec2(to.x, to.y); - - float t = 0; - for(unsigned int i = segments + 1; i > 0; i--) - { - float x = powf(1 - t, 2) * from.x + 2.0f * (1 - t) * t * control.x + t * t * to.x; - float y = powf(1 - t, 2) * from.y + 2.0f * (1 - t) * t * control.y + t * t * to.y; - vertex = Vec2(x, y); - - V2F_C4B_T2F a = {firstVertex, col, texCoord }; - V2F_C4B_T2F b = {lastVertex, col, texCoord }; - V2F_C4B_T2F c = {vertex, col, texCoord }; - V2F_C4B_T2F_Triangle triangle = {a, b, c}; - ((V2F_C4B_T2F_Triangle *)(_buffer + _bufferCount))[0] = triangle; - - lastVertex = vertex; - t += 1.0f / segments; - _bufferCount += 3; - } - _dirty = true; + drawQuadBezier(from, control, to, segments, color); } void DrawNode::clear() { _bufferCount = 0; _dirty = true; + _bufferCountGLLine = 0; + _dirtyGLLine = true; + _bufferCountGLPoint = 0; + _dirtyGLPoint = true; } const BlendFunc& DrawNode::getBlendFunc() const diff --git a/cocos/2d/CCDrawNode.h b/cocos/2d/CCDrawNode.h index 35a7835328..38f0b9d11f 100644 --- a/cocos/2d/CCDrawNode.h +++ b/cocos/2d/CCDrawNode.h @@ -34,6 +34,7 @@ #include "2d/CCNode.h" #include "base/ccTypes.h" #include "renderer/CCCustomCommand.h" +#include "math/CCMath.h" NS_CC_BEGIN @@ -43,15 +44,51 @@ NS_CC_BEGIN @since v2.1 */ + +class PointArray; + class CC_DLL DrawNode : public Node { public: /** creates and initialize a DrawNode node */ static DrawNode* create(); + void drawPoint(const Vec2& point, const float pointSize, const Color4F &color); + + void drawPoints(const Vec2 *position, unsigned int numberOfPoints, const Color4F &color); + + void drawLine(const Vec2 &origin, const Vec2 &destination, const Color4F &color); + + void drawRect(const Vec2 &origin, const Vec2 &destination, const Color4F &color); + + void drawPoly(const Vec2 *poli, unsigned int numberOfPoints, bool closePolygon, const Color4F &color); + + void drawCircle( const Vec2& center, float radius, float angle, unsigned int segments, bool drawLineToCenter, float scaleX, float scaleY, const Color4F &color); + + void drawCircle(const Vec2 ¢er, float radius, float angle, unsigned int segments, bool drawLineToCenter, const Color4F &color); + + void drawQuadBezier(const Vec2 &origin, const Vec2 &control, const Vec2 &destination, unsigned int segments, const Color4F &color); + + /** draw a cubic bezier curve with color and number of segments */ + void drawCubicBezier(const Vec2 &origin, const Vec2 &control1, const Vec2 &control2, const Vec2 &destination, unsigned int segments, const Color4F &color); + + void drawCardinalSpline(PointArray *config, float tension, unsigned int segments, const Color4F &color); + + void drawCatmullRom(PointArray *points, unsigned int segments, const Color4F &color); + /** draw a dot at a position, with a given radius and color */ void drawDot(const Vec2 &pos, float radius, const Color4F &color); + void drawRect(const Vec2 &lb, const Vec2 <, const Vec2 &rt, const Vec2& rb, const Color4F &color); + + void drawSolidRect(const Vec2 &origin, const Vec2 &destination, const Color4F &color); + + void drawSolidPoly(const Vec2 *poli, unsigned int numberOfPoints, const Color4F &color); + + void drawSolidCircle(const Vec2& center, float radius, float angle, unsigned int segments, float scaleX, float scaleY, const Color4F &color); + + void drawSolidCircle(const Vec2& center, float radius, float angle, unsigned int segments, const Color4F& color); + /** draw a segment with a radius and color */ void drawSegment(const Vec2 &from, const Vec2 &to, float radius, const Color4F &color); @@ -62,16 +99,13 @@ public: * In lua:local drawPolygon(local pointTable,local tableCount,local fillColor,local width,local borderColor) * @endcode */ - void drawPolygon(Vec2 *verts, int count, const Color4F &fillColor, float borderWidth, const Color4F &borderColor); + void drawPolygon(const Vec2 *verts, int count, const Color4F &fillColor, float borderWidth, const Color4F &borderColor); /** draw a triangle with color */ void drawTriangle(const Vec2 &p1, const Vec2 &p2, const Vec2 &p3, const Color4F &color); - /** draw a cubic bezier curve with color and number of segments */ - void drawCubicBezier(const Vec2& from, const Vec2& control1, const Vec2& control2, const Vec2& to, unsigned int segments, const Color4F &color); - - /** draw a quadratic bezier curve with color and number of segments */ - void drawQuadraticBezier(const Vec2& from, const Vec2& control, const Vec2& to, unsigned int segments, const Color4F &color); + /** draw a quadratic bezier curve with color and number of segments, use drawQuadBezier instead*/ + CC_DEPRECATED_ATTRIBUTE void drawQuadraticBezier(const Vec2& from, const Vec2& control, const Vec2& to, unsigned int segments, const Color4F &color); /** Clear the geometry in the node's buffer. */ void clear(); @@ -90,6 +124,8 @@ public: void setBlendFunc(const BlendFunc &blendFunc); void onDraw(const Mat4 &transform, uint32_t flags); + void onDrawGLLine(const Mat4 &transform, uint32_t flags); + void onDrawGLPoint(const Mat4 &transform, uint32_t flags); // Overrides virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; @@ -101,18 +137,38 @@ CC_CONSTRUCTOR_ACCESS: protected: void ensureCapacity(int count); + void ensureCapacityGLPoint(int count); + void ensureCapacityGLLine(int count); GLuint _vao; GLuint _vbo; + GLuint _vaoGLPoint; + GLuint _vboGLPoint; + GLuint _vaoGLLine; + GLuint _vboGLLine; int _bufferCapacity; GLsizei _bufferCount; V2F_C4B_T2F *_buffer; + + int _bufferCapacityGLPoint; + GLsizei _bufferCountGLPoint; + V2F_C4B_T2F *_bufferGLPoint; + Color4F _pointColor; + int _pointSize; + + int _bufferCapacityGLLine; + GLsizei _bufferCountGLLine; + V2F_C4B_T2F *_bufferGLLine; BlendFunc _blendFunc; CustomCommand _customCommand; + CustomCommand _customCommandGLPoint; + CustomCommand _customCommandGLLine; bool _dirty; + bool _dirtyGLPoint; + bool _dirtyGLLine; private: CC_DISALLOW_COPY_AND_ASSIGN(DrawNode); diff --git a/cocos/2d/CCDrawingPrimitives.h b/cocos/2d/CCDrawingPrimitives.h index c90b6b8a1c..24c91129b8 100644 --- a/cocos/2d/CCDrawingPrimitives.h +++ b/cocos/2d/CCDrawingPrimitives.h @@ -79,85 +79,85 @@ class PointArray; namespace DrawPrimitives { /** Initializes the drawing primitives */ - void CC_DLL init(); + CC_DEPRECATED_ATTRIBUTE void CC_DLL init(); /** Frees allocated resources by the drawing primitives */ - void CC_DLL free(); + CC_DEPRECATED_ATTRIBUTE void CC_DLL free(); /** draws a point given x and y coordinate measured in points */ - void CC_DLL drawPoint(const Vec2& point); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawPoint(const Vec2& point); /** draws an array of points. @since v0.7.2 */ - void CC_DLL drawPoints(const Vec2 *points, unsigned int numberOfPoints); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawPoints(const Vec2 *points, unsigned int numberOfPoints); /** draws a line given the origin and destination point measured in points */ - void CC_DLL drawLine(const Vec2& origin, const Vec2& destination); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawLine(const Vec2& origin, const Vec2& destination); /** draws a rectangle given the origin and destination point measured in points. */ - void CC_DLL drawRect(Vec2 origin, Vec2 destination); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawRect(Vec2 origin, Vec2 destination); /** draws a solid rectangle given the origin and destination point measured in points. @since 1.1 */ - void CC_DLL drawSolidRect(Vec2 origin, Vec2 destination, Color4F color); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawSolidRect(Vec2 origin, Vec2 destination, Color4F color); /** draws a polygon given a pointer to point coordinates and the number of vertices measured in points. The polygon can be closed or open */ - void CC_DLL drawPoly(const Vec2 *vertices, unsigned int numOfVertices, bool closePolygon); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawPoly(const Vec2 *vertices, unsigned int numOfVertices, bool closePolygon); /** draws a solid polygon given a pointer to CGPoint coordinates, the number of vertices measured in points, and a color. */ - void CC_DLL drawSolidPoly(const Vec2 *poli, unsigned int numberOfPoints, Color4F color); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawSolidPoly(const Vec2 *poli, unsigned int numberOfPoints, Color4F color); /** draws a circle given the center, radius and number of segments. */ - void CC_DLL drawCircle(const Vec2& center, float radius, float angle, unsigned int segments, bool drawLineToCenter, float scaleX, float scaleY); - void CC_DLL drawCircle(const Vec2& center, float radius, float angle, unsigned int segments, bool drawLineToCenter); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawCircle(const Vec2& center, float radius, float angle, unsigned int segments, bool drawLineToCenter, float scaleX, float scaleY); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawCircle(const Vec2& center, float radius, float angle, unsigned int segments, bool drawLineToCenter); /** draws a solid circle given the center, radius and number of segments. */ - void CC_DLL drawSolidCircle(const Vec2& center, float radius, float angle, unsigned int segments, float scaleX, float scaleY); - void CC_DLL drawSolidCircle(const Vec2& center, float radius, float angle, unsigned int segments); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawSolidCircle(const Vec2& center, float radius, float angle, unsigned int segments, float scaleX, float scaleY); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawSolidCircle(const Vec2& center, float radius, float angle, unsigned int segments); /** draws a quad bezier path @warning This function could be pretty slow. Use it only for debugging purposes. @since v0.8 */ - void CC_DLL drawQuadBezier(const Vec2& origin, const Vec2& control, const Vec2& destination, unsigned int segments); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawQuadBezier(const Vec2& origin, const Vec2& control, const Vec2& destination, unsigned int segments); /** draws a cubic bezier path @warning This function could be pretty slow. Use it only for debugging purposes. @since v0.8 */ - void CC_DLL drawCubicBezier(const Vec2& origin, const Vec2& control1, const Vec2& control2, const Vec2& destination, unsigned int segments); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawCubicBezier(const Vec2& origin, const Vec2& control1, const Vec2& control2, const Vec2& destination, unsigned int segments); /** draws a Catmull Rom path. @warning This function could be pretty slow. Use it only for debugging purposes. @since v2.0 */ - void CC_DLL drawCatmullRom(PointArray *arrayOfControlPoints, unsigned int segments); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawCatmullRom(PointArray *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 */ - void CC_DLL drawCardinalSpline(PointArray *config, float tension, unsigned int segments); + CC_DEPRECATED_ATTRIBUTE void CC_DLL drawCardinalSpline(PointArray *config, float tension, unsigned int segments); /** set the drawing color with 4 unsigned bytes @since v2.0 */ - void CC_DLL setDrawColor4B(GLubyte r, GLubyte g, GLubyte b, GLubyte a); + CC_DEPRECATED_ATTRIBUTE void CC_DLL setDrawColor4B(GLubyte r, GLubyte g, GLubyte b, GLubyte a); /** set the drawing color with 4 floats @since v2.0 */ - void CC_DLL setDrawColor4F(GLfloat r, GLfloat g, GLfloat b, GLfloat a); + CC_DEPRECATED_ATTRIBUTE void CC_DLL setDrawColor4F(GLfloat r, GLfloat g, GLfloat b, GLfloat a); /** set the point size in points. Default 1. @since v2.0 */ - void CC_DLL setPointSize(GLfloat pointSize); + CC_DEPRECATED_ATTRIBUTE void CC_DLL setPointSize(GLfloat pointSize); }; diff --git a/cocos/2d/CCLabelAtlas.cpp b/cocos/2d/CCLabelAtlas.cpp index e903fd4712..aa0750e906 100644 --- a/cocos/2d/CCLabelAtlas.cpp +++ b/cocos/2d/CCLabelAtlas.cpp @@ -252,19 +252,8 @@ void LabelAtlas::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) { AtlasNode::draw(renderer, transform, transformUpdated); - _customDebugDrawCommand.init(_globalZOrder); - _customDebugDrawCommand.func = CC_CALLBACK_0(LabelAtlas::drawDebugData, this,transform,transformUpdated); - renderer->addCommand(&_customDebugDrawCommand); -} - -void LabelAtlas::drawDebugData(const Mat4& transform, bool transformUpdated) -{ - Director* director = Director::getInstance(); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - + _debugDrawNode->clear(); auto size = getContentSize(); - Vec2 vertices[4]= { Vec2::ZERO, @@ -272,10 +261,7 @@ void LabelAtlas::drawDebugData(const Mat4& transform, bool transformUpdated) Vec2(size.width, size.height), Vec2(0, size.height) }; - - DrawPrimitives::drawPoly(vertices, 4, true); - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + _debugDrawNode->drawPoly(vertices, 4, true, Color4F(1.0, 1.0, 1.0, 1.0)); } #endif diff --git a/cocos/2d/CCLabelAtlas.h b/cocos/2d/CCLabelAtlas.h index b0e26d3ffb..cced77a816 100644 --- a/cocos/2d/CCLabelAtlas.h +++ b/cocos/2d/CCLabelAtlas.h @@ -90,7 +90,12 @@ public: CC_CONSTRUCTOR_ACCESS: LabelAtlas() :_string("") - {} + { +#if CC_LABELATLAS_DEBUG_DRAW + _debugDrawNode = DrawNode::create(); + addChild(_debugDrawNode); +#endif + } virtual ~LabelAtlas() { @@ -101,8 +106,7 @@ protected: virtual void updateColor() override; #if CC_LABELATLAS_DEBUG_DRAW - CustomCommand _customDebugDrawCommand; - void drawDebugData(const Mat4& transform, bool transformUpdated); + DrawNode *_debugDrawNode; #endif // string to render diff --git a/cocos/2d/CCLabelBMFont.cpp b/cocos/2d/CCLabelBMFont.cpp index 3b425824b9..6315b9761b 100644 --- a/cocos/2d/CCLabelBMFont.cpp +++ b/cocos/2d/CCLabelBMFont.cpp @@ -98,6 +98,11 @@ LabelBMFont::LabelBMFont() this->addChild(_label); this->setAnchorPoint(Vec2::ANCHOR_MIDDLE); _cascadeOpacityEnabled = true; + +#if CC_LABELBMFONT_DEBUG_DRAW + _debugDrawNode = DrawNode::create(); + addChild(_debugDrawNode); +#endif } LabelBMFont::~LabelBMFont() @@ -210,19 +215,8 @@ void LabelBMFont::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags { Node::draw(renderer, transform, transformUpdated); - _customDebugDrawCommand.init(_globalZOrder); - _customDebugDrawCommand.func = CC_CALLBACK_0(LabelBMFont::drawDebugData, this,transform,transformUpdated); - renderer->addCommand(&_customDebugDrawCommand); -} - -void LabelBMFont::drawDebugData(const Mat4& transform, bool transformUpdated) -{ - Director* director = Director::getInstance(); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - + _debugDrawNode->clear(); auto size = getContentSize(); - Vec2 vertices[4]= { Vec2::ZERO, @@ -230,10 +224,7 @@ void LabelBMFont::drawDebugData(const Mat4& transform, bool transformUpdated) Vec2(size.width, size.height), Vec2(0, size.height) }; - - DrawPrimitives::drawPoly(vertices, 4, true); - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + _debugDrawNode->drawPoly(vertices, 4, true, Color4F(1.0, 1.0, 1.0, 1.0)); } #endif diff --git a/cocos/2d/CCLabelBMFont.h b/cocos/2d/CCLabelBMFont.h index cc22e5b79c..65fc7f0d7c 100644 --- a/cocos/2d/CCLabelBMFont.h +++ b/cocos/2d/CCLabelBMFont.h @@ -129,8 +129,7 @@ public: private: #if CC_LABELBMFONT_DEBUG_DRAW - CustomCommand _customDebugDrawCommand; - void drawDebugData(const Mat4& transform, bool transformUpdated); + DrawNode *_debugDrawNode; #endif // name of fntFile diff --git a/cocos/2d/CCSprite.cpp b/cocos/2d/CCSprite.cpp index ba4b14ac6d..9b2bd7bbf1 100644 --- a/cocos/2d/CCSprite.cpp +++ b/cocos/2d/CCSprite.cpp @@ -263,6 +263,10 @@ Sprite::Sprite(void) , _texture(nullptr) , _insideBounds(true) { +#if CC_SPRITE_DEBUG_DRAW + _debugDrawNode = DrawNode::create(); + addChild(_debugDrawNode); +#endif //CC_SPRITE_DEBUG_DRAW } Sprite::~Sprite(void) @@ -585,32 +589,17 @@ void Sprite::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) _quadCommand.init(_globalZOrder, _texture->getName(), getGLProgramState(), _blendFunc, &_quad, 1, transform); renderer->addCommand(&_quadCommand); #if CC_SPRITE_DEBUG_DRAW - _customDebugDrawCommand.init(_globalZOrder); - _customDebugDrawCommand.func = CC_CALLBACK_0(Sprite::drawDebugData, this); - renderer->addCommand(&_customDebugDrawCommand); + _debugDrawNode->clear(); + Vec2 vertices[4] = { + Vec2( _quad.bl.vertices.x, _quad.bl.vertices.y ), + Vec2( _quad.br.vertices.x, _quad.br.vertices.y ), + Vec2( _quad.tr.vertices.x, _quad.tr.vertices.y ), + Vec2( _quad.tl.vertices.x, _quad.tl.vertices.y ), + }; + _debugDrawNode->drawPoly(vertices, 4, true, Color4F(1.0, 1.0, 1.0, 1.0)); #endif //CC_SPRITE_DEBUG_DRAW } } -#if CC_SPRITE_DEBUG_DRAW -void Sprite::drawDebugData() -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - Mat4 oldModelView; - oldModelView = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform); - // draw bounding box - Vec2 vertices[4] = { - Vec2( _quad.bl.vertices.x, _quad.bl.vertices.y ), - Vec2( _quad.br.vertices.x, _quad.br.vertices.y ), - Vec2( _quad.tr.vertices.x, _quad.tr.vertices.y ), - Vec2( _quad.tl.vertices.x, _quad.tl.vertices.y ), - }; - DrawPrimitives::drawPoly(vertices, 4, true); - - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, oldModelView); -} -#endif //CC_SPRITE_DEBUG_DRAW // MARK: visit, draw, transform diff --git a/cocos/2d/CCSprite.h b/cocos/2d/CCSprite.h index a4e75c334c..d0928d3a91 100644 --- a/cocos/2d/CCSprite.h +++ b/cocos/2d/CCSprite.h @@ -540,8 +540,7 @@ protected: Texture2D* _texture; /// Texture2D object that is used to render the sprite QuadCommand _quadCommand; /// quad command #if CC_SPRITE_DEBUG_DRAW - CustomCommand _customDebugDrawCommand; - void drawDebugData(); + DrawNode *_debugDrawNode; #endif //CC_SPRITE_DEBUG_DRAW // // Shared data diff --git a/cocos/scripting/lua-bindings/manual/cocos2d/LuaOpengl.cpp b/cocos/scripting/lua-bindings/manual/cocos2d/LuaOpengl.cpp index a43162ba5c..21bae98b01 100644 --- a/cocos/scripting/lua-bindings/manual/cocos2d/LuaOpengl.cpp +++ b/cocos/scripting/lua-bindings/manual/cocos2d/LuaOpengl.cpp @@ -4417,7 +4417,7 @@ tolua_lerror: /* function: DrawPoint in the DrawPrimitives namespace */ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_ccDrawPoint00 -static int tolua_cocos2d_DrawPrimitives_drawPoint00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawPoint00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4445,7 +4445,7 @@ tolua_lerror: /* function: drawPoints in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_DrawPoints00 -static int tolua_cocos2d_DrawPrimitives_drawPoints00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawPoints00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4499,7 +4499,7 @@ tolua_lerror: /* function: drawLine in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawLine00 -static int tolua_cocos2d_DrawPrimitives_drawLine00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawLine00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4532,7 +4532,7 @@ tolua_lerror: /* function: drawRect in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawRect00 -static int tolua_cocos2d_DrawPrimitives_drawRect00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawRect00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4565,7 +4565,7 @@ tolua_lerror: /* function: drawSolidRect in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_Cocos2d_DrawPrimitives_drawSolidRect00 -static int tolua_cocos2d_DrawPrimitives_drawSolidRect00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawSolidRect00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4605,7 +4605,7 @@ tolua_lerror: /* function: drawPoly in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawPoly00 -static int tolua_cocos2d_DrawPrimitives_drawPoly00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawPoly00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4661,7 +4661,7 @@ tolua_lerror: /* function: drawSolidPoly in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawSolidPoly00 -static int tolua_cocos2d_DrawPrimitives_drawSolidPoly00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawSolidPoly00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4723,7 +4723,7 @@ tolua_lerror: /* function: drawCircle in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawCircle00 -static int tolua_cocos2d_DrawPrimitives_drawCircle00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawCircle00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4765,7 +4765,7 @@ tolua_lerror: /* function: drawSolidCircle in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawSolidCircle00 -static int tolua_cocos2d_DrawPrimitives_drawSolidCircle00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawSolidCircle00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4804,7 +4804,7 @@ tolua_lerror: /* function: drawQuadBezier in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawQuadBezier00 -static int tolua_cocos2d_DrawPrimitives_drawQuadBezier00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawQuadBezier00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4845,7 +4845,7 @@ tolua_lerror: /* function: drawCubicBezier in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawCubicBezier00 -static int tolua_cocos2d_DrawPrimitives_drawCubicBezier00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawCubicBezier00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4892,7 +4892,7 @@ tolua_lerror: /* function: drawCatmullRom in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawCatmullRom00 -int tolua_cocos2d_DrawPrimitives_drawCatmullRom00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE int tolua_cocos2d_DrawPrimitives_drawCatmullRom00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4938,7 +4938,7 @@ tolua_lerror: /* function: drawCardinalSpline in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawCardinalSpline00 -int tolua_cocos2d_DrawPrimitives_drawCardinalSpline00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE int tolua_cocos2d_DrawPrimitives_drawCardinalSpline00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -4984,7 +4984,7 @@ tolua_lerror: /* function: drawColor4B in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawColor4B00 -static int tolua_cocos2d_DrawPrimitives_drawColor4B00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawColor4B00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -5016,7 +5016,7 @@ tolua_lerror: /* function: drawColor4F in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_drawColor4F00 -static int tolua_cocos2d_DrawPrimitives_drawColor4F00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_drawColor4F00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; @@ -5048,7 +5048,7 @@ tolua_lerror: /* function: setPointSize in the DrawPrimitives namespace*/ #ifndef TOLUA_DISABLE_tolua_cocos2d_DrawPrimitives_setPointSize00 -static int tolua_cocos2d_DrawPrimitives_setPointSize00(lua_State* tolua_S) +CC_DEPRECATED_ATTRIBUTE static int tolua_cocos2d_DrawPrimitives_setPointSize00(lua_State* tolua_S) { #ifndef TOLUA_RELEASE tolua_Error tolua_err; diff --git a/cocos/scripting/lua-bindings/manual/cocos2d/lua_cocos2dx_manual.cpp b/cocos/scripting/lua-bindings/manual/cocos2d/lua_cocos2dx_manual.cpp index ba320b61eb..f581cfd04c 100644 --- a/cocos/scripting/lua-bindings/manual/cocos2d/lua_cocos2dx_manual.cpp +++ b/cocos/scripting/lua-bindings/manual/cocos2d/lua_cocos2dx_manual.cpp @@ -2653,7 +2653,7 @@ tolua_lerror: #endif } -static int tolua_cocos2d_DrawNode_drawPolygon(lua_State* tolua_S) +static int tolua_cocos2dx_DrawNode_drawPolygon(lua_State* tolua_S) { if (NULL == tolua_S) return 0; @@ -2748,6 +2748,370 @@ tolua_lerror: #endif } +int tolua_cocos2dx_DrawNode_drawSolidPoly(lua_State* tolua_S) +{ + int argc = 0; + cocos2d::DrawNode* self = nullptr; + bool ok = true; + + tolua_Error tolua_err; + +#if COCOS2D_DEBUG >= 1 + if (!tolua_isusertype(tolua_S,1,"cc.DrawNode",0,&tolua_err)) goto tolua_lerror; +#endif + + self = (cocos2d::DrawNode*)tolua_tousertype(tolua_S,1,0); + +#if COCOS2D_DEBUG >= 1 + if (!self) + { + tolua_error(tolua_S,"invalid 'self' in function 'lua_cocos2dx_DrawNode_drawSolidPoly'", nullptr); + return 0; + } +#endif + + argc = lua_gettop(tolua_S)-1; + if (argc == 3) + { + unsigned int size; + luaval_to_uint32(tolua_S, 3, &size, "cc.DrawNode:drawSolidPoly"); + if ( size > 0 ) + { + cocos2d::Vec2* points = new cocos2d::Vec2[size]; + if (NULL == points) + return 0; + + for (int i = 0; i < size; i++) + { + lua_pushnumber(tolua_S,i + 1); + lua_gettable(tolua_S,2); + if (!tolua_istable(tolua_S,-1, 0, &tolua_err)) + { + CC_SAFE_DELETE_ARRAY(points); +#if COCOS2D_DEBUG >= 1 + goto tolua_lerror; +#endif + } + + if(!luaval_to_vec2(tolua_S, lua_gettop(tolua_S), &points[i], "cc.DrawNode:drawSolidPoly")) + { + lua_pop(tolua_S, 1); + CC_SAFE_DELETE_ARRAY(points); + return 0; + } + lua_pop(tolua_S, 1); + } + + cocos2d::Color4F arg2; + + ok &=luaval_to_color4f(tolua_S, 4, &arg2, "cc.DrawNode:drawSolidPoly"); + if(!ok) + return 0; + self->drawSolidPoly(points, size, arg2); + CC_SAFE_DELETE_ARRAY(points); + return 0; + } + } + + CCLOG("%s has wrong number of arguments: %d, was expecting %d \n", "cc.DrawNode:drawSolidPoly",argc, 3); + return 0; + +#if COCOS2D_DEBUG >= 1 +tolua_lerror: + tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_DrawNode_drawSolidPoly'.",&tolua_err); +#endif + + return 0; +} + +int tolua_cocos2dx_DrawNode_drawPoly(lua_State* tolua_S) +{ + if (NULL == tolua_S) + return 0; + + int argc = 0; + DrawNode* self = nullptr; + bool ok = true; + + tolua_Error tolua_err; + +#if COCOS2D_DEBUG >= 1 + if (!tolua_isusertype(tolua_S,1,"cc.DrawNode",0,&tolua_err)) goto tolua_lerror; +#endif + + self = static_cast(tolua_tousertype(tolua_S,1,0)); + +#if COCOS2D_DEBUG >= 1 + if (!self) + { + tolua_error(tolua_S,"invalid 'self' in function 'lua_cocos2dx_DrawNode_drawPoly'", NULL); + return 0; + } +#endif + + argc = lua_gettop(tolua_S)-1; + if (argc == 4) + { + unsigned int size; + luaval_to_uint32(tolua_S, 3, &size, "cc.DrawNode:drawPoly"); + if ( size > 0 ) + { + cocos2d::Vec2* points = new cocos2d::Vec2[size]; + if (NULL == points) + return 0; + + for (int i = 0; i < size; i++) + { + lua_pushnumber(tolua_S,i + 1); + lua_gettable(tolua_S,2); + if (!tolua_istable(tolua_S,-1, 0, &tolua_err)) + { + CC_SAFE_DELETE_ARRAY(points); +#if COCOS2D_DEBUG >= 1 + goto tolua_lerror; +#endif + } + + if(!luaval_to_vec2(tolua_S, lua_gettop(tolua_S), &points[i], "cc.DrawNode:drawPoly")) + { + lua_pop(tolua_S, 1); + CC_SAFE_DELETE_ARRAY(points); + return 0; + } + lua_pop(tolua_S, 1); + } + + bool arg2; + cocos2d::Color4F arg3; + + ok &= luaval_to_boolean(tolua_S, 4,&arg2, "cc.DrawNode:drawPoly"); + + ok &= luaval_to_color4f(tolua_S, 5, &arg3, "cc.DrawNode:drawPoly"); + if(!ok) + return 0; + + self->drawPoly(points, size, arg2, arg3); + CC_SAFE_DELETE_ARRAY(points); + return 0; + } + } + + CCLOG("%s has wrong number of arguments: %d, was expecting %d \n", "cc.DrawNode:drawPoly",argc, 4); + return 0; + +#if COCOS2D_DEBUG >= 1 +tolua_lerror: + tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_DrawNode_drawPoly'.",&tolua_err); +#endif + + return 0; +} + +int tolua_cocos2dx_DrawNode_drawCardinalSpline(lua_State* tolua_S) +{ + int argc = 0; + cocos2d::DrawNode* self = nullptr; + bool ok = true; + + tolua_Error tolua_err; + +#if COCOS2D_DEBUG >= 1 + if (!tolua_isusertype(tolua_S,1,"cc.DrawNode",0,&tolua_err)) goto tolua_lerror; +#endif + + self = (cocos2d::DrawNode*)tolua_tousertype(tolua_S,1,0); + +#if COCOS2D_DEBUG >= 1 + if (!self) + { + tolua_error(tolua_S,"invalid 'self' in function 'lua_cocos2dx_DrawNode_drawCardinalSpline'", nullptr); + return 0; + } +#endif + + argc = lua_gettop(tolua_S)-1; + if (argc == 4) + { + int num = 0; + cocos2d::Vec2 *arr = NULL; + if (!luaval_to_array_of_vec2(tolua_S, 2, &arr, &num, "cc.DrawNode:drawCardinalSpline")) + return 0; + PointArray* config = PointArray::create(num); + if (NULL == config) + { + CC_SAFE_DELETE_ARRAY(arr); + return 0; + } + + for( int i = 0; i < num; i++) { + config->addControlPoint(arr[i]); + } + CC_SAFE_DELETE_ARRAY(arr); + + double arg1; + unsigned int arg2; + cocos2d::Color4F arg3; + + ok &= luaval_to_number(tolua_S, 3,&arg1, "cc.DrawNode:drawCardinalSpline"); + + ok &= luaval_to_uint32(tolua_S, 4,&arg2, "cc.DrawNode:drawCardinalSpline"); + + ok &= luaval_to_color4f(tolua_S, 5, &arg3, "cc.DrawNode:drawCardinalSpline"); + if(!ok) + return 0; + self->drawCardinalSpline(config, arg1, arg2, arg3); + return 0; + } + CCLOG("%s has wrong number of arguments: %d, was expecting %d \n", "cc.DrawNode:drawCardinalSpline",argc, 4); + return 0; + +#if COCOS2D_DEBUG >= 1 +tolua_lerror: + tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_DrawNode_drawCardinalSpline'.",&tolua_err); +#endif + + return 0; +} + +int tolua_cocos2dx_DrawNode_drawCatmullRom(lua_State* tolua_S) +{ + int argc = 0; + cocos2d::DrawNode* self = nullptr; + bool ok = true; + + tolua_Error tolua_err; + +#if COCOS2D_DEBUG >= 1 + if (!tolua_isusertype(tolua_S,1,"cc.DrawNode",0,&tolua_err)) goto tolua_lerror; +#endif + + self = (cocos2d::DrawNode*)tolua_tousertype(tolua_S,1,0); + +#if COCOS2D_DEBUG >= 1 + if (!self) + { + tolua_error(tolua_S,"invalid 'self' in function 'lua_cocos2dx_DrawNode_drawCatmullRom'", nullptr); + return 0; + } +#endif + + argc = lua_gettop(tolua_S)-1; + if (argc == 3) + { + int num = 0; + cocos2d::Vec2 *arr = NULL; + if (!luaval_to_array_of_vec2(tolua_S, 2, &arr, &num, "cc.DrawNode:drawCatmullRom")) + return 0; + PointArray* config = PointArray::create(num); + if (NULL == config) + { + CC_SAFE_DELETE_ARRAY(arr); + return 0; + } + + for( int i = 0; i < num; i++) { + config->addControlPoint(arr[i]); + } + CC_SAFE_DELETE_ARRAY(arr); + + unsigned int arg1; + cocos2d::Color4F arg2; + + ok &= luaval_to_uint32(tolua_S, 3,&arg1, "cc.DrawNode:drawCatmullRom"); + + ok &=luaval_to_color4f(tolua_S, 4, &arg2, "cc.DrawNode:drawCatmullRom"); + if(!ok) + return 0; + self->drawCatmullRom(config, arg1, arg2); + return 0; + } + + CCLOG("%s has wrong number of arguments: %d, was expecting %d \n", "cc.DrawNode:drawCatmullRom",argc, 3); + return 0; + +#if COCOS2D_DEBUG >= 1 +tolua_lerror: + tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_DrawNode_drawCatmullRom'.",&tolua_err); +#endif + + return 0; +} + +int tolua_cocos2dx_DrawNode_drawPoints(lua_State* tolua_S) +{ + int argc = 0; + cocos2d::DrawNode* self = nullptr; + bool ok = true; + + tolua_Error tolua_err; + +#if COCOS2D_DEBUG >= 1 + if (!tolua_isusertype(tolua_S,1,"cc.DrawNode",0,&tolua_err)) goto tolua_lerror; +#endif + + self = (cocos2d::DrawNode*)tolua_tousertype(tolua_S,1,0); + +#if COCOS2D_DEBUG >= 1 + if (!self) + { + tolua_error(tolua_S,"invalid 'self' in function 'lua_cocos2dx_DrawNode_drawPoints'", nullptr); + return 0; + } +#endif + + argc = lua_gettop(tolua_S)-1; + if (argc == 3) + { + unsigned int size; + luaval_to_uint32(tolua_S, 3, &size, "cc.DrawNode:drawPoints"); + if ( size > 0 ) + { + cocos2d::Vec2* points = new cocos2d::Vec2[size]; + if (NULL == points) + return 0; + + for (int i = 0; i < size; i++) + { + lua_pushnumber(tolua_S,i + 1); + lua_gettable(tolua_S,2); + if (!tolua_istable(tolua_S,-1, 0, &tolua_err)) + { + CC_SAFE_DELETE_ARRAY(points); +#if COCOS2D_DEBUG >= 1 + goto tolua_lerror; +#endif + } + + if(!luaval_to_vec2(tolua_S, lua_gettop(tolua_S), &points[i], "cc.DrawNode:drawPoints")) + { + lua_pop(tolua_S, 1); + CC_SAFE_DELETE_ARRAY(points); + return 0; + } + lua_pop(tolua_S, 1); + } + + cocos2d::Color4F arg2; + + ok &=luaval_to_color4f(tolua_S, 4, &arg2, "cc.DrawNode:drawPoints"); + if(!ok) + return 0; + self->drawPoints(points, size, arg2); + return 0; + } + } + + CCLOG("%s has wrong number of arguments: %d, was expecting %d \n", "cc.DrawNode:drawPoints",argc, 3); + return 0; + +#if COCOS2D_DEBUG >= 1 +tolua_lerror: + tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_DrawNode_drawPoints'.",&tolua_err); +#endif + + return 0; +} + // setBlendFunc template static int tolua_cocos2dx_setBlendFunc(lua_State* tolua_S,const char* className) @@ -4154,7 +4518,27 @@ static void extendDrawNode(lua_State* tolua_S) if (lua_istable(tolua_S,-1)) { lua_pushstring(tolua_S,"drawPolygon"); - lua_pushcfunction(tolua_S,tolua_cocos2d_DrawNode_drawPolygon); + lua_pushcfunction(tolua_S,tolua_cocos2dx_DrawNode_drawPolygon); + lua_rawset(tolua_S,-3); + + lua_pushstring(tolua_S,"drawSolidPoly"); + lua_pushcfunction(tolua_S,tolua_cocos2dx_DrawNode_drawSolidPoly); + lua_rawset(tolua_S,-3); + + lua_pushstring(tolua_S,"drawPoly"); + lua_pushcfunction(tolua_S,tolua_cocos2dx_DrawNode_drawPoly); + lua_rawset(tolua_S,-3); + + lua_pushstring(tolua_S,"drawCardinalSpline"); + lua_pushcfunction(tolua_S,tolua_cocos2dx_DrawNode_drawCardinalSpline); + lua_rawset(tolua_S,-3); + + lua_pushstring(tolua_S,"drawCatmullRom"); + lua_pushcfunction(tolua_S,tolua_cocos2dx_DrawNode_drawCatmullRom); + lua_rawset(tolua_S,-3); + + lua_pushstring(tolua_S,"drawPoints"); + lua_pushcfunction(tolua_S,tolua_cocos2dx_DrawNode_drawPoints); lua_rawset(tolua_S,-3); lua_pushstring(tolua_S,"setBlendFunc"); diff --git a/cocos/ui/UILayout.cpp b/cocos/ui/UILayout.cpp index 1e8b5a55b7..43ef74ccdc 100644 --- a/cocos/ui/UILayout.cpp +++ b/cocos/ui/UILayout.cpp @@ -27,6 +27,7 @@ THE SOFTWARE. #include "ui/UIScale9Sprite.h" #include "renderer/CCGLProgram.h" #include "renderer/CCGLProgramCache.h" +#include "renderer/ccGLStateCache.h" #include "base/CCDirector.h" #include "2d/CCDrawingPrimitives.h" #include "renderer/CCRenderer.h" @@ -351,14 +352,44 @@ void Layout::drawFullScreenQuadClearStencil() { Director* director = Director::getInstance(); CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - + + director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + director->loadIdentityMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_PROJECTION); director->loadIdentityMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_PROJECTION); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadIdentityMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + Vec2 vertices[] = { + Vec2(-1, -1), + Vec2(1, -1), + Vec2(1, 1), + Vec2(-1, 1) + }; - DrawPrimitives::drawSolidRect(Vec2(-1,-1), Vec2(1,1), Color4F(1, 1, 1, 1)); + auto glProgram = GLProgramCache::getInstance()->getGLProgram(GLProgram::SHADER_NAME_POSITION_U_COLOR); + glProgram->retain(); + + int colorLocation = glProgram->getUniformLocation("u_color"); + CHECK_GL_ERROR_DEBUG(); + + Color4F color(1, 1, 1, 1); + + glProgram->use(); + glProgram->setUniformsForBuiltins(); + glProgram->setUniformLocationWith4fv(colorLocation, (GLfloat*) &color.r, 1); + + GL::enableVertexAttribs( GL::VERTEX_ATTRIB_FLAG_POSITION ); + + GLuint vbo; + glGenBuffers(1, &vbo); + glBindBuffer(GL_ARRAY_BUFFER, vbo); + glBufferData(GL_ARRAY_BUFFER, sizeof(Vec2)*4, vertices, GL_STREAM_DRAW); + + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_POSITION, 2, GL_FLOAT, GL_FALSE, 0, 0); + glDrawArrays(GL_TRIANGLE_FAN, 0, 4); + glBindBuffer(GL_ARRAY_BUFFER, 0); + + CC_INCREMENT_GL_DRAWN_BATCHES_AND_VERTICES(1, 4); director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_PROJECTION); director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); diff --git a/cocos/ui/UIVideoPlayer-android.cpp b/cocos/ui/UIVideoPlayer-android.cpp index ae61f94b14..ca588b44b3 100644 --- a/cocos/ui/UIVideoPlayer-android.cpp +++ b/cocos/ui/UIVideoPlayer-android.cpp @@ -178,6 +178,11 @@ VideoPlayer::VideoPlayer() { _videoPlayerIndex = createVideoWidgetJNI(); s_allVideoPlayers[_videoPlayerIndex] = this; + +#if CC_VIDEOPLAYER_DEBUG_DRAW + _debugDrawNode = DrawNode::create(); + addchild(_debugDrawNode); +#endif } VideoPlayer::~VideoPlayer() @@ -224,9 +229,16 @@ void VideoPlayer::draw(Renderer* renderer, const Mat4 &transform, uint32_t flags } #if CC_VIDEOPLAYER_DEBUG_DRAW - _customDebugDrawCommand.init(_globalZOrder); - _customDebugDrawCommand.func = CC_CALLBACK_0(VideoPlayer::drawDebugData, this); - renderer->addCommand(&_customDebugDrawCommand); + _debugDrawNode->clear(); + auto size = getContentSize(); + Point vertices[4]= + { + Point::ZERO, + Point(size.width, 0), + Point(size.width, size.height), + Point(0, size.height) + }; + _debugdrawNode->drawPoly(vertices, 4, true, Color4F(1.0, 1.0, 1.0, 1.0)); #endif } diff --git a/cocos/ui/UIVideoPlayer-ios.mm b/cocos/ui/UIVideoPlayer-ios.mm index 94749f2422..064ee363a4 100644 --- a/cocos/ui/UIVideoPlayer-ios.mm +++ b/cocos/ui/UIVideoPlayer-ios.mm @@ -275,6 +275,11 @@ VideoPlayer::VideoPlayer() , _isPlaying(false) { _videoView = [[UIVideoViewWrapperIos alloc] init:this]; + +#if CC_VIDEOPLAYER_DEBUG_DRAW + _debugDrawNode = DrawNode::create(); + addchild(_debugDrawNode); +#endif } VideoPlayer::~VideoPlayer() @@ -324,9 +329,16 @@ void VideoPlayer::draw(Renderer* renderer, const Mat4 &transform, uint32_t flags } #if CC_VIDEOPLAYER_DEBUG_DRAW - _customDebugDrawCommand.init(_globalZOrder); - _customDebugDrawCommand.func = CC_CALLBACK_0(VideoPlayer::drawDebugData, this); - renderer->addCommand(&_customDebugDrawCommand); + _debugDrawNode->clear(); + auto size = getContentSize(); + Point vertices[4]= + { + Point::ZERO, + Point(size.width, 0), + Point(size.width, size.height), + Point(0, size.height) + }; + _debugdrawNode->drawPoly(vertices, 4, true, Color4F(1.0, 1.0, 1.0, 1.0)); #endif } @@ -349,31 +361,6 @@ void VideoPlayer::setKeepAspectRatioEnabled(bool enable) } } -#if CC_VIDEOPLAYER_DEBUG_DRAW -void VideoPlayer::drawDebugData() -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform); - - auto size = getContentSize(); - - Point vertices[4]= - { - Point::ZERO, - Point(size.width, 0), - Point(size.width, size.height), - Point(0, size.height) - }; - - DrawPrimitives::drawPoly(vertices, 4, true); - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); -} -#endif - void VideoPlayer::play() { if (! _videoURL.empty()) diff --git a/cocos/ui/UIVideoPlayer.h b/cocos/ui/UIVideoPlayer.h index deb029aaee..87dc5d0022 100644 --- a/cocos/ui/UIVideoPlayer.h +++ b/cocos/ui/UIVideoPlayer.h @@ -84,8 +84,7 @@ namespace experimental{ virtual ~VideoPlayer(); #if CC_VIDEOPLAYER_DEBUG_DRAW - CustomCommand _customDebugDrawCommand; - void VideoPlayer::drawDebugData(); + DrawNode *_debugDrawNode; #endif enum class Source diff --git a/tests/cpp-tests/Classes/ActionsTest/ActionsTest.cpp b/tests/cpp-tests/Classes/ActionsTest/ActionsTest.cpp index fb7a470c79..35bbddc85d 100644 --- a/tests/cpp-tests/Classes/ActionsTest/ActionsTest.cpp +++ b/tests/cpp-tests/Classes/ActionsTest/ActionsTest.cpp @@ -1339,6 +1339,15 @@ void ActionFollow::onEnter() centerSprites(1); auto s = Director::getInstance()->getWinSize(); + DrawNode* drawNode = DrawNode::create(); + float x = s.width*2 - 100; + float y = s.height; + + Vec2 vertices[] = { Vec2(5,5), Vec2(x-5,5), Vec2(x-5,y-5), Vec2(5,y-5) }; + drawNode->drawPoly(vertices, 4, true, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 1)); + + this->addChild(drawNode); + _grossini->setPosition(-200, s.height / 2); auto move = MoveBy::create(2, Vec2(s.width * 3, 0)); auto move_back = move->reverse(); @@ -1350,32 +1359,6 @@ void ActionFollow::onEnter() this->runAction(Follow::create(_grossini, Rect(0, 0, s.width * 2 - 100, s.height))); } -void ActionFollow::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _customCommand.init(_globalZOrder); - _customCommand.func = CC_CALLBACK_0(ActionFollow::onDraw, this, transform, flags); - - renderer->addCommand(&_customCommand); -} - -void ActionFollow::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - - auto winSize = Director::getInstance()->getWinSize(); - - float x = winSize.width*2 - 100; - float y = winSize.height; - - Vec2 vertices[] = { Vec2(5,5), Vec2(x-5,5), Vec2(x-5,y-5), Vec2(5,y-5) }; - DrawPrimitives::drawPoly(vertices, 4, true); - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); -} - std::string ActionFollow::subtitle() const { return "Follow action"; @@ -1623,6 +1606,11 @@ void ActionCatmullRomStacked::onEnter() MoveBy::create(0.05f, Vec2(-10,0)), nullptr))); + auto drawNode1 = DrawNode::create(); + drawNode1->setPosition(Vec2(50,50)); + drawNode1->drawCatmullRom(array, 50, Color4F(1.0, 1.0, 0.0, 0.5)); + this->addChild(drawNode1); + // // sprite 2 (To) // @@ -1652,54 +1640,13 @@ void ActionCatmullRomStacked::onEnter() MoveBy::create(0.05f, Vec2(-10,0)), nullptr))); - array->retain(); - _array1 = array; - array2->retain(); - _array2 = array2; + auto drawNode2 = DrawNode::create(); + drawNode2->drawCatmullRom(array2, 50, Color4F(1.0, 0.0, 0.0, 0.5)); + this->addChild(drawNode2); } ActionCatmullRomStacked::~ActionCatmullRomStacked() { - CC_SAFE_RELEASE(_array1); - CC_SAFE_RELEASE(_array2); -} - -void ActionCatmullRomStacked::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - ActionsDemo::draw(renderer, transform, flags); - - // move to 50,50 since the "by" path will start at 50,50 - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - Mat4 translation; - - //Create a rotation matrix using the axis and the angle - Mat4::createTranslation(50, 50, 0, &translation); - director->multiplyMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, translation); - - _modelViewMV1 = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - _modelViewMV2 = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - _customCommand.init(_globalZOrder); - _customCommand.func = CC_CALLBACK_0(ActionCatmullRomStacked::onDraw, this, transform, flags); - renderer->addCommand(&_customCommand); -} - -void ActionCatmullRomStacked::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - - Mat4 oldMat; - oldMat = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewMV1); - DrawPrimitives::drawCatmullRom(_array1,50); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewMV2); - DrawPrimitives::drawCatmullRom(_array2,50); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, oldMat); } std::string ActionCatmullRomStacked::title() const @@ -1753,6 +1700,11 @@ void ActionCardinalSplineStacked::onEnter() MoveBy::create(0.05f, Vec2(-10,0)), nullptr))); + auto drawNode1 = DrawNode::create(); + drawNode1->setPosition(Vec2(50,50)); + drawNode1->drawCardinalSpline(array, 0, 100, Color4F(1.0, 0.0, 1.0, 1.0)); + this->addChild(drawNode1); + // // sprite 2 (By) // @@ -1775,61 +1727,14 @@ void ActionCardinalSplineStacked::onEnter() MoveBy::create(0.05f, Vec2(-10,0)), nullptr))); - array->retain(); - _array = array; + auto drawNode2 = DrawNode::create(); + drawNode2->setPosition(Vec2(s.width/2,50)); + drawNode2->drawCardinalSpline(array, 1, 100, Color4F(0.0, 0.0, 1.0, 1.0)); + this->addChild(drawNode2); } ActionCardinalSplineStacked::~ActionCardinalSplineStacked() { - CC_SAFE_RELEASE(_array); -} - -void ActionCardinalSplineStacked::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - ActionsDemo::draw(renderer, transform, flags); - - // move to 50,50 since the "by" path will start at 50,50 - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - Mat4 translation; - - //Create a rotation matrix using the axis and the angle - Mat4::createTranslation(50, 50, 0, &translation); - director->multiplyMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, translation); - - _modelViewMV1 = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - auto s = Director::getInstance()->getWinSize(); - - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - //Create a rotation matrix using the axis and the angle - Mat4::createTranslation(s.width/2, 50, 0, &translation); - director->multiplyMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, translation); - - _modelViewMV2 = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - _customCommand.init(_globalZOrder); - _customCommand.func = CC_CALLBACK_0(ActionCardinalSplineStacked::onDraw, this, transform, flags); - renderer->addCommand(&_customCommand); -} - -void ActionCardinalSplineStacked::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - - Mat4 oldMat; - oldMat = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewMV1); - DrawPrimitives::drawCardinalSpline(_array, 0, 100); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewMV2); - DrawPrimitives::drawCardinalSpline(_array, 1, 100); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, oldMat); } std::string ActionCardinalSplineStacked::title() const @@ -2163,6 +2068,10 @@ void ActionCatmullRom::onEnter() _tamara->runAction(seq); + auto drawNode1 = DrawNode::create(); + drawNode1->setPosition(Vec2(50,50)); + drawNode1->drawCatmullRom(array, 50, Color4F(1.0, 0.0, 1.0, 1.0)); + this->addChild(drawNode1); // // sprite 2 (To) @@ -2186,58 +2095,15 @@ void ActionCatmullRom::onEnter() _kathia->runAction(seq2); - _array1 = array; - _array1->retain(); - _array2 = array2; - _array2->retain(); + auto drawNode2 = DrawNode::create(); + drawNode2->drawCatmullRom(array2, 50, Color4F(0.0, 1.0, 1.0, 1.0)); + this->addChild(drawNode2); } ActionCatmullRom::~ActionCatmullRom() { - _array1->release(); - _array2->release(); } -void ActionCatmullRom::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - ActionsDemo::draw(renderer, transform, flags); - - // move to 50,50 since the "by" path will start at 50,50 - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - Mat4 translation; - - //Create a rotation matrix using the axis and the angle - Mat4::createTranslation(50, 50, 0, &translation); - director->multiplyMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, translation); - _modelViewMV1 = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - _modelViewMV2 = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - _customCommand.init(_globalZOrder); - _customCommand.func = CC_CALLBACK_0(ActionCatmullRom::onDraw, this, transform, flags); - renderer->addCommand(&_customCommand); -} - - -void ActionCatmullRom::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - - Mat4 oldMat; - oldMat = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewMV1); - DrawPrimitives::drawCatmullRom(_array1, 50); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewMV2); - DrawPrimitives::drawCatmullRom(_array2,50); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, oldMat); -} - - std::string ActionCatmullRom::title() const { return "CatmullRomBy / CatmullRomTo"; @@ -2280,6 +2146,11 @@ void ActionCardinalSpline::onEnter() _tamara->setPosition(50, 50); _tamara->runAction(seq); + auto drawNode1 = DrawNode::create(); + drawNode1->setPosition(Vec2(50,50)); + drawNode1->drawCardinalSpline(array, 0, 100, Color4F(1.0, 0.0, 1.0, 1.0)); + this->addChild(drawNode1); + // // sprite 2 (By) // @@ -2294,59 +2165,14 @@ void ActionCardinalSpline::onEnter() _kathia->setPosition(s.width/2, 50); _kathia->runAction(seq2); - _array = array; - array->retain(); + auto drawNode2 = DrawNode::create(); + drawNode2->setPosition(Vec2(s.width/2, 50)); + drawNode2->drawCardinalSpline(array, 1, 100, Color4F(1.0, 0.0, 1.0, 1.0)); + this->addChild(drawNode2); } ActionCardinalSpline::~ActionCardinalSpline() { - _array->release(); -} - -void ActionCardinalSpline::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - ActionsDemo::draw(renderer, transform, flags); - - // move to 50,50 since the "by" path will start at 50,50 - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - Mat4 translation; - - //Create a rotation matrix using the axis and the angle - Mat4::createTranslation(50, 50, 0, &translation); - director->multiplyMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, translation); - _modelViewMV1 = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - auto s = Director::getInstance()->getWinSize(); - - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - //Create a rotation matrix using the axis and the angle - Mat4::createTranslation(s.width/2, 50, 0, &translation); - director->multiplyMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, translation); - _modelViewMV2 = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - - _customCommand.init(_globalZOrder); - _customCommand.func = CC_CALLBACK_0(ActionCardinalSpline::onDraw, this, transform, flags); - renderer->addCommand(&_customCommand); -} - -void ActionCardinalSpline::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - - Mat4 oldMat; - oldMat = director->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewMV1); - DrawPrimitives::drawCardinalSpline(_array, 0, 100); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewMV2); - DrawPrimitives::drawCardinalSpline(_array, 1, 100); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, oldMat); } std::string ActionCardinalSpline::title() const diff --git a/tests/cpp-tests/Classes/ActionsTest/ActionsTest.h b/tests/cpp-tests/Classes/ActionsTest/ActionsTest.h index a596e23cb0..25fe9f48ff 100644 --- a/tests/cpp-tests/Classes/ActionsTest/ActionsTest.h +++ b/tests/cpp-tests/Classes/ActionsTest/ActionsTest.h @@ -379,13 +379,7 @@ public: CREATE_FUNC(ActionFollow); virtual void onEnter() override; - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual std::string subtitle() const override; - -protected: - void onDraw(const Mat4 &transform, uint32_t flags); - - CustomCommand _customCommand; }; class ActionTargeted : public ActionsDemo @@ -454,20 +448,9 @@ public: CREATE_FUNC(ActionCatmullRomStacked); virtual ~ActionCatmullRomStacked(); - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual void onEnter() override; virtual std::string title() const override; virtual std::string subtitle() const override; - -protected: - void onDraw(const Mat4 &transform, uint32_t flags); - - //cached data and callback - Mat4 _modelViewMV1; - Mat4 _modelViewMV2; - PointArray* _array1; - PointArray* _array2; - CustomCommand _customCommand; }; class ActionCardinalSplineStacked : public ActionsDemo @@ -476,18 +459,9 @@ public: CREATE_FUNC(ActionCardinalSplineStacked); virtual ~ActionCardinalSplineStacked(); - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags); virtual void onEnter() override; virtual std::string title() const override; virtual std::string subtitle() const override; - -protected: - void onDraw(const Mat4 &transform, uint32_t flags); - - Mat4 _modelViewMV1; - Mat4 _modelViewMV2; - CustomCommand _customCommand; - PointArray* _array; }; class Issue1305 : public ActionsDemo @@ -584,18 +558,8 @@ public: ~ActionCatmullRom(); virtual void onEnter() override; - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual std::string subtitle() const override; virtual std::string title() const override; - -protected: - void onDraw(const Mat4 &transform, uint32_t flags); - - Mat4 _modelViewMV1; - Mat4 _modelViewMV2; - CustomCommand _customCommand; - PointArray *_array1; - PointArray *_array2; }; class ActionCardinalSpline : public ActionsDemo @@ -606,17 +570,8 @@ public: ~ActionCardinalSpline(); virtual void onEnter() override; - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual std::string subtitle() const override; virtual std::string title() const override; - -protected: - void onDraw(const Mat4 &transform, uint32_t flags); - - PointArray *_array; - Mat4 _modelViewMV1; - Mat4 _modelViewMV2; - CustomCommand _customCommand; }; class PauseResumeActions : public ActionsDemo diff --git a/tests/cpp-tests/Classes/ClippingNodeTest/ClippingNodeTest.cpp b/tests/cpp-tests/Classes/ClippingNodeTest/ClippingNodeTest.cpp index e7ad67a7ee..9af98ad05d 100644 --- a/tests/cpp-tests/Classes/ClippingNodeTest/ClippingNodeTest.cpp +++ b/tests/cpp-tests/Classes/ClippingNodeTest/ClippingNodeTest.cpp @@ -677,15 +677,75 @@ void RawStencilBufferTest::onBeforeDrawClip(int planeIndex, const Vec2& pt) { this->setupStencilForClippingOnPlane(planeIndex); CHECK_GL_ERROR_DEBUG(); - DrawPrimitives::drawSolidRect(Vec2::ZERO, pt, Color4F(1, 1, 1, 1)); + + Vec2 vertices[] = { + Vec2::ZERO, + Vec2(pt.x, 0), + pt, + Vec2(0, pt.y) + }; + + auto glProgram= GLProgramCache::getInstance()->getGLProgram(GLProgram::SHADER_NAME_POSITION_U_COLOR); + glProgram->retain(); + + int colorLocation = glProgram->getUniformLocation("u_color"); + CHECK_GL_ERROR_DEBUG(); + + Color4F color(1, 1, 1, 1); + + glProgram->use(); + glProgram->setUniformsForBuiltins(); + glProgram->setUniformLocationWith4fv(colorLocation, (GLfloat*) &color.r, 1); + + GL::enableVertexAttribs( GL::VERTEX_ATTRIB_FLAG_POSITION ); + + GLuint vbo; + glGenBuffers(1, &vbo); + glBindBuffer(GL_ARRAY_BUFFER, vbo); + glBufferData(GL_ARRAY_BUFFER, sizeof(Vec2)*4, vertices, GL_STREAM_DRAW); + + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_POSITION, 2, GL_FLOAT, GL_FALSE, 0, 0); + glDrawArrays(GL_TRIANGLE_FAN, 0, 4); + glBindBuffer(GL_ARRAY_BUFFER, 0); + + CC_INCREMENT_GL_DRAWN_BATCHES_AND_VERTICES(1, 4); } void RawStencilBufferTest::onBeforeDrawSprite(int planeIndex, const Vec2& pt) { this->setupStencilForDrawingOnPlane(planeIndex); CHECK_GL_ERROR_DEBUG(); - - DrawPrimitives::drawSolidRect(Vec2::ZERO, pt, _planeColor[planeIndex]); + + Vec2 vertices[] = { + Vec2::ZERO, + Vec2(pt.x, 0), + pt, + Vec2(0, pt.y) + }; + + auto glProgram = GLProgramCache::getInstance()->getGLProgram(GLProgram::SHADER_NAME_POSITION_U_COLOR); + glProgram->retain(); + + int colorLocation = glProgram->getUniformLocation("u_color"); + CHECK_GL_ERROR_DEBUG(); + + Color4F color = _planeColor[planeIndex]; + glProgram->use(); + glProgram->setUniformsForBuiltins(); + glProgram->setUniformLocationWith4fv(colorLocation, (GLfloat*) &color.r, 1); + + GL::enableVertexAttribs( GL::VERTEX_ATTRIB_FLAG_POSITION ); + + GLuint vbo; + glGenBuffers(1, &vbo); + glBindBuffer(GL_ARRAY_BUFFER, vbo); + glBufferData(GL_ARRAY_BUFFER, sizeof(Vec2)*4, vertices, GL_STREAM_DRAW); + + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_POSITION, 2, GL_FLOAT, GL_FALSE, 0, 0); + glDrawArrays(GL_TRIANGLE_FAN, 0, 4); + glBindBuffer(GL_ARRAY_BUFFER, 0); + + CC_INCREMENT_GL_DRAWN_BATCHES_AND_VERTICES(1, 4); } void RawStencilBufferTest::setupStencilForClippingOnPlane(GLint plane) @@ -861,7 +921,40 @@ void RawStencilBufferTest6::setupStencilForClippingOnPlane(GLint plane) glStencilMask(planeMask); glStencilFunc(GL_NEVER, 0, planeMask); glStencilOp(GL_REPLACE, GL_KEEP, GL_KEEP); - DrawPrimitives::drawSolidRect(Vec2::ZERO, Vec2(Director::getInstance()->getWinSize()), Color4F(1, 1, 1, 1)); + + Vec2 pt = Director::getInstance()->getWinSize(); + Vec2 vertices[] = { + Vec2::ZERO, + Vec2(pt.x, 0), + pt, + Vec2(0, pt.y) + }; + + auto glProgram = GLProgramCache::getInstance()->getGLProgram(GLProgram::SHADER_NAME_POSITION_U_COLOR); + glProgram->retain(); + + int colorLocation = glProgram->getUniformLocation("u_color"); + CHECK_GL_ERROR_DEBUG(); + + Color4F color(1, 1, 1, 1); + + glProgram->use(); + glProgram->setUniformsForBuiltins(); + glProgram->setUniformLocationWith4fv(colorLocation, (GLfloat*) &color.r, 1); + + GL::enableVertexAttribs( GL::VERTEX_ATTRIB_FLAG_POSITION ); + + GLuint vbo; + glGenBuffers(1, &vbo); + glBindBuffer(GL_ARRAY_BUFFER, vbo); + glBufferData(GL_ARRAY_BUFFER, sizeof(Vec2)*4, vertices, GL_STREAM_DRAW); + + glVertexAttribPointer(GLProgram::VERTEX_ATTRIB_POSITION, 2, GL_FLOAT, GL_FALSE, 0, 0); + glDrawArrays(GL_TRIANGLE_FAN, 0, 4); + glBindBuffer(GL_ARRAY_BUFFER, 0); + + CC_INCREMENT_GL_DRAWN_BATCHES_AND_VERTICES(1, 4); + glStencilFunc(GL_NEVER, planeMask, planeMask); glStencilOp(GL_REPLACE, GL_KEEP, GL_KEEP); glDisable(GL_DEPTH_TEST); diff --git a/tests/cpp-tests/Classes/DrawPrimitivesTest/DrawPrimitivesTest.cpp b/tests/cpp-tests/Classes/DrawPrimitivesTest/DrawPrimitivesTest.cpp index 7f4c78335e..2d27dad1a2 100644 --- a/tests/cpp-tests/Classes/DrawPrimitivesTest/DrawPrimitivesTest.cpp +++ b/tests/cpp-tests/Classes/DrawPrimitivesTest/DrawPrimitivesTest.cpp @@ -257,6 +257,60 @@ DrawNodeTest::DrawNodeTest() auto draw = DrawNode::create(); addChild(draw, 10); + draw->drawPoint(Vec2(s.width/2-120, s.height/2-120), 10, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 1)); + + draw->drawPoint(Vec2(s.width/2+120, s.height/2+120), 10, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 1)); + + // draw 4 small points + Vec2 position[] = { Vec2(60,60), Vec2(70,70), Vec2(60,70), Vec2(70,60) }; + draw->drawPoints( position, 4, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 1)); + + // draw a line + draw->drawLine(Vec2(0,0), Vec2(s.width, s.height), Color4F(1.0, 0.0, 0.0, 0.5)); + + // draw a rectangle + draw->drawRect(Vec2(23,23), Vec2(7,7), Color4F(1,1,0,1)); + + // draw a circle + draw->drawCircle(VisibleRect::center() + Vec2(140,0), 100, CC_DEGREES_TO_RADIANS(90), 50, true, 1.0f, 2.0f, Color4F(1.0, 0.0, 0.0, 0.5)); + + draw->drawCircle(VisibleRect::center() - Vec2(140,0), 50, CC_DEGREES_TO_RADIANS(90), 30, false, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 1)); + + // Draw some beziers + draw->drawQuadBezier(Vec2(s.width - 150, s.height - 150), Vec2(s.width - 70, s.height - 10), Vec2(s.width - 10, s.height - 10), 10, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 0.5)); + + draw->drawQuadBezier(Vec2(0, s.height), Vec2(s.width/2, s.height/2), Vec2(s.width, s.height), 50, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 0.5)); + + draw->drawCubicBezier(VisibleRect::center(), Vec2(VisibleRect::center().x+30,VisibleRect::center().y+50), Vec2(VisibleRect::center().x+60,VisibleRect::center().y-50),VisibleRect::right(),100, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 0.5)); + + draw->drawCubicBezier(Vec2(s.width - 250, 40), Vec2(s.width - 70, 100), Vec2(s.width - 30, 250), Vec2(s.width - 10, s.height - 50), 10, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 0.5)); + + auto array = PointArray::create(20); + array->addControlPoint(Vec2(0,0)); + array->addControlPoint(Vec2(80,80)); + array->addControlPoint(Vec2(s.width-80,80)); + array->addControlPoint(Vec2(s.width-80,s.height-80)); + array->addControlPoint(Vec2(80,s.height-80)); + array->addControlPoint(Vec2(80,80)); + array->addControlPoint(Vec2(s.width/2, s.height/2)); + draw->drawCardinalSpline(array, 0.5, 50, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 0.5)); + + auto array2 = PointArray::create(20); + array2->addControlPoint(Vec2(s.width / 2, 30)); + array2->addControlPoint(Vec2(s.width -80, 30)); + array2->addControlPoint(Vec2(s.width - 80, s.height - 80)); + array2->addControlPoint(Vec2(s.width / 2, s.height - 80)); + array2->addControlPoint(Vec2(s.width / 2, 30)); + draw->drawCatmullRom(array2, 50, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 0.5)); + + // open random color poly + Vec2 vertices[] = { Vec2(0,0), Vec2(50,50), Vec2(100,50), Vec2(100,100), Vec2(50,100) }; + draw->drawPoly( vertices, 5, false, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 1)); + + // closed random color poly + Vec2 vertices2[] = { Vec2(30,130), Vec2(30,230), Vec2(50,200) }; + draw->drawPoly( vertices2, 3, true, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 1)); + // Draw 10 circles for( int i=0; i < 10; i++) { @@ -265,7 +319,7 @@ DrawNodeTest::DrawNodeTest() // Draw polygons Vec2 points[] = { Vec2(s.height/4,0), Vec2(s.width,s.height/5), Vec2(s.width/3*2,s.height) }; - draw->drawPolygon(points, sizeof(points)/sizeof(points[0]), Color4F(1,0,0,0.5), 4, Color4F(0,0,1,1)); + draw->drawPolygon(points, sizeof(points)/sizeof(points[0]), Color4F(1,0,0,0.5), 4, Color4F(0,0,1,0.5)); // star poly (triggers buggs) { @@ -297,19 +351,23 @@ DrawNodeTest::DrawNodeTest() draw->drawPolygon(star, sizeof(star)/sizeof(star[0]), Color4F(1,0,0,0.5), 1, Color4F(0,0,1,1)); } + //draw a solid polygon + Vec2 vertices3[] = {Vec2(60,160), Vec2(70,190), Vec2(100,190), Vec2(90,160)}; + draw->drawSolidPoly( vertices3, 4, Color4F(1,1,0,1) ); + + //draw a solid rectangle + draw->drawSolidRect(Vec2(10,10), Vec2(20,20), Color4F(1,1,0,1)); + + //draw a solid circle + draw->drawSolidCircle( VisibleRect::center() + Vec2(140,0), 40, CC_DEGREES_TO_RADIANS(90), 50, 2.0f, 2.0f, Color4F(0.0, 1.0, 0.0, 1.0)); // Draw segment draw->drawSegment(Vec2(20,s.height), Vec2(20,s.height/2), 10, Color4F(0, 1, 0, 1)); - + draw->drawSegment(Vec2(10,s.height/2), Vec2(s.width/2, s.height/2), 40, Color4F(1, 0, 1, 0.5)); // Draw triangle draw->drawTriangle(Vec2(10, 10), Vec2(70, 30), Vec2(100, 140), Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 0.5)); - - // Draw some beziers - draw->drawQuadraticBezier(Vec2(s.width - 150, s.height - 150), Vec2(s.width - 70, s.height - 10), Vec2(s.width - 10, s.height - 10), 10, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 0.5)); - - draw->drawCubicBezier(Vec2(s.width - 250, 40), Vec2(s.width - 70, 100), Vec2(s.width - 30, 250), Vec2(s.width - 10, s.height - 50), 10, Color4F(CCRANDOM_0_1(), CCRANDOM_0_1(), CCRANDOM_0_1(), 0.5)); } string DrawNodeTest::title() const diff --git a/tests/cpp-tests/Classes/ExtensionsTest/CocoStudioArmatureTest/ArmatureScene.cpp b/tests/cpp-tests/Classes/ExtensionsTest/CocoStudioArmatureTest/ArmatureScene.cpp index 32644c847d..5cf57fda40 100644 --- a/tests/cpp-tests/Classes/ExtensionsTest/CocoStudioArmatureTest/ArmatureScene.cpp +++ b/tests/cpp-tests/Classes/ExtensionsTest/CocoStudioArmatureTest/ArmatureScene.cpp @@ -764,6 +764,10 @@ void TestColliderDetector::onEnter() bullet = cocos2d::extension::PhysicsSprite::createWithSpriteFrameName("25.png"); #elif ENABLE_PHYSICS_SAVE_CALCULATED_VERTEX bullet = Sprite::createWithSpriteFrameName("25.png"); + + drawNode = DrawNode::create(); + addChild(drawNode, -1); + #endif addChild(bullet); @@ -1070,21 +1074,35 @@ void TestColliderDetector::update(float delta) } void TestColliderDetector::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) { - _customCommand.init(_globalZOrder); - _customCommand.func = CC_CALLBACK_0(TestColliderDetector::onDraw, this, transform, flags); - renderer->addCommand(&_customCommand); -} - -void TestColliderDetector::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - - armature2->drawContour(); - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + for(auto& element : armature2->getBoneDic()) + { + Bone *bone = element.second; + ColliderDetector *detector = bone->getColliderDetector(); + + if (!detector) + continue; + + const cocos2d::Vector& bodyList = detector->getColliderBodyList(); + + for (auto& object : bodyList) + { + ColliderBody *body = static_cast(object); + const std::vector &vertexList = body->getCalculatedVertexList(); + + unsigned long length = vertexList.size(); + Vec2 *points = new Vec2[length]; + for (unsigned long i = 0; iclear(); + drawNode->drawPoly(points, (unsigned int)length, true, Color4F(1.0, 1.0, 1.0, 1.0)); + + delete []points; + } + } } #endif @@ -1104,6 +1122,9 @@ void TestBoundingBox::onEnter() Sprite *sprite = Sprite::create("Images/background3.png"); armature->addChild(sprite); + + _drawNode = DrawNode::create(); + this->addChild(_drawNode); } std::string TestBoundingBox::title() const { @@ -1111,21 +1132,9 @@ std::string TestBoundingBox::title() const } void TestBoundingBox::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) { - _customCommand.init(_globalZOrder); - _customCommand.func = CC_CALLBACK_0(TestBoundingBox::onDraw, this, transform, flags); - renderer->addCommand(&_customCommand); - -} - -void TestBoundingBox::onDraw(const Mat4 &transform, uint32_t flags) -{ - getGLProgram()->use(); - getGLProgram()->setUniformsForBuiltins(transform); - rect = armature->getBoundingBox(); - - DrawPrimitives::setDrawColor4B(100, 100, 100, 255); - DrawPrimitives::drawRect(rect.origin, Vec2(rect.getMaxX(), rect.getMaxY())); + _drawNode->clear(); + _drawNode->drawRect(rect.origin, Vec2(rect.getMaxX(), rect.getMaxY()), Color4F(1.0, 0.5, 0.5, 1.0)); } void TestAnchorPoint::onEnter() diff --git a/tests/cpp-tests/Classes/ExtensionsTest/CocoStudioArmatureTest/ArmatureScene.h b/tests/cpp-tests/Classes/ExtensionsTest/CocoStudioArmatureTest/ArmatureScene.h index 4b353e6fcd..a5e1a3f49a 100644 --- a/tests/cpp-tests/Classes/ExtensionsTest/CocoStudioArmatureTest/ArmatureScene.h +++ b/tests/cpp-tests/Classes/ExtensionsTest/CocoStudioArmatureTest/ArmatureScene.h @@ -272,7 +272,6 @@ public: virtual std::string title() const override; virtual void update(float delta); virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; - void onDraw(const Mat4 &transform, uint32_t flags); void onFrameEvent(cocostudio::Bone *bone, const std::string& evt, int originFrameIndex, int currentFrameIndex); @@ -280,7 +279,7 @@ public: cocostudio::Armature *armature; cocostudio::Armature *armature2; - CustomCommand _customCommand; //new render needed this for drawing primitives + DrawNode *drawNode; cocos2d::Sprite *bullet; }; #endif @@ -298,11 +297,9 @@ public: cocostudio::Armature *armature; Rect rect; - + protected: - void onDraw(const Mat4 &transform, uint32_t flags); - - CustomCommand _customCommand; + DrawNode* _drawNode; }; class TestAnchorPoint : public ArmatureTestLayer diff --git a/tests/cpp-tests/Classes/LabelTest/LabelTest.cpp b/tests/cpp-tests/Classes/LabelTest/LabelTest.cpp index 48014b08ab..3959e662a4 100644 --- a/tests/cpp-tests/Classes/LabelTest/LabelTest.cpp +++ b/tests/cpp-tests/Classes/LabelTest/LabelTest.cpp @@ -484,12 +484,17 @@ Atlas4::Atlas4() { _time = 0; + auto s = Director::getInstance()->getWinSize(); + + auto drawNode = DrawNode::create(); + drawNode->drawLine( Vec2(0, s.height/2), Vec2(s.width, s.height/2), Color4F(1.0, 1.0, 1.0, 1.0) ); + drawNode->drawLine( Vec2(s.width/2, 0), Vec2(s.width/2, s.height), Color4F(1.0, 1.0, 1.0, 1.0) ); + addChild(drawNode, -1); + // Upper Label auto label = LabelBMFont::create("Bitmap Font Atlas", "fonts/bitmapFontTest.fnt"); addChild(label); - auto s = Director::getInstance()->getWinSize(); - label->setPosition( Vec2(s.width/2, s.height/2) ); label->setAnchorPoint( Vec2::ANCHOR_MIDDLE ); @@ -532,27 +537,6 @@ Atlas4::Atlas4() schedule( schedule_selector(Atlas4::step), 0.1f); } -void Atlas4::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _customCommand.init(_globalZOrder); - _customCommand.func = CC_CALLBACK_0(Atlas4::onDraw, this, transform, flags); - renderer->addCommand(&_customCommand); -} - -void Atlas4::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - - auto s = Director::getInstance()->getWinSize(); - DrawPrimitives::drawLine( Vec2(0, s.height/2), Vec2(s.width, s.height/2) ); - DrawPrimitives::drawLine( Vec2(s.width/2, 0), Vec2(s.width/2, s.height) ); - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); -} - void Atlas4::step(float dt) { _time += dt; @@ -1644,36 +1628,13 @@ LabelBMFontBounds::LabelBMFontBounds() addChild(layer, -10); // LabelBMFont - label1 = LabelBMFont::create("Testing Glyph Designer", "fonts/boundsTestFont.fnt"); + auto label1 = LabelBMFont::create("Testing Glyph Designer", "fonts/boundsTestFont.fnt"); addChild(label1); label1->setPosition(Vec2(s.width/2, s.height/2)); -} - -std::string LabelBMFontBounds::title() const -{ - return "Testing LabelBMFont Bounds"; -} - -std::string LabelBMFontBounds::subtitle() const -{ - return "You should see string enclosed by a box"; -} - -void LabelBMFontBounds::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _customCommand.init(_globalZOrder); - _customCommand.func = CC_CALLBACK_0(LabelBMFontBounds::onDraw, this, transform, flags); - renderer->addCommand(&_customCommand); -} - -void LabelBMFontBounds::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - + + auto drawNode = DrawNode::create(); + auto labelSize = label1->getContentSize(); auto origin = Director::getInstance()->getWinSize(); @@ -1687,9 +1648,18 @@ void LabelBMFontBounds::onDraw(const Mat4 &transform, uint32_t flags) Vec2(labelSize.width + origin.width, labelSize.height + origin.height), Vec2(origin.width, labelSize.height + origin.height) }; - DrawPrimitives::drawPoly(vertices, 4, true); + drawNode->drawPoly(vertices, 4, true, Color4F(1.0, 1.0, 1.0, 1.0)); + addChild(drawNode); +} - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); +std::string LabelBMFontBounds::title() const +{ + return "Testing LabelBMFont Bounds"; +} + +std::string LabelBMFontBounds::subtitle() const +{ + return "You should see string enclosed by a box"; } // LabelBMFontCrashTest diff --git a/tests/cpp-tests/Classes/LabelTest/LabelTest.h b/tests/cpp-tests/Classes/LabelTest/LabelTest.h index 68ac427bb5..2f0e0d252f 100644 --- a/tests/cpp-tests/Classes/LabelTest/LabelTest.h +++ b/tests/cpp-tests/Classes/LabelTest/LabelTest.h @@ -108,14 +108,9 @@ public: Atlas4(); virtual void step(float dt); - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual std::string title() const override; virtual std::string subtitle() const override; -protected: - void onDraw(const Mat4 &transform, uint32_t flags); -protected: - CustomCommand _customCommand; }; class Atlas5 : public AtlasDemo @@ -383,14 +378,8 @@ public: LabelBMFontBounds(); - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual std::string title() const override; virtual std::string subtitle() const override; -protected: - void onDraw(const Mat4 &transform, uint32_t flags); -private: - LabelBMFont *label1; - CustomCommand _customCommand; }; class NewLabelTTFUnicode : public AtlasDemo diff --git a/tests/cpp-tests/Classes/LabelTest/LabelTestNew.cpp b/tests/cpp-tests/Classes/LabelTest/LabelTestNew.cpp index ee7d63a9c2..28750581ea 100644 --- a/tests/cpp-tests/Classes/LabelTest/LabelTestNew.cpp +++ b/tests/cpp-tests/Classes/LabelTest/LabelTestNew.cpp @@ -263,12 +263,18 @@ std::string LabelFNTColorAndOpacity::subtitle() const LabelFNTSpriteActions::LabelFNTSpriteActions() { _time = 0; + + auto s = Director::getInstance()->getWinSize(); + + auto drawNode = DrawNode::create(); + drawNode->drawLine( Vec2(0, s.height/2), Vec2(s.width, s.height/2), Color4F(1.0, 1.0, 1.0, 1.0) ); + drawNode->drawLine( Vec2(s.width/2, 0), Vec2(s.width/2, s.height), Color4F(1.0, 1.0, 1.0, 1.0) ); + addChild(drawNode, -1); // Upper Label auto label = Label::createWithBMFont("fonts/bitmapFontTest.fnt", "Bitmap Font Atlas"); addChild(label); - auto s = Director::getInstance()->getWinSize(); label->setPosition( Vec2(s.width/2, s.height/2) ); @@ -310,28 +316,6 @@ LabelFNTSpriteActions::LabelFNTSpriteActions() schedule( schedule_selector(LabelFNTSpriteActions::step), 0.1f); } -void LabelFNTSpriteActions::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _renderCmd.init(_globalZOrder); - _renderCmd.func = CC_CALLBACK_0(LabelFNTSpriteActions::onDraw, this, transform, flags); - renderer->addCommand(&_renderCmd); - -} - -void LabelFNTSpriteActions::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - - auto s = Director::getInstance()->getWinSize(); - DrawPrimitives::drawLine( Vec2(0, s.height/2), Vec2(s.width, s.height/2) ); - DrawPrimitives::drawLine( Vec2(s.width/2, 0), Vec2(s.width/2, s.height) ); - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); -} - void LabelFNTSpriteActions::step(float dt) { _time += dt; @@ -894,35 +878,11 @@ LabelFNTBounds::LabelFNTBounds() addChild(layer, -10); // LabelBMFont - label1 = Label::createWithBMFont("fonts/boundsTestFont.fnt", "Testing Glyph Designer", TextHAlignment::CENTER,s.width); + auto label1 = Label::createWithBMFont("fonts/boundsTestFont.fnt", "Testing Glyph Designer", TextHAlignment::CENTER,s.width); addChild(label1); label1->setPosition(Vec2(s.width/2, s.height/2)); -} -std::string LabelFNTBounds::title() const -{ - return "New Label + .FNT + Bounds"; -} - -std::string LabelFNTBounds::subtitle() const -{ - return "You should see string enclosed by a box"; -} - -void LabelFNTBounds::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _renderCmd.init(_globalZOrder); - _renderCmd.func = CC_CALLBACK_0(LabelFNTBounds::onDraw, this, transform, flags); - renderer->addCommand(&_renderCmd); -} - -void LabelFNTBounds::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - + auto drawNode = DrawNode::create(); auto labelSize = label1->getContentSize(); auto origin = Director::getInstance()->getWinSize(); @@ -936,9 +896,18 @@ void LabelFNTBounds::onDraw(const Mat4 &transform, uint32_t flags) Vec2(labelSize.width + origin.width, labelSize.height + origin.height), Vec2(origin.width, labelSize.height + origin.height) }; - DrawPrimitives::drawPoly(vertices, 4, true); - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + drawNode->drawPoly(vertices, 4, true, Color4F(1.0, 1.0, 1.0, 1.0)); + addChild(drawNode); +} + +std::string LabelFNTBounds::title() const +{ + return "New Label + .FNT + Bounds"; +} + +std::string LabelFNTBounds::subtitle() const +{ + return "You should see string enclosed by a box"; } LabelTTFLongLineWrapping::LabelTTFLongLineWrapping() @@ -1508,16 +1477,8 @@ LabelTTFOldNew::LabelTTFOldNew() auto label2 = Label::createWithTTF(ttfConfig, "Cocos2d-x Label Test"); addChild(label2, 0, kTagBitmapAtlas2); label2->setPosition(Vec2(s.width/2, delta * 2)); -} -void LabelTTFOldNew::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - - auto label1 = (Label*)getChildByTag(kTagBitmapAtlas1); + auto drawNode = DrawNode::create(); auto labelSize = label1->getContentSize(); auto origin = Director::getInstance()->getWinSize(); @@ -1531,16 +1492,14 @@ void LabelTTFOldNew::onDraw(const Mat4 &transform, uint32_t flags) Vec2(labelSize.width + origin.width, labelSize.height + origin.height), Vec2(origin.width, labelSize.height + origin.height) }; - DrawPrimitives::setDrawColor4B(Color4B::RED.r,Color4B::RED.g,Color4B::RED.b,Color4B::RED.a); - DrawPrimitives::drawPoly(vertices, 4, true); - - auto label2 = (Label*)getChildByTag(kTagBitmapAtlas2); + drawNode->drawPoly(vertices, 4, true, Color4F(1.0, 0.0, 0.0, 1.0)); + labelSize = label2->getContentSize(); origin = Director::getInstance()->getWinSize(); - + origin.width = origin.width / 2 - (labelSize.width / 2); origin.height = origin.height / 2 - (labelSize.height / 2); - + Vec2 vertices2[4]= { Vec2(origin.width, origin.height), @@ -1548,17 +1507,9 @@ void LabelTTFOldNew::onDraw(const Mat4 &transform, uint32_t flags) Vec2(labelSize.width + origin.width, labelSize.height + origin.height), Vec2(origin.width, labelSize.height + origin.height) }; - DrawPrimitives::setDrawColor4B(Color4B::WHITE.r,Color4B::WHITE.g,Color4B::WHITE.b,Color4B::WHITE.a); - DrawPrimitives::drawPoly(vertices2, 4, true); + drawNode->drawPoly(vertices2, 4, true, Color4F(1.0, 1.0, 1.0, 1.0)); - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); -} - -void LabelTTFOldNew::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _renderCmd.init(_globalZOrder); - _renderCmd.func = CC_CALLBACK_0(LabelTTFOldNew::onDraw, this, transform, flags); - renderer->addCommand(&_renderCmd); + addChild(drawNode); } std::string LabelTTFOldNew::title() const diff --git a/tests/cpp-tests/Classes/LabelTest/LabelTestNew.h b/tests/cpp-tests/Classes/LabelTest/LabelTestNew.h index 3450352982..9e588e4931 100644 --- a/tests/cpp-tests/Classes/LabelTest/LabelTestNew.h +++ b/tests/cpp-tests/Classes/LabelTest/LabelTestNew.h @@ -58,14 +58,9 @@ public: LabelFNTSpriteActions(); virtual void step(float dt); - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual std::string title() const override; virtual std::string subtitle() const override; - -protected: - CustomCommand _renderCmd; - void onDraw(const Mat4 &transform, uint32_t flags); }; class LabelFNTPadding : public AtlasDemoNew @@ -224,14 +219,8 @@ public: LabelFNTBounds(); - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual std::string title() const override; virtual std::string subtitle() const override; - -protected: - CustomCommand _renderCmd; - void onDraw(const Mat4 &transform, uint32_t flags); - Label *label1; }; class LabelTTFLongLineWrapping : public AtlasDemoNew @@ -430,14 +419,8 @@ public: LabelTTFOldNew(); - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; - virtual std::string title() const override; virtual std::string subtitle() const override; - -protected: - CustomCommand _renderCmd; - void onDraw(const Mat4 &transform, uint32_t flags); }; class LabelFontNameTest : public AtlasDemoNew diff --git a/tests/cpp-tests/Classes/MutiTouchTest/MutiTouchTest.cpp b/tests/cpp-tests/Classes/MutiTouchTest/MutiTouchTest.cpp index 70108a8ac6..226007b30c 100644 --- a/tests/cpp-tests/Classes/MutiTouchTest/MutiTouchTest.cpp +++ b/tests/cpp-tests/Classes/MutiTouchTest/MutiTouchTest.cpp @@ -1,7 +1,7 @@ #include "MutiTouchTest.h" -static const Color3B* s_TouchColors[EventTouch::MAX_TOUCHES] = { +static const Color3B* s_TouchColors[5] = { &Color3B::YELLOW, &Color3B::BLUE, &Color3B::GREEN, @@ -12,44 +12,25 @@ static const Color3B* s_TouchColors[EventTouch::MAX_TOUCHES] = { class TouchPoint : public Node { public: - TouchPoint() + TouchPoint(const Vec2 &touchPoint, const Color3B &touchColor) { - setGLProgramState(GLProgramState::getOrCreateWithGLProgramName(GLProgram::SHADER_NAME_POSITION_TEXTURE_COLOR)); + DrawNode* drawNode = DrawNode::create(); + auto s = Director::getInstance()->getWinSize(); + Color4F color(touchColor.r/255.0f, touchColor.g/255.0f, touchColor.b/255.0f, 1.0f); + drawNode->drawLine(Vec2(0, touchPoint.y), Vec2(s.width, touchPoint.y), color); + drawNode->drawLine(Vec2(touchPoint.x, 0), Vec2(touchPoint.x, s.height), color); + drawNode->drawDot(touchPoint, 3, color); + addChild(drawNode); } - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) + static TouchPoint* touchPointWithParent(Node* pParent, const Vec2 &touchPoint, const Color3B &touchColor) { - DrawPrimitives::setDrawColor4B(_touchColor.r, _touchColor.g, _touchColor.b, 255); - glLineWidth(10); - DrawPrimitives::drawLine( Vec2(0, _touchPoint.y), Vec2(getContentSize().width, _touchPoint.y) ); - DrawPrimitives::drawLine( Vec2(_touchPoint.x, 0), Vec2(_touchPoint.x, getContentSize().height) ); - glLineWidth(1); - DrawPrimitives::setPointSize(30); - DrawPrimitives::drawPoint(_touchPoint); - } - - void setTouchPos(const Vec2& pt) - { - _touchPoint = pt; - } - - void setTouchColor(Color3B color) - { - _touchColor = color; - } - - static TouchPoint* touchPointWithParent(Node* pParent) - { - auto pRet = new (std::nothrow) TouchPoint(); + auto pRet = new (std::nothrow) TouchPoint(touchPoint, touchColor); pRet->setContentSize(pParent->getContentSize()); pRet->setAnchorPoint(Vec2(0.0f, 0.0f)); pRet->autorelease(); return pRet; } - -private: - Vec2 _touchPoint; - Color3B _touchColor; }; bool MutiTouchTestLayer::init() @@ -78,11 +59,8 @@ void MutiTouchTestLayer::onTouchesBegan(const std::vector& touches, Even for ( auto &item: touches ) { auto touch = item; - auto touchPoint = TouchPoint::touchPointWithParent(this); auto location = touch->getLocation(); - - touchPoint->setTouchPos(location); - touchPoint->setTouchColor(*s_TouchColors[touch->getID()]); + auto touchPoint = TouchPoint::touchPointWithParent(this, location, *s_TouchColors[touch->getID()%5]); addChild(touchPoint); s_map.insert(touch->getID(), touchPoint); @@ -96,7 +74,13 @@ void MutiTouchTestLayer::onTouchesMoved(const std::vector& touches, Even auto touch = item; auto pTP = s_map.at(touch->getID()); auto location = touch->getLocation(); - pTP->setTouchPos(location); + + removeChild(pTP, true); + s_map.erase(touch->getID()); + + auto touchPointNew = TouchPoint::touchPointWithParent(this, location, *s_TouchColors[touch->getID()%5]); + addChild(touchPointNew); + s_map.insert(touch->getID(), touchPointNew); } } diff --git a/tests/cpp-tests/Classes/TileMapTest/TileMapTest.cpp b/tests/cpp-tests/Classes/TileMapTest/TileMapTest.cpp index 1d380d63df..9349fbc7a7 100644 --- a/tests/cpp-tests/Classes/TileMapTest/TileMapTest.cpp +++ b/tests/cpp-tests/Classes/TileMapTest/TileMapTest.cpp @@ -757,28 +757,9 @@ TMXOrthoObjectsTest::TMXOrthoObjectsTest() Value objectsVal = Value(objects); CCLOG("%s", objectsVal.getDescription().c_str()); -} -void TMXOrthoObjectsTest::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _renderCmd.init(_globalZOrder); - _renderCmd.func = CC_CALLBACK_0(TMXOrthoObjectsTest::onDraw, this, transform, flags); - renderer->addCommand(&_renderCmd); -} - -void TMXOrthoObjectsTest::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); + auto drawNode = DrawNode::create(); - auto map = static_cast( getChildByTag(kTagTileMap) ); - auto pos = map->getPosition(); - auto group = map->getObjectGroup("Object Group 1"); - - auto& objects = group->getObjects(); - for (auto& obj : objects) { ValueMap& dict = obj.asValueMap(); @@ -788,17 +769,14 @@ void TMXOrthoObjectsTest::onDraw(const Mat4 &transform, uint32_t flags) float width = dict["width"].asFloat(); float height = dict["height"].asFloat(); - glLineWidth(3); + Color4F color(1.0, 1.0, 1.0, 1.0); - DrawPrimitives::drawLine( pos + Vec2(x, y), pos + Vec2((x+width), y) ); - DrawPrimitives::drawLine( pos + Vec2((x+width), y), pos + Vec2((x+width), (y+height)) ); - DrawPrimitives::drawLine( pos + Vec2((x+width), (y+height)), pos + Vec2(x, (y+height)) ); - DrawPrimitives::drawLine( pos + Vec2(x, (y+height)), pos + Vec2(x, y) ); - - glLineWidth(1); + drawNode->drawLine( Vec2(x, y), Vec2((x+width), y), color ); + drawNode->drawLine( Vec2((x+width), y), Vec2((x+width), (y+height)), color ); + drawNode->drawLine( Vec2((x+width), (y+height)), Vec2(x, (y+height)), color ); + drawNode->drawLine( Vec2(x, (y+height)), Vec2(x, y), color ); } - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + map->addChild(drawNode); } std::string TMXOrthoObjectsTest::title() const @@ -832,46 +810,26 @@ TMXIsoObjectsTest::TMXIsoObjectsTest() Value objectsVal = Value(objects); CCLOG("%s", objectsVal.getDescription().c_str()); -} - -void TMXIsoObjectsTest::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _renderCmd.init(_globalZOrder); - _renderCmd.func = CC_CALLBACK_0(TMXIsoObjectsTest::onDraw, this, transform, flags); - renderer->addCommand(&_renderCmd); -} - -void TMXIsoObjectsTest::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - - auto map = (TMXTiledMap*) getChildByTag(kTagTileMap); - auto pos = map->getPosition(); - auto group = map->getObjectGroup("Object Group 1"); - - auto& objects = group->getObjects(); + + auto drawNode = DrawNode::create(); + for (auto& obj : objects) { ValueMap& dict = obj.asValueMap(); + float x = dict["x"].asFloat(); float y = dict["y"].asFloat(); float width = dict["width"].asFloat(); float height = dict["height"].asFloat(); - glLineWidth(3); + Color4F color(1.0, 1.0, 1.0, 1.0); - DrawPrimitives::drawLine( pos + Vec2(x,y), pos + Vec2(x+width,y) ); - DrawPrimitives::drawLine( pos + Vec2(x+width,y), pos + Vec2(x+width,y+height) ); - DrawPrimitives::drawLine( pos + Vec2(x+width,y+height), pos + Vec2(x,y+height) ); - DrawPrimitives::drawLine( pos + Vec2(x,y+height), pos + Vec2(x,y) ); - - glLineWidth(1); + drawNode->drawLine( Vec2(x, y), Vec2((x+width), y), color ); + drawNode->drawLine( Vec2((x+width), y), Vec2((x+width), (y+height)), color ); + drawNode->drawLine( Vec2((x+width), (y+height)), Vec2(x, (y+height)), color ); + drawNode->drawLine( Vec2(x, (y+height)), Vec2(x, y), color ); } - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + map->addChild(drawNode, 10); } std::string TMXIsoObjectsTest::title() const @@ -1519,28 +1477,10 @@ TMXGIDObjectsTest::TMXGIDObjectsTest() CCLOG("Contentsize: %f, %f", s.width, s.height); CCLOG("----> Iterating over all the group objets"); - //auto group = map->objectGroupNamed("Object Layer 1"); - -} - -void TMXGIDObjectsTest::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _renderCmd.init(_globalZOrder); - _renderCmd.func = CC_CALLBACK_0(TMXGIDObjectsTest::onDraw, this, transform, flags); - renderer->addCommand(&_renderCmd); -} - -void TMXGIDObjectsTest::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - - auto map = (TMXTiledMap*)getChildByTag(kTagTileMap); - auto pos = map->getPosition(); - auto group = map->getObjectGroup("Object Layer 1"); + auto drawNode = DrawNode::create(); + Color4F color(1.0, 1.0, 1.0, 1.0); + auto group = map->getObjectGroup("Object Layer 1"); auto& objects = group->getObjects(); for (auto& obj : objects) { @@ -1551,17 +1491,12 @@ void TMXGIDObjectsTest::onDraw(const Mat4 &transform, uint32_t flags) float width = dict["width"].asFloat(); float height = dict["height"].asFloat(); - glLineWidth(3); - - DrawPrimitives::drawLine(pos + Vec2(x, y), pos + Vec2(x + width, y)); - DrawPrimitives::drawLine(pos + Vec2(x + width, y), pos + Vec2(x + width, y + height)); - DrawPrimitives::drawLine(pos + Vec2(x + width,y + height), pos + Vec2(x,y + height)); - DrawPrimitives::drawLine(pos + Vec2(x,y + height), pos + Vec2(x,y)); - - glLineWidth(1); + drawNode->drawLine(Vec2(x, y), Vec2(x + width, y), color); + drawNode->drawLine(Vec2(x + width, y), Vec2(x + width, y + height), color); + drawNode->drawLine(Vec2(x + width,y + height), Vec2(x,y + height), color); + drawNode->drawLine(Vec2(x,y + height), Vec2(x,y), color); } - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + map->addChild(drawNode); } std::string TMXGIDObjectsTest::title() const diff --git a/tests/cpp-tests/Classes/TileMapTest/TileMapTest.h b/tests/cpp-tests/Classes/TileMapTest/TileMapTest.h index d2621fdd07..38d915305b 100644 --- a/tests/cpp-tests/Classes/TileMapTest/TileMapTest.h +++ b/tests/cpp-tests/Classes/TileMapTest/TileMapTest.h @@ -134,11 +134,7 @@ public: TMXOrthoObjectsTest(void); virtual std::string title() const override; - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual std::string subtitle() const override; -protected: - CustomCommand _renderCmd; - void onDraw(const Mat4 &transform, uint32_t flags); }; class TMXIsoObjectsTest : public TileDemo @@ -147,11 +143,7 @@ public: TMXIsoObjectsTest(void); virtual std::string title() const override; - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual std::string subtitle() const override; -protected: - CustomCommand _renderCmd; - void onDraw(const Mat4 &transform, uint32_t flags); }; class TMXResizeTest : public TileDemo @@ -291,13 +283,7 @@ class TMXGIDObjectsTest : public TileDemo public: TMXGIDObjectsTest(); virtual std::string title() const override; - virtual std::string subtitle() const override; - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; - -protected: - CustomCommand _renderCmd; - void onDraw(const Mat4 &transform, uint32_t flags); - + virtual std::string subtitle() const override; }; class TileMapTestScene : public TestScene diff --git a/tests/cpp-tests/Classes/TileMapTest/TileMapTest2.cpp b/tests/cpp-tests/Classes/TileMapTest/TileMapTest2.cpp index 7208449203..92bce7febd 100644 --- a/tests/cpp-tests/Classes/TileMapTest/TileMapTest2.cpp +++ b/tests/cpp-tests/Classes/TileMapTest/TileMapTest2.cpp @@ -728,28 +728,9 @@ TMXOrthoObjectsTestNew::TMXOrthoObjectsTestNew() Value objectsVal = Value(objects); CCLOG("%s", objectsVal.getDescription().c_str()); -} - -void TMXOrthoObjectsTestNew::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _renderCmd.init(_globalZOrder); - _renderCmd.func = CC_CALLBACK_0(TMXOrthoObjectsTestNew::onDraw, this, transform, flags); - renderer->addCommand(&_renderCmd); -} - -void TMXOrthoObjectsTestNew::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - auto map = static_cast( getChildByTag(kTagTileMap) ); - auto pos = map->getPosition(); - auto group = map->getObjectGroup("Object Group 1"); - - auto& objects = group->getObjects(); - + auto drawNode = DrawNode::create(); + Color4F color(1.0, 1.0, 1.0, 1.0); for (auto& obj : objects) { ValueMap& dict = obj.asValueMap(); @@ -759,17 +740,12 @@ void TMXOrthoObjectsTestNew::onDraw(const Mat4 &transform, uint32_t flags) float width = dict["width"].asFloat(); float height = dict["height"].asFloat(); - glLineWidth(3); - - DrawPrimitives::drawLine( pos + Vec2(x, y), pos + Vec2((x+width), y) ); - DrawPrimitives::drawLine( pos + Vec2((x+width), y), pos + Vec2((x+width), (y+height)) ); - DrawPrimitives::drawLine( pos + Vec2((x+width), (y+height)), pos + Vec2(x, (y+height)) ); - DrawPrimitives::drawLine( pos + Vec2(x, (y+height)), pos + Vec2(x, y) ); - - glLineWidth(1); + drawNode->drawLine(Vec2(x, y), Vec2(x + width, y), color); + drawNode->drawLine(Vec2(x + width, y), Vec2(x + width, y + height), color); + drawNode->drawLine(Vec2(x + width,y + height), Vec2(x,y + height), color); + drawNode->drawLine(Vec2(x,y + height), Vec2(x,y), color); } - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + map->addChild(drawNode); } std::string TMXOrthoObjectsTestNew::title() const @@ -803,46 +779,24 @@ TMXIsoObjectsTestNew::TMXIsoObjectsTestNew() Value objectsVal = Value(objects); CCLOG("%s", objectsVal.getDescription().c_str()); -} - -void TMXIsoObjectsTestNew::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _renderCmd.init(_globalZOrder); - _renderCmd.func = CC_CALLBACK_0(TMXIsoObjectsTestNew::onDraw, this, transform, flags); - renderer->addCommand(&_renderCmd); -} - -void TMXIsoObjectsTestNew::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - - auto map = (cocos2d::experimental::TMXTiledMap*) getChildByTag(kTagTileMap); - auto pos = map->getPosition(); - auto group = map->getObjectGroup("Object Group 1"); - - auto& objects = group->getObjects(); + + auto drawNode = DrawNode::create(); + Color4F color(1.0, 1.0, 1.0, 1.0); for (auto& obj : objects) { ValueMap& dict = obj.asValueMap(); + float x = dict["x"].asFloat(); float y = dict["y"].asFloat(); float width = dict["width"].asFloat(); float height = dict["height"].asFloat(); - glLineWidth(3); - - DrawPrimitives::drawLine( pos + Vec2(x,y), pos + Vec2(x+width,y) ); - DrawPrimitives::drawLine( pos + Vec2(x+width,y), pos + Vec2(x+width,y+height) ); - DrawPrimitives::drawLine( pos + Vec2(x+width,y+height), pos + Vec2(x,y+height) ); - DrawPrimitives::drawLine( pos + Vec2(x,y+height), pos + Vec2(x,y) ); - - glLineWidth(1); + drawNode->drawLine(Vec2(x, y), Vec2(x + width, y), color); + drawNode->drawLine(Vec2(x + width, y), Vec2(x + width, y + height), color); + drawNode->drawLine(Vec2(x + width,y + height), Vec2(x,y + height), color); + drawNode->drawLine(Vec2(x,y + height), Vec2(x,y), color); } - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + map->addChild(drawNode, 10); } std::string TMXIsoObjectsTestNew::title() const @@ -1460,29 +1414,11 @@ TMXGIDObjectsTestNew::TMXGIDObjectsTestNew() CCLOG("Contentsize: %f, %f", s.width, s.height); CCLOG("----> Iterating over all the group objets"); - //auto group = map->objectGroupNamed("Object Layer 1"); - -} - -void TMXGIDObjectsTestNew::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) -{ - _renderCmd.init(_globalZOrder); - _renderCmd.func = CC_CALLBACK_0(TMXGIDObjectsTestNew::onDraw, this, transform, flags); - renderer->addCommand(&_renderCmd); -} - -void TMXGIDObjectsTestNew::onDraw(const Mat4 &transform, uint32_t flags) -{ - Director* director = Director::getInstance(); - CCASSERT(nullptr != director, "Director is null when seting matrix stack"); - director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); - director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, transform); - - auto map = (cocos2d::experimental::TMXTiledMap*)getChildByTag(kTagTileMap); - auto pos = map->getPosition(); - auto group = map->getObjectGroup("Object Layer 1"); - auto& objects = group->getObjects(); + auto drawNode = DrawNode::create(); + Color4F color(1.0, 1.0, 1.0, 1.0); + auto group = map->getObjectGroup("Object Layer 1"); + auto objects = group->getObjects(); for (auto& obj : objects) { ValueMap& dict = obj.asValueMap(); @@ -1492,17 +1428,12 @@ void TMXGIDObjectsTestNew::onDraw(const Mat4 &transform, uint32_t flags) float width = dict["width"].asFloat(); float height = dict["height"].asFloat(); - glLineWidth(3); - - DrawPrimitives::drawLine(pos + Vec2(x, y), pos + Vec2(x + width, y)); - DrawPrimitives::drawLine(pos + Vec2(x + width, y), pos + Vec2(x + width, y + height)); - DrawPrimitives::drawLine(pos + Vec2(x + width,y + height), pos + Vec2(x,y + height)); - DrawPrimitives::drawLine(pos + Vec2(x,y + height), pos + Vec2(x,y)); - - glLineWidth(1); + drawNode->drawLine(Vec2(x, y), Vec2(x + width, y), color); + drawNode->drawLine(Vec2(x + width, y), Vec2(x + width, y + height), color); + drawNode->drawLine(Vec2(x + width,y + height), Vec2(x,y + height), color); + drawNode->drawLine(Vec2(x,y + height), Vec2(x,y), color); } - - director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW); + map->addChild(drawNode, 10); } std::string TMXGIDObjectsTestNew::title() const diff --git a/tests/cpp-tests/Classes/TileMapTest/TileMapTest2.h b/tests/cpp-tests/Classes/TileMapTest/TileMapTest2.h index 1f7a98a3e9..15ad4c5060 100644 --- a/tests/cpp-tests/Classes/TileMapTest/TileMapTest2.h +++ b/tests/cpp-tests/Classes/TileMapTest/TileMapTest2.h @@ -134,11 +134,7 @@ public: TMXOrthoObjectsTestNew(void); virtual std::string title() const override; - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual std::string subtitle() const override; -protected: - CustomCommand _renderCmd; - void onDraw(const Mat4 &transform, uint32_t flags); }; class TMXIsoObjectsTestNew : public TileDemoNew @@ -147,11 +143,7 @@ public: TMXIsoObjectsTestNew(void); virtual std::string title() const override; - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; virtual std::string subtitle() const override; -protected: - CustomCommand _renderCmd; - void onDraw(const Mat4 &transform, uint32_t flags); }; class TMXResizeTestNew : public TileDemoNew @@ -291,13 +283,7 @@ class TMXGIDObjectsTestNew : public TileDemoNew public: TMXGIDObjectsTestNew(); virtual std::string title() const override; - virtual std::string subtitle() const override; - virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override; - -protected: - CustomCommand _renderCmd; - void onDraw(const Mat4 &transform, uint32_t flags); - + virtual std::string subtitle() const override; }; class TileMapTestSceneNew : public TestScene diff --git a/tests/lua-tests/src/ActionsTest/ActionsTest.lua b/tests/lua-tests/src/ActionsTest/ActionsTest.lua index 64ad791a10..633fc14cd1 100644 --- a/tests/lua-tests/src/ActionsTest/ActionsTest.lua +++ b/tests/lua-tests/src/ActionsTest/ActionsTest.lua @@ -311,27 +311,17 @@ local function ActionCardinalSpline() kathia:setPosition(cc.p(size.width / 2, 50)) kathia:runAction(seq2) ---[[ - local function drawCardinalSpline() - kmGLPushMatrix() - kmGLTranslatef(50, 50, 0) - cc.DrawPrimitives.drawCardinalSpline(array, 0, 100) - kmGLPopMatrix() + + local drawNode1 = cc.DrawNode:create() + drawNode1:setPosition(50, 50) + drawNode1:drawCardinalSpline(array, 0, 100, cc.c4f(0,0,1,1)) + layer:addChild(drawNode1) + + local drawNode2 = cc.DrawNode:create() + drawNode2:setPosition(size.width/2, 50) + drawNode2:drawCardinalSpline(array, 1, 100, cc.c4f(0,0,1,1)) + layer:addChild(drawNode2) - kmGLPushMatrix() - kmGLTranslatef(size.width / 2, 50, 0) - cc.DrawPrimitives.drawCardinalSpline(array, 1, 100) - kmGLPopMatrix() - end - - array:retain() - local glNode = gl.glNodeCreate() - glNode:setContentSize(cc.size(size.width, size.height)) - glNode:setAnchorPoint(cc.p(0.5, 0.5)) - glNode:registerScriptDrawHandler(drawCardinalSpline) - layer:addChild(glNode,-10) - glNode:setPosition( size.width / 2, size.height / 2) -]]-- Helper.titleLabel:setString("CardinalSplineBy / CardinalSplineAt") Helper.subtitleLabel:setString("Cardinal Spline paths.\nTesting different tensions for one array") return layer @@ -374,25 +364,15 @@ local function ActionCatmullRom() local reverse2 = action2:reverse() local seq2 = cc.Sequence:create(action2, reverse2) kathia:runAction(seq2) ---[[ - local function drawCatmullRom() - kmGLPushMatrix() - kmGLTranslatef(50, 50, 0) - cc.DrawPrimitives.drawCatmullRom(array, 50) - kmGLPopMatrix() - - cc.DrawPrimitives.drawCatmullRom(array2,50) - end - - array:retain() - array2:retain() - local glNode = gl.glNodeCreate() - glNode:setContentSize(cc.size(size.width, size.height)) - glNode:setAnchorPoint(cc.p(0.5, 0.5)) - glNode:registerScriptDrawHandler(drawCatmullRom) - layer:addChild(glNode,-10) - glNode:setPosition( size.width / 2, size.height / 2) - ]]-- + local drawNode1 = cc.DrawNode:create() + drawNode1:setPosition(50, 50) + drawNode1:drawCatmullRom(array, 50, cc.c4f(0,0,1,1)) + layer:addChild(drawNode1) + + local drawNode2 = cc.DrawNode:create() + --drawNode2:setPosition(size.width/2, 50) + drawNode2:drawCatmullRom(array2, 50, cc.c4f(0,0,1,1)) + layer:addChild(drawNode2) Helper.titleLabel:setString("CatmullRomBy / CatmullRomTo") Helper.subtitleLabel:setString("Catmull Rom spline paths. Testing reverse too") @@ -965,21 +945,14 @@ local function ActionFollow() grossini:runAction(rep) layer:runAction(cc.Follow:create(grossini, cc.rect(0, 0, size.width * 2 - 100, size.height))) - - local function draw() - local winSize = cc.Director:getInstance():getWinSize() - local x = winSize.width * 2 - 100 - local y = winSize.height - local vertices = { cc.p(5, 5), cc.p(x - 5, 5), cc.p(x - 5,y - 5), cc.p(5,y - 5) } - cc.DrawPrimitives.drawPoly(vertices, 4, true) - end - - local glNode = gl.glNodeCreate() - glNode:setContentSize(cc.size(size.width, size.height)) - glNode:setAnchorPoint(cc.p(0.5, 0.5)) - glNode:registerScriptDrawHandler(draw) - layer:addChild(glNode,-10) - glNode:setPosition( size.width / 2, size.height / 2) + + local drawNode = cc.DrawNode:create() + local winSize = cc.Director:getInstance():getWinSize() + local x = winSize.width * 2 - 100 + local y = winSize.height + local vertices = { cc.p(5, 5), cc.p(x - 5, 5), cc.p(x - 5,y - 5), cc.p(5,y - 5) } + drawNode:drawPoly(vertices, 4, true, cc.c4f(0,0,1,1)) + layer:addChild(drawNode) Helper.subtitleLabel:setString("Follow action") return layer diff --git a/tests/lua-tests/src/DrawPrimitivesTest/DrawPrimitivesTest.lua b/tests/lua-tests/src/DrawPrimitivesTest/DrawPrimitivesTest.lua index fd23694ea2..202812b294 100644 --- a/tests/lua-tests/src/DrawPrimitivesTest/DrawPrimitivesTest.lua +++ b/tests/lua-tests/src/DrawPrimitivesTest/DrawPrimitivesTest.lua @@ -175,9 +175,69 @@ local function drawPrimitivesMainLayer() local draw = cc.DrawNode:create() layer:addChild(draw, 10) + --draw 1 point + draw:drawPoint(cc.p(60,60), 4, cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 1)) + + --draw 4 small points + local fourpoints = { cc.p(60,60), cc.p(70,70), cc.p(60,70), cc.p(70,60) } + draw:drawPoints(fourpoints, 4, cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 1)) + + --draw a line + draw:drawLine(cc.p(0,0), cc.p(size.width, size.height), cc.c4f(0,1,0,1)) + + --draw a rectangle + draw:drawRect(cc.p(23,23), cc.p(7,7), cc.c4f(1,1,0,1)) + + --draw a solid polygon + local vertices3 = { cc.p(60,160), cc.p(70,190), cc.p(100,190), cc.p(90,160) } + draw:drawSolidPoly( vertices3, 4, cc.c4f(0,0,1,1) ) + + --draw a solid rectangle + draw:drawSolidRect(cc.p(10,10), cc.p(20,20), cc.c4f(1,1,0,1)) + + --draw a solid circle + draw:drawSolidCircle(cc.p(VisibleRect:center().x + 140 ,VisibleRect:center().y), 100, math.pi/2, 50, 1.0, 2.0, cc.c4f(1,0,0,0.2)) + + --draw open random color poly + local vertices = { cc.p(0,0), cc.p(50,50), cc.p(100,50), cc.p(100,100), cc.p(50,100) } + draw:drawPoly( vertices, 5, false, cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 1)) + + --draw closed random color poly + local vertices2 = { cc.p(30,130), cc.p(30,230), cc.p(50,200) } + draw:drawPoly( vertices2, 3, true, cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 1)) + + --draw two circle + draw:drawCircle(cc.p(VisibleRect:center().x + 140 ,VisibleRect:center().y), 110, math.pi/2, 50, true, 1.0, 2.0, cc.c4f(1.0, 0.0, 0.0, 0.5)) + + draw:drawCircle(cc.p(VisibleRect:center().x - 140 ,VisibleRect:center().y), 50, math.pi/2, 30, false, cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 1)) + + --draw some beziers + draw:drawQuadBezier(cc.p(size.width - 150, size.height - 150), cc.p(size.width - 70, size.height - 10), cc.p(size.width - 10, size.height - 10), 10, cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 0.5)) + + draw:drawQuadBezier(cc.p(0, size.height), cc.p(size.width/2, size.height/2), cc.p(size.width, size.height), 50, cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 0.5)) + + draw:drawCubicBezier(cc.p(VisibleRect:center()), cc.p(VisibleRect:center().x+30,VisibleRect:center().y+50), cc.p(VisibleRect:center().x+60,VisibleRect:center().y-50),VisibleRect:right(),100, cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 0.5)) + + --draw Cardinal spline and catmullrom + local array = { + cc.p(0, 0), + cc.p(size.width / 2 - 30, 0), + cc.p(size.width / 2 - 30, size.height - 80), + cc.p(0, size.height - 80), + cc.p(0, 0) } + draw:drawCardinalSpline(array, 0.5, 50, cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 0.5)) + + local array2 = { + cc.p(size.width / 2, 30), + cc.p(size.width - 80, 30), + cc.p(size.width - 80, size.height - 80), + cc.p(size.width / 2, size.height - 80), + cc.p(size.width / 2, 30) } + draw:drawCatmullRom(array2, 50, cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 0.5)) + --Draw 10 circles for i=1, 10 do - draw:drawDot(cc.p(size.width/2, size.height/2), 10*(10-i), cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 1)) + draw:drawDot(cc.p(size.width/2, size.height/2), 10*(10-i), cc.c4f(math.random(0,1), math.random(0,1), math.random(0,1), 0.5)) end --Draw polygons diff --git a/tests/lua-tests/src/FastTiledMapTest/FastTiledMapTest.lua b/tests/lua-tests/src/FastTiledMapTest/FastTiledMapTest.lua index 87c001f3e7..7aa6d17a1d 100644 --- a/tests/lua-tests/src/FastTiledMapTest/FastTiledMapTest.lua +++ b/tests/lua-tests/src/FastTiledMapTest/FastTiledMapTest.lua @@ -542,6 +542,9 @@ local function TMXOrthoObjectsTest() local s = map:getContentSize() cclog("ContentSize: %f, %f", s.width,s.height) + + local drawNode = cc.DrawNode:create() + map:addChild(drawNode, 10) --------cclog("---: Iterating over all the group objets") local group = map:getObjectGroup("Object Group 1") @@ -558,30 +561,7 @@ local function TMXOrthoObjectsTest() break end --------cclog("object: %x", dict) - end - - --------cclog("---: Fetching 1 object by name") - -- local platform = group:objectNamed("platform") - --------cclog("platform: %x", platform) - return ret -end - -local function draw() - - local map = tolua.cast(getChildByTag(kTagTileMap), "cc.TMXTiledMap") - local group = map:getObjectGroup("Object Group 1") - - local objects = group:getObjects() - local dict = nil - local i = 0 - local len = table.getn(objects) - for i = 0, len-1, 1 do - dict = objects[i + 1] - - if dict == nil then - break - end - + local key = "x" local x = dict["x"] key = "y" @@ -590,16 +570,21 @@ local function draw() local width = dict["width"]--dynamic_cast(dict:objectForKey("width")):getNumber() key = "height" local height = dict["height"]--dynamic_cast(dict:objectForKey("height")):getNumber() - - glLineWidth(3) - - cc.DrawPrimitives.drawLine( cc.p(x, y), cc.p((x+width), y) ) - cc.DrawPrimitives.drawLine( cc.p((x+width), y), cc.p((x+width), (y+height)) ) - cc.DrawPrimitives.drawLine( cc.p((x+width), (y+height)), cc.p(x, (y+height)) ) - cc.DrawPrimitives.drawLine( cc.p(x, (y+height)), cc.p(x, y) ) - - glLineWidth(1) + + local color = cc.c4f(1,1,1,1) + drawNode:drawLine( cc.p(x, y), cc.p((x+width), y), color) + drawNode:drawLine( cc.p((x+width), y), cc.p((x+width), (y+height)), color) + drawNode:drawLine( cc.p((x+width), (y+height)), cc.p(x, (y+height)), color) + drawNode:drawLine( cc.p(x, (y+height)), cc.p(x, y), color) end + + --------cclog("---: Fetching 1 object by name") + -- local platform = group:objectNamed("platform") + --------cclog("platform: %x", platform) + + + + return ret end -------------------------------------------------------------------- @@ -615,6 +600,9 @@ local function TMXIsoObjectsTest() local s = map:getContentSize() cclog("ContentSize: %f, %f", s.width,s.height) + + local drawNode = cc.DrawNode:create() + map:addChild(drawNode, 10) local group = map:getObjectGroup("Object Group 1") @@ -624,51 +612,30 @@ local function TMXIsoObjectsTest() local dict = nil local i = 0 local len = table.getn(objects) - for i = 0, len-1, 1 do - -- dict = tolua.cast(objects[i + 1], "cc.Dictionary") - - -- if dict == nil then - -- break - -- end - --------cclog("object: %x", dict) - end - return ret -end - -local function draw() - - local map = tolua.cast(getChildByTag(kTagTileMap), "cc.TMXTiledMap") - local group = map:getObjectGroup("Object Group 1") - - local objects = group:getObjects() - local dict = nil - local i = 0 - local len = table.getn(objects) for i = 0, len-1, 1 do dict = tolua.cast(objects[i + 1], "cc.Dictionary") if dict == nil then break end - + --------cclog("object: %x", dict) + local key = "x" - local x = (tolua.cast(dict:objectForKey(key), "cc.String")):intValue()--dynamic_cast(dict:objectForKey("x")):getNumber() + local x = dict["x"] key = "y" - local y = (tolua.cast(dict:objectForKey(key), "cc.String")):intValue()--dynamic_cast(dict:objectForKey("y")):getNumber() + local y = dict["y"]--dynamic_cast(dict:objectForKey("y")):getNumber() key = "width" - local width = (tolua.cast(dict:objectForKey(key), "cc.String")):intValue()--dynamic_cast(dict:objectForKey("width")):getNumber() + local width = dict["width"]--dynamic_cast(dict:objectForKey("width")):getNumber() key = "height" - local height = (tolua.cast(dict:objectForKey(key), "cc.String")):intValue()--dynamic_cast(dict:objectForKey("height")):getNumber() - - glLineWidth(3) - - cc.DrawPrimitives.drawLine( cc.p(x,y), cc.p(x+width,y) ) - cc.DrawPrimitives.drawLine( cc.p(x+width,y), cc.p(x+width,y+height) ) - cc.DrawPrimitives.drawLine( cc.p(x+width,y+height), cc.p(x,y+height) ) - cc.DrawPrimitives.drawLine( cc.p(x,y+height), cc.p(x,y) ) - - glLineWidth(1) + local height = dict["height"]--dynamic_cast(dict:objectForKey("height")):getNumber() + + local color = cc.c4f(1,1,1,1) + drawNode:drawLine( cc.p(x, y), cc.p((x+width), y), color) + drawNode:drawLine( cc.p((x+width), y), cc.p((x+width), (y+height)), color) + drawNode:drawLine( cc.p((x+width), (y+height)), cc.p(x, (y+height)), color) + drawNode:drawLine( cc.p(x, (y+height)), cc.p(x, y), color) end + return ret end -------------------------------------------------------------------- diff --git a/tests/lua-tests/src/LabelTest/LabelTest.lua b/tests/lua-tests/src/LabelTest/LabelTest.lua index adfeb0a3eb..21b248313a 100644 --- a/tests/lua-tests/src/LabelTest/LabelTest.lua +++ b/tests/lua-tests/src/LabelTest/LabelTest.lua @@ -263,13 +263,18 @@ function Atlas4.create() local layer = cc.Layer:create() Helper.initWithLayer(layer) Atlas4.layer = layer + + local s = cc.Director:getInstance():getWinSize() + + local drawNode = cc.DrawNode:create() + drawNode:drawLine( cc.p(0, s.height/2), cc.p(s.width, s.height/2), cc.c4f(1,1,1,1)) + drawNode:drawLine( cc.p(s.width/2, 0), cc.p(s.width/2, s.height), cc.c4f(1,1,1,1)) + layer:addChild(drawNode, -10) -- Upper Label local label = cc.LabelBMFont:create("Bitmap Font Atlas", "fonts/bitmapFontTest.fnt") layer:addChild(label) - local s = cc.Director:getInstance():getWinSize() - label:setPosition( cc.p(s.width/2, s.height/2) ) label:setAnchorPoint( cc.p(0.5, 0.5) ) @@ -311,19 +316,11 @@ function Atlas4.create() local lastChar = label2:getChildByTag(3) lastChar:runAction(rot_4ever:clone()) - layer:registerScriptHandler(Atlas4.onNodeEvent) - Helper.titleLabel:setString("LabelBMFont") Helper.subtitleLabel:setString( "Using fonts as cc.Sprite objects. Some characters should rotate.") return layer end -function Atlas4.draw() - local s = cc.Director:getInstance():getWinSize() - cc.DrawPrimitives.drawLine( cc.p(0, s.height/2), cc.p(s.width, s.height/2) ) - cc.DrawPrimitives.drawLine( cc.p(s.width/2, 0), cc.p(s.width/2, s.height) ) -end - function Atlas4.step(dt) m_time = m_time + dt diff --git a/tests/lua-tests/src/LabelTestNew/LabelTestNew.lua b/tests/lua-tests/src/LabelTestNew/LabelTestNew.lua index 9e9b2b5f9f..71e084361e 100644 --- a/tests/lua-tests/src/LabelTestNew/LabelTestNew.lua +++ b/tests/lua-tests/src/LabelTestNew/LabelTestNew.lua @@ -119,12 +119,18 @@ function LabelFNTSpriteActions.create() local layer = cc.Layer:create() Helper.initWithLayer(layer) LabelFNTSpriteActions.layer = layer + + local s = cc.Director:getInstance():getWinSize() + + local drawNode = cc.DrawNode:create() + drawNode:drawLine( cc.p(0, s.height/2), cc.p(s.width, s.height/2), cc.c4f(1,1,1,1)) + drawNode:drawLine( cc.p(s.width/2, 0), cc.p(s.width/2, s.height), cc.c4f(1,1,1,1)) + layer:addChild(drawNode, -10) -- Upper Label local label = cc.Label:createWithBMFont("fonts/bitmapFontTest.fnt", "Bitmap Font Atlas") layer:addChild(label) - local s = cc.Director:getInstance():getWinSize() label:setPosition( cc.p(s.width/2, s.height/2) ) label:setAnchorPoint( cc.p(0.5, 0.5) ) @@ -174,12 +180,6 @@ function LabelFNTSpriteActions.create() return layer end -function LabelFNTSpriteActions.draw() - local s = cc.Director:getInstance():getWinSize() - cc.DrawPrimitives.drawLine( cc.p(0, s.height/2), cc.p(s.width, s.height/2) ) - cc.DrawPrimitives.drawLine( cc.p(s.width/2, 0), cc.p(s.width/2, s.height) ) -end - function LabelFNTSpriteActions.step(dt) m_time = m_time + dt @@ -1652,6 +1652,21 @@ function LabelTTFOldNew.create() label1:setPosition(cc.p(s.width/2, delta * 2)) label1:setColor(cc.c3b(255, 0, 0)) + local labelSize = label1:getContentSize() + local origin = cc.Director:getInstance():getWinSize() + origin.width = origin.width / 2 - (labelSize.width / 2) + origin.height = origin.height / 2 - (labelSize.height / 2) + local vertices = + { + cc.p(origin.width, origin.height), + cc.p(labelSize.width + origin.width, origin.height), + cc.p(labelSize.width + origin.width, labelSize.height + origin.height), + cc.p(origin.width, labelSize.height + origin.height), + } + local drawNode = cc.DrawNode:create() + drawNode:drawPoly(vertices, 4, true, cc.c4f(1,0,0,1)) + layer:addChild(drawNode) + local ttfConfig = {} ttfConfig.fontFilePath = "fonts/arial.ttf" ttfConfig.fontSize = 24 @@ -1659,54 +1674,20 @@ function LabelTTFOldNew.create() layer:addChild(label2, 0, kTagBitmapAtlas2) label2:setPosition(cc.p(s.width/2, delta * 2)) - local function onDraw(transform, transformUpdated) - kmGLPushMatrix() - kmGLLoadMatrix(transform) - - local label1 = layer:getChildByTag(kTagBitmapAtlas1) - local labelSize = label1:getContentSize() - local origin = cc.Director:getInstance():getWinSize() - - origin.width = origin.width / 2 - (labelSize.width / 2) - origin.height = origin.height / 2 - (labelSize.height / 2) - - local vertices = - { - cc.p(origin.width, origin.height), - cc.p(labelSize.width + origin.width, origin.height), - cc.p(labelSize.width + origin.width, labelSize.height + origin.height), - cc.p(origin.width, labelSize.height + origin.height), - } - - cc.DrawPrimitives.drawColor4B(255, 0, 0, 255) - cc.DrawPrimitives.drawPoly(vertices, 4, true) - - local label2 = layer:getChildByTag(kTagBitmapAtlas2) - labelSize = label2:getContentSize() - origin = cc.Director:getInstance():getWinSize() - - origin.width = origin.width / 2 - (labelSize.width / 2) - origin.height = origin.height / 2 - (labelSize.height / 2) - - local vertices2 = - { - cc.p(origin.width, origin.height), - cc.p(labelSize.width + origin.width, origin.height), - cc.p(labelSize.width + origin.width, labelSize.height + origin.height), - cc.p(origin.width, labelSize.height + origin.height), - } - cc.DrawPrimitives.drawColor4B(255, 255, 255, 255) - cc.DrawPrimitives.drawPoly(vertices2, 4, true) - - kmGLPopMatrix() - end - - local glNode = gl.glNodeCreate() - glNode:setContentSize(cc.size(s.width, s.height)) - glNode:setAnchorPoint(cc.p(0.5, 0.5)) - glNode:setPosition( s.width / 2, s.height / 2) - glNode:registerScriptDrawHandler(onDraw) - layer:addChild(glNode,-10) + labelSize = label2:getContentSize() + origin = cc.Director:getInstance():getWinSize() + origin.width = origin.width / 2 - (labelSize.width / 2) + origin.height = origin.height / 2 - (labelSize.height / 2) + local vertices2 = + { + cc.p(origin.width, origin.height), + cc.p(labelSize.width + origin.width, origin.height), + cc.p(labelSize.width + origin.width, labelSize.height + origin.height), + cc.p(origin.width, labelSize.height + origin.height), + } + local drawNode2 = cc.DrawNode:create() + drawNode2:drawPoly(vertices2, 4, true, cc.c4f(1,1,1,1)) + layer:addChild(drawNode2) return layer end diff --git a/tests/lua-tests/src/TileMapTest/TileMapTest.lua b/tests/lua-tests/src/TileMapTest/TileMapTest.lua index 54c138e87c..ba6510e3cc 100644 --- a/tests/lua-tests/src/TileMapTest/TileMapTest.lua +++ b/tests/lua-tests/src/TileMapTest/TileMapTest.lua @@ -625,6 +625,9 @@ local function TMXOrthoObjectsTest() local s = map:getContentSize() cclog("ContentSize: %f, %f", s.width,s.height) + + local drawNode = cc.DrawNode:create() + map:addChild(drawNode, 10) --------cclog("---: Iterating over all the group objets") local group = map:getObjectGroup("Object Group 1") @@ -641,30 +644,7 @@ local function TMXOrthoObjectsTest() break end --------cclog("object: %x", dict) - end - - --------cclog("---: Fetching 1 object by name") - -- local platform = group:objectNamed("platform") - --------cclog("platform: %x", platform) - return ret -end - -local function draw() - - local map = tolua.cast(getChildByTag(kTagTileMap), "cc.TMXTiledMap") - local group = map:getObjectGroup("Object Group 1") - - local objects = group:getObjects() - local dict = nil - local i = 0 - local len = table.getn(objects) - for i = 0, len-1, 1 do - dict = objects[i + 1] - - if dict == nil then - break - end - + local key = "x" local x = dict["x"] key = "y" @@ -673,16 +653,19 @@ local function draw() local width = dict["width"]--dynamic_cast(dict:objectForKey("width")):getNumber() key = "height" local height = dict["height"]--dynamic_cast(dict:objectForKey("height")):getNumber() - - glLineWidth(3) - - cc.DrawPrimitives.drawLine( cc.p(x, y), cc.p((x+width), y) ) - cc.DrawPrimitives.drawLine( cc.p((x+width), y), cc.p((x+width), (y+height)) ) - cc.DrawPrimitives.drawLine( cc.p((x+width), (y+height)), cc.p(x, (y+height)) ) - cc.DrawPrimitives.drawLine( cc.p(x, (y+height)), cc.p(x, y) ) - - glLineWidth(1) + + local color = cc.c4f(1,1,1,1) + drawNode:drawLine( cc.p(x, y), cc.p((x+width), y), color) + drawNode:drawLine( cc.p((x+width), y), cc.p((x+width), (y+height)), color) + drawNode:drawLine( cc.p((x+width), (y+height)), cc.p(x, (y+height)), color) + drawNode:drawLine( cc.p(x, (y+height)), cc.p(x, y), color) end + + --------cclog("---: Fetching 1 object by name") + -- local platform = group:objectNamed("platform") + --------cclog("platform: %x", platform) + + return ret end -------------------------------------------------------------------- @@ -701,6 +684,9 @@ local function TMXIsoObjectsTest() local group = map:getObjectGroup("Object Group 1") + local drawNode = cc.DrawNode:create() + map:addChild(drawNode, 10) + --UxMutableArray* objects = group:objects() local objects = group:getObjects() --UxMutableDictionary* dict @@ -714,26 +700,7 @@ local function TMXIsoObjectsTest() break end --------cclog("object: %x", dict) - end - return ret -end - -local function draw() - - local map = tolua.cast(getChildByTag(kTagTileMap), "cc.TMXTiledMap") - local group = map:getObjectGroup("Object Group 1") - - local objects = group:getObjects() - local dict = nil - local i = 0 - local len = table.getn(objects) - for i = 0, len-1, 1 do - dict = tolua.cast(objects[i + 1], "cc.Dictionary") - - if dict == nil then - break - end - + local key = "x" local x = (tolua.cast(dict:objectForKey(key), "cc.String")):intValue()--dynamic_cast(dict:objectForKey("x")):getNumber() key = "y" @@ -742,16 +709,14 @@ local function draw() local width = (tolua.cast(dict:objectForKey(key), "cc.String")):intValue()--dynamic_cast(dict:objectForKey("width")):getNumber() key = "height" local height = (tolua.cast(dict:objectForKey(key), "cc.String")):intValue()--dynamic_cast(dict:objectForKey("height")):getNumber() - - glLineWidth(3) - - cc.DrawPrimitives.drawLine( cc.p(x,y), cc.p(x+width,y) ) - cc.DrawPrimitives.drawLine( cc.p(x+width,y), cc.p(x+width,y+height) ) - cc.DrawPrimitives.drawLine( cc.p(x+width,y+height), cc.p(x,y+height) ) - cc.DrawPrimitives.drawLine( cc.p(x,y+height), cc.p(x,y) ) - - glLineWidth(1) + + local color = cc.c4f(1,1,1,1) + drawNode:drawLine( cc.p(x, y), cc.p((x+width), y), color) + drawNode:drawLine( cc.p((x+width), y), cc.p((x+width), (y+height)), color) + drawNode:drawLine( cc.p((x+width), (y+height)), cc.p(x, (y+height)), color) + drawNode:drawLine( cc.p(x, (y+height)), cc.p(x, y), color) end + return ret end -------------------------------------------------------------------- diff --git a/tools/tolua/cocos2dx.ini b/tools/tolua/cocos2dx.ini index dec87dfd0a..8b92268f28 100644 --- a/tools/tolua/cocos2dx.ini +++ b/tools/tolua/cocos2dx.ini @@ -43,7 +43,7 @@ skip = Node::[setGLServerState description getUserObject .*UserData getGLServerS ParticleBatchNode::[getBlendFunc setBlendFunc], LayerColor::[getBlendFunc setBlendFunc], ParticleSystem::[(g|s)etBlendFunc updateQuadWithParticle initParticle], - DrawNode::[getBlendFunc setBlendFunc drawPolygon listenBackToForeground], + DrawNode::[getBlendFunc setBlendFunc drawPolygon drawSolidPoly drawPoly drawCardinalSpline drawCatmullRom drawPoints listenBackToForeground], Director::[getAccelerometer getProjection getFrustum getRenderer], Layer.*::[didAccelerate (g|s)etBlendFunc keyPressed keyReleased], Menu.*::[.*Target getSubItems create initWithItems alignItemsInRows alignItemsInColumns],