mirror of https://github.com/axmolengine/axmol.git
Improve Android performance (#1125)
* Improve Android performance * Remove unused memset * Using the same code as Metal. * Add a comment
This commit is contained in:
parent
cd76849c4d
commit
8a4494606a
|
@ -995,8 +995,10 @@ void Renderer::TriangleCommandBufferManager::createBuffer()
|
||||||
{
|
{
|
||||||
auto device = backend::Device::getInstance();
|
auto device = backend::Device::getInstance();
|
||||||
|
|
||||||
#ifdef AX_USE_METAL
|
// Not initializing the buffer before passing it to updateData for Android/OpenGL ES.
|
||||||
// Metal doesn't need to update buffer to make sure it has the correct size.
|
// This change does fix the Android/OpenGL ES performance problem
|
||||||
|
// If for some reason we get reports of performance issues on OpenGL implementations,
|
||||||
|
// then we can just add pre-processor checks for OpenGL and have the updateData() allocate the full size after buffer creation.
|
||||||
auto vertexBuffer = device->newBuffer(Renderer::VBO_SIZE * sizeof(_verts[0]), backend::BufferType::VERTEX,
|
auto vertexBuffer = device->newBuffer(Renderer::VBO_SIZE * sizeof(_verts[0]), backend::BufferType::VERTEX,
|
||||||
backend::BufferUsage::DYNAMIC);
|
backend::BufferUsage::DYNAMIC);
|
||||||
if (!vertexBuffer)
|
if (!vertexBuffer)
|
||||||
|
@ -1009,32 +1011,6 @@ void Renderer::TriangleCommandBufferManager::createBuffer()
|
||||||
vertexBuffer->release();
|
vertexBuffer->release();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#else
|
|
||||||
auto tmpData = malloc(Renderer::VBO_SIZE * sizeof(V3F_C4B_T2F));
|
|
||||||
if (!tmpData)
|
|
||||||
return;
|
|
||||||
|
|
||||||
auto vertexBuffer = device->newBuffer(Renderer::VBO_SIZE * sizeof(V3F_C4B_T2F), backend::BufferType::VERTEX,
|
|
||||||
backend::BufferUsage::DYNAMIC);
|
|
||||||
if (!vertexBuffer)
|
|
||||||
{
|
|
||||||
free(tmpData);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
vertexBuffer->updateData(tmpData, Renderer::VBO_SIZE * sizeof(V3F_C4B_T2F));
|
|
||||||
|
|
||||||
auto indexBuffer = device->newBuffer(Renderer::INDEX_VBO_SIZE * sizeof(unsigned short), backend::BufferType::INDEX,
|
|
||||||
backend::BufferUsage::DYNAMIC);
|
|
||||||
if (!indexBuffer)
|
|
||||||
{
|
|
||||||
free(tmpData);
|
|
||||||
vertexBuffer->release();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
indexBuffer->updateData(tmpData, Renderer::INDEX_VBO_SIZE * sizeof(unsigned short));
|
|
||||||
|
|
||||||
free(tmpData);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
_vertexBufferPool.emplace_back(vertexBuffer);
|
_vertexBufferPool.emplace_back(vertexBuffer);
|
||||||
_indexBufferPool.emplace_back(indexBuffer);
|
_indexBufferPool.emplace_back(indexBuffer);
|
||||||
|
|
Loading…
Reference in New Issue