mirror of https://github.com/axmolengine/axmol.git
Merge branch 'billboard' of https://github.com/super626/cocos2d-x into billboard
This commit is contained in:
commit
6a2f4c635e
|
@ -99,6 +99,32 @@ void RenderQueue::clear()
|
||||||
_queuePosZ.clear();
|
_queuePosZ.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// helper
|
||||||
|
static bool compareTransparentRenderCommand(RenderCommand* a, RenderCommand* b)
|
||||||
|
{
|
||||||
|
return a->getGlobalOrder() > b->getGlobalOrder();
|
||||||
|
}
|
||||||
|
|
||||||
|
void TransparentRenderQueue::push_back(RenderCommand* command)
|
||||||
|
{
|
||||||
|
_queueCmd.push_back(command);
|
||||||
|
}
|
||||||
|
|
||||||
|
void TransparentRenderQueue::sort()
|
||||||
|
{
|
||||||
|
std::sort(std::begin(_queueCmd), std::end(_queueCmd), compareTransparentRenderCommand);
|
||||||
|
}
|
||||||
|
|
||||||
|
RenderCommand* TransparentRenderQueue::operator[](ssize_t index) const
|
||||||
|
{
|
||||||
|
return _queueCmd[index];
|
||||||
|
}
|
||||||
|
|
||||||
|
void TransparentRenderQueue::clear()
|
||||||
|
{
|
||||||
|
_queueCmd.clear();
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
|
@ -256,6 +282,11 @@ void Renderer::addCommand(RenderCommand* command, int renderQueue)
|
||||||
_renderGroups[renderQueue].push_back(command);
|
_renderGroups[renderQueue].push_back(command);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Renderer::addTransparentCommand(RenderCommand* command)
|
||||||
|
{
|
||||||
|
_transparentRenderGroups.push_back(command);
|
||||||
|
}
|
||||||
|
|
||||||
void Renderer::pushGroup(int renderQueueID)
|
void Renderer::pushGroup(int renderQueueID)
|
||||||
{
|
{
|
||||||
CCASSERT(!_isRendering, "Cannot change render queue while rendering");
|
CCASSERT(!_isRendering, "Cannot change render queue while rendering");
|
||||||
|
@ -351,6 +382,56 @@ void Renderer::visitRenderQueue(const RenderQueue& queue)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Renderer::visitTransparentRenderQueue(const TransparentRenderQueue& queue)
|
||||||
|
{
|
||||||
|
// do not batch for transparent objects
|
||||||
|
ssize_t size = queue.size();
|
||||||
|
|
||||||
|
for (ssize_t index = 0; index < size; ++index)
|
||||||
|
{
|
||||||
|
auto command = queue[index];
|
||||||
|
auto commandType = command->getType();
|
||||||
|
if(RenderCommand::Type::QUAD_COMMAND == commandType)
|
||||||
|
{
|
||||||
|
auto cmd = static_cast<QuadCommand*>(command);
|
||||||
|
|
||||||
|
_batchedQuadCommands.push_back(cmd);
|
||||||
|
memcpy(_quads, cmd->getQuads(), sizeof(V3F_C4B_T2F_Quad) * cmd->getQuadCount());
|
||||||
|
convertToWorldCoordinates(_quads, cmd->getQuadCount(), cmd->getModelView());
|
||||||
|
drawBatchedQuads();
|
||||||
|
}
|
||||||
|
else if(RenderCommand::Type::GROUP_COMMAND == commandType)
|
||||||
|
{
|
||||||
|
int renderQueueID = ((GroupCommand*) command)->getRenderQueueID();
|
||||||
|
visitRenderQueue(_renderGroups[renderQueueID]);
|
||||||
|
}
|
||||||
|
else if(RenderCommand::Type::CUSTOM_COMMAND == commandType)
|
||||||
|
{
|
||||||
|
auto cmd = static_cast<CustomCommand*>(command);
|
||||||
|
cmd->execute();
|
||||||
|
}
|
||||||
|
else if(RenderCommand::Type::BATCH_COMMAND == commandType)
|
||||||
|
{
|
||||||
|
auto cmd = static_cast<BatchCommand*>(command);
|
||||||
|
cmd->execute();
|
||||||
|
}
|
||||||
|
else if(RenderCommand::Type::PRIMITIVE_COMMAND == commandType)
|
||||||
|
{
|
||||||
|
auto cmd = static_cast<PrimitiveCommand*>(command);
|
||||||
|
cmd->execute();
|
||||||
|
}
|
||||||
|
else if (RenderCommand::Type::MESH_COMMAND == commandType)
|
||||||
|
{
|
||||||
|
auto cmd = static_cast<MeshCommand*>(command);
|
||||||
|
cmd->execute();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
CCLOGERROR("Unknown commands in renderQueue");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void Renderer::render()
|
void Renderer::render()
|
||||||
{
|
{
|
||||||
//Uncomment this once everything is rendered by new renderer
|
//Uncomment this once everything is rendered by new renderer
|
||||||
|
@ -372,6 +453,14 @@ void Renderer::render()
|
||||||
}
|
}
|
||||||
visitRenderQueue(_renderGroups[0]);
|
visitRenderQueue(_renderGroups[0]);
|
||||||
flush();
|
flush();
|
||||||
|
|
||||||
|
//Process render commands
|
||||||
|
//draw transparent objects here, do not batch for transparent objects
|
||||||
|
if (_transparentRenderGroups.size())
|
||||||
|
{
|
||||||
|
_transparentRenderGroups.sort();
|
||||||
|
visitTransparentRenderQueue(_transparentRenderGroups);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
clean();
|
clean();
|
||||||
_isRendering = false;
|
_isRendering = false;
|
||||||
|
|
|
@ -60,6 +60,22 @@ protected:
|
||||||
std::vector<RenderCommand*> _queuePosZ;
|
std::vector<RenderCommand*> _queuePosZ;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//render queue for transparency object
|
||||||
|
class TransparentRenderQueue {
|
||||||
|
public:
|
||||||
|
void push_back(RenderCommand* command);
|
||||||
|
ssize_t size() const
|
||||||
|
{
|
||||||
|
return _queueCmd.size();
|
||||||
|
}
|
||||||
|
void sort();
|
||||||
|
RenderCommand* operator[](ssize_t index) const;
|
||||||
|
void clear();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
std::vector<RenderCommand*> _queueCmd;
|
||||||
|
};
|
||||||
|
|
||||||
struct RenderStackElement
|
struct RenderStackElement
|
||||||
{
|
{
|
||||||
int renderQueueID;
|
int renderQueueID;
|
||||||
|
@ -90,6 +106,9 @@ public:
|
||||||
/** Adds a `RenderComamnd` into the renderer specifying a particular render queue ID */
|
/** Adds a `RenderComamnd` into the renderer specifying a particular render queue ID */
|
||||||
void addCommand(RenderCommand* command, int renderQueue);
|
void addCommand(RenderCommand* command, int renderQueue);
|
||||||
|
|
||||||
|
/** add transprent command */
|
||||||
|
void addTransparentCommand(RenderCommand* command);
|
||||||
|
|
||||||
/** Pushes a group into the render queue */
|
/** Pushes a group into the render queue */
|
||||||
void pushGroup(int renderQueueID);
|
void pushGroup(int renderQueueID);
|
||||||
|
|
||||||
|
@ -139,11 +158,14 @@ protected:
|
||||||
|
|
||||||
void visitRenderQueue(const RenderQueue& queue);
|
void visitRenderQueue(const RenderQueue& queue);
|
||||||
|
|
||||||
|
void visitTransparentRenderQueue(const TransparentRenderQueue& queue);
|
||||||
|
|
||||||
void convertToWorldCoordinates(V3F_C4B_T2F_Quad* quads, ssize_t quantity, const Mat4& modelView);
|
void convertToWorldCoordinates(V3F_C4B_T2F_Quad* quads, ssize_t quantity, const Mat4& modelView);
|
||||||
|
|
||||||
std::stack<int> _commandGroupStack;
|
std::stack<int> _commandGroupStack;
|
||||||
|
|
||||||
std::vector<RenderQueue> _renderGroups;
|
std::vector<RenderQueue> _renderGroups;
|
||||||
|
TransparentRenderQueue _transparentRenderGroups; //transparency objects
|
||||||
|
|
||||||
uint32_t _lastMaterialID;
|
uint32_t _lastMaterialID;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue