Merge branch 'billboard' of https://github.com/super626/cocos2d-x into billboard

This commit is contained in:
songchengjiang 2014-08-28 11:06:02 +08:00
commit 6a2f4c635e
2 changed files with 111 additions and 0 deletions

View File

@ -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;

View File

@ -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;