axmol/extensions/spine/v3/SkeletonTwoColorBatch.h

173 lines
5.6 KiB
C
Raw Normal View History

2017-11-02 09:06:13 +08:00
/******************************************************************************
2019-12-12 23:26:12 +08:00
* Spine Runtimes License Agreement
2020-01-05 03:09:32 +08:00
* Last updated January 1, 2020. Replaces all prior versions.
2017-11-02 09:06:13 +08:00
*
2020-01-05 03:09:32 +08:00
* Copyright (c) 2013-2020, Esoteric Software LLC
2017-11-02 09:06:13 +08:00
*
2019-12-12 23:26:12 +08:00
* Integration of the Spine Runtimes into software or otherwise creating
* derivative works of the Spine Runtimes is permitted under the terms and
* conditions of Section 2 of the Spine Editor License Agreement:
* http://esotericsoftware.com/spine-editor-license
2017-11-02 09:06:13 +08:00
*
2019-12-12 23:26:12 +08:00
* Otherwise, it is permitted to integrate the Spine Runtimes into software
* or otherwise create derivative works of the Spine Runtimes (collectively,
* "Products"), provided that each user of the Products must obtain their own
* Spine Editor license and redistribution of the Products in any form must
* include this license and copyright notice.
*
2020-01-05 03:09:32 +08:00
* THE SPINE RUNTIMES ARE PROVIDED BY ESOTERIC SOFTWARE LLC "AS IS" AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL ESOTERIC SOFTWARE LLC BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES,
* BUSINESS INTERRUPTION, OR LOSS OF USE, DATA, OR PROFITS) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THE SPINE RUNTIMES, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2017-11-02 09:06:13 +08:00
*****************************************************************************/
#ifndef SPINE_SKELETONTWOCOLORBATCH_H_
#define SPINE_SKELETONTWOCOLORBATCH_H_
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
#include "cocos2d.h"
2020-01-05 03:09:32 +08:00
#if COCOS2D_VERSION < 0x00040000
#include <spine/spine.h>
2017-11-02 09:06:13 +08:00
#include <vector>
namespace spine {
struct V3F_C4B_C4B_T2F {
cocos2d::Vec3 position;
cocos2d::Color4B color;
cocos2d::Color4B color2;
cocos2d::Tex2F texCoords;
};
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
struct TwoColorTriangles {
V3F_C4B_C4B_T2F* verts;
unsigned short* indices;
int vertCount;
int indexCount;
};
2020-01-05 03:09:32 +08:00
2020-10-17 16:32:16 +08:00
class SP_API TwoColorTrianglesCommand : public cocos2d::CustomCommand {
2017-11-02 09:06:13 +08:00
public:
TwoColorTrianglesCommand();
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
~TwoColorTrianglesCommand();
2019-12-12 23:26:12 +08:00
2020-01-05 03:09:32 +08:00
void init(float globalOrder, GLuint textureID, cocos2d::GLProgramState* glProgramState, cocos2d::BlendFunc blendType, const TwoColorTriangles& triangles, const cocos2d::Mat4& mv, uint32_t flags);
2019-12-12 23:26:12 +08:00
2020-01-05 03:09:32 +08:00
void useMaterial() const;
2019-12-12 23:26:12 +08:00
2020-01-05 03:09:32 +08:00
inline uint32_t getMaterialID() const { return _materialID; }
2019-12-12 23:26:12 +08:00
2020-01-05 03:09:32 +08:00
inline GLuint getTextureID() const { return _textureID; }
2019-12-12 23:26:12 +08:00
2017-11-02 09:06:13 +08:00
inline const TwoColorTriangles& getTriangles() const { return _triangles; }
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
inline ssize_t getVertexCount() const { return _triangles.vertCount; }
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
inline ssize_t getIndexCount() const { return _triangles.indexCount; }
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
inline const V3F_C4B_C4B_T2F* getVertices() const { return _triangles.verts; }
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
inline const unsigned short* getIndices() const { return _triangles.indices; }
2020-01-05 03:09:32 +08:00
inline cocos2d::GLProgramState* getGLProgramState() const { return _glProgramState; }
2017-11-02 09:06:13 +08:00
inline cocos2d::BlendFunc getBlendType() const { return _blendType; }
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
inline const cocos2d::Mat4& getModelView() const { return _mv; }
2020-01-05 03:09:32 +08:00
void draw ();
2017-11-02 09:06:13 +08:00
void setForceFlush (bool forceFlush) { _forceFlush = forceFlush; }
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
bool isForceFlush () { return _forceFlush; };
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
protected:
void generateMaterialID();
uint32_t _materialID;
2020-01-05 03:09:32 +08:00
GLuint _textureID;
cocos2d::GLProgramState* _glProgramState;
cocos2d::GLProgram* _glProgram;
cocos2d::BlendFunc _blendType;
TwoColorTriangles _triangles;
cocos2d::Mat4 _mv;
GLuint _alphaTextureID;
bool _forceFlush;
2017-11-02 09:06:13 +08:00
};
2020-10-17 16:32:16 +08:00
class SP_API SkeletonTwoColorBatch {
2020-01-05 03:09:32 +08:00
public:
static SkeletonTwoColorBatch* getInstance ();
2017-11-02 09:06:13 +08:00
2020-01-05 03:09:32 +08:00
static void destroyInstance ();
2017-11-02 09:06:13 +08:00
2020-01-05 03:09:32 +08:00
void update (float delta);
2017-11-02 09:06:13 +08:00
V3F_C4B_C4B_T2F* allocateVertices(uint32_t numVertices);
void deallocateVertices(uint32_t numVertices);
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
unsigned short* allocateIndices(uint32_t numIndices);
void deallocateIndices(uint32_t numIndices);
2020-01-05 03:09:32 +08:00
TwoColorTrianglesCommand* addCommand(cocos2d::Renderer* renderer, float globalOrder, GLuint textureID, cocos2d::GLProgramState* glProgramState, cocos2d::BlendFunc blendType, const TwoColorTriangles& triangles, const cocos2d::Mat4& mv, uint32_t flags);
cocos2d::GLProgramState* getTwoColorTintProgramState () { return _twoColorTintShaderState; }
2019-12-12 23:26:12 +08:00
2020-01-05 03:09:32 +08:00
void batch (TwoColorTrianglesCommand* command);
2019-12-12 23:26:12 +08:00
2020-01-05 03:09:32 +08:00
void flush (TwoColorTrianglesCommand* materialCommand);
2017-11-02 09:06:13 +08:00
uint32_t getNumBatches () { return _numBatches; };
2020-01-05 03:09:32 +08:00
protected:
SkeletonTwoColorBatch ();
virtual ~SkeletonTwoColorBatch ();
2017-11-02 09:06:13 +08:00
void reset ();
TwoColorTrianglesCommand* nextFreeCommand ();
// pool of commands
std::vector<TwoColorTrianglesCommand*> _commandsPool;
uint32_t _nextFreeCommand;
// pool of vertices
std::vector<V3F_C4B_C4B_T2F> _vertices;
uint32_t _numVertices;
2020-01-05 03:09:32 +08:00
2017-11-02 09:06:13 +08:00
// pool of indices
2019-12-12 23:26:12 +08:00
Vector<unsigned short> _indices;
2020-01-05 03:09:32 +08:00
// two color tint shader and state
cocos2d::GLProgram* _twoColorTintShader;
cocos2d::GLProgramState* _twoColorTintShaderState;
2017-11-02 09:06:13 +08:00
// VBO handles & attribute locations
GLuint _vertexBufferHandle;
V3F_C4B_C4B_T2F* _vertexBuffer;
uint32_t _numVerticesBuffer;
2020-01-05 03:09:32 +08:00
GLuint _indexBufferHandle;
uint32_t _numIndicesBuffer;
unsigned short* _indexBuffer;
GLint _positionAttributeLocation;
GLint _colorAttributeLocation;
GLint _color2AttributeLocation;
GLint _texCoordsAttributeLocation;
2019-12-12 23:26:12 +08:00
2017-11-02 09:06:13 +08:00
// last batched command, needed for flushing to set material
2020-01-05 03:09:32 +08:00
TwoColorTrianglesCommand* _lastCommand;
2019-12-12 23:26:12 +08:00
2017-11-02 09:06:13 +08:00
// number of batches in the last frame
uint32_t _numBatches;
};
}
2020-01-05 03:09:32 +08:00
#endif
2017-11-02 09:06:13 +08:00
#endif // SPINE_SKELETONTWOCOLORBATCH_H_