Change TextDrawable base class
This commit is contained in:
@@ -18,11 +18,11 @@ using namespace OpenVulkano::Scene;
|
||||
namespace OpenVulkano::Vulkan
|
||||
{
|
||||
|
||||
void EncodeBackground(LabelDrawable* labelDrawable, Vulkan::VulkanDrawContext* drawContext)
|
||||
void EncodeBackground(LabelDrawable* labelDrawable, VulkanDrawContext* drawContext)
|
||||
{
|
||||
if (labelDrawable->IsBillboard())
|
||||
{
|
||||
OpenVulkano::Scene::UniformBuffer* buffer = labelDrawable->GetBillboardBuffer();
|
||||
Scene::UniformBuffer* buffer = labelDrawable->GetBillboardBuffer();
|
||||
VulkanUniformBuffer* vkBuffer = buffer->GetRenderResource();
|
||||
if (!vkBuffer)
|
||||
{
|
||||
@@ -31,7 +31,7 @@ namespace OpenVulkano::Vulkan
|
||||
vkBuffer->Record(drawContext);
|
||||
}
|
||||
|
||||
OpenVulkano::Scene::UniformBuffer* labelBuffer = labelDrawable->GetLabelBuffer();
|
||||
Scene::UniformBuffer* labelBuffer = labelDrawable->GetLabelBuffer();
|
||||
VulkanUniformBuffer* vkBuffer = labelBuffer->GetRenderResource();
|
||||
if (!vkBuffer)
|
||||
{
|
||||
@@ -50,13 +50,13 @@ namespace OpenVulkano::Vulkan
|
||||
drawContext->commandBuffer.draw(4, 1, 0, 0);
|
||||
}
|
||||
|
||||
void EncodeTextDrawable(LabelDrawable* labelDrawable, Vulkan::VulkanDrawContext* drawContext)
|
||||
void EncodeTextDrawable(LabelDrawable* labelDrawable, VulkanDrawContext* drawContext)
|
||||
{
|
||||
for (TextDrawable& entry : labelDrawable->GetTexts())
|
||||
{
|
||||
OpenVulkano::Scene::Shader* shader = entry.GetShader();
|
||||
Shader* shader = entry.GetShader();
|
||||
drawContext->EncodeShader(shader);
|
||||
Geometry* mesh = entry.GetMesh();
|
||||
Geometry* mesh = entry.GetGeometry();
|
||||
VulkanGeometry* renderGeo = mesh->GetRenderResource();
|
||||
if (!renderGeo)
|
||||
{
|
||||
@@ -64,16 +64,16 @@ namespace OpenVulkano::Vulkan
|
||||
}
|
||||
renderGeo->RecordBind(drawContext->commandBuffer);
|
||||
|
||||
std::array<OpenVulkano::Scene::UniformBuffer*, 2> uniforms = { nullptr, nullptr };
|
||||
std::array<Scene::UniformBuffer*, 2> uniforms = { nullptr, nullptr };
|
||||
// fragment shader buffer
|
||||
uniforms[0] = entry.GetBuffer();
|
||||
uniforms[0] = entry.GetUniformBuffer();
|
||||
if (labelDrawable->IsBillboard())
|
||||
{
|
||||
// vertex shader buffer
|
||||
uniforms[1] = labelDrawable->GetBillboardBuffer();
|
||||
}
|
||||
|
||||
for (OpenVulkano::Scene::UniformBuffer* buffer : uniforms)
|
||||
for (Scene::UniformBuffer* buffer : uniforms)
|
||||
{
|
||||
if (buffer)
|
||||
{
|
||||
@@ -85,19 +85,15 @@ namespace OpenVulkano::Vulkan
|
||||
vkBuffer->Record(drawContext);
|
||||
}
|
||||
}
|
||||
|
||||
if (Material* material = entry.GetMaterial())
|
||||
|
||||
if (Texture* texture = entry.GetTexture())
|
||||
{
|
||||
if (Texture* texture = material->texture)
|
||||
VulkanTexture* renderTexture = texture->GetRenderResource();
|
||||
if (!renderTexture)
|
||||
{
|
||||
VulkanTexture* renderTexture = texture->GetRenderResource();
|
||||
if (!renderTexture)
|
||||
{
|
||||
drawContext->renderer->GetResourceManager().PrepareMaterial(entry.GetMaterial());
|
||||
renderTexture = texture->GetRenderResource();
|
||||
}
|
||||
renderTexture->Record(drawContext);
|
||||
renderTexture = drawContext->renderer->GetResourceManager().PrepareTexture(entry.GetTexture());
|
||||
}
|
||||
renderTexture->Record(drawContext);
|
||||
}
|
||||
|
||||
for (Node* node: labelDrawable->GetNodes())
|
||||
@@ -112,7 +108,7 @@ namespace OpenVulkano::Vulkan
|
||||
}
|
||||
}
|
||||
|
||||
void EncodeLabelDrawable(Drawable* instance, Vulkan::VulkanDrawContext* drawContext)
|
||||
void EncodeLabelDrawable(Drawable* instance, VulkanDrawContext* drawContext)
|
||||
{
|
||||
LabelDrawable* labelDrawable = static_cast<LabelDrawable*>(instance);
|
||||
EncodeBackground(labelDrawable, drawContext);
|
||||
@@ -122,5 +118,5 @@ namespace OpenVulkano::Vulkan
|
||||
|
||||
namespace
|
||||
{
|
||||
void* labelDrawableVulkanEncoderReg = DrawEncoder::RegisterVulkanEncodeFunction<LabelDrawable>(&OpenVulkano::Vulkan::EncodeLabelDrawable);
|
||||
[[maybe_unused]] void* labelDrawableVulkanEncoderReg = DrawEncoder::RegisterVulkanEncodeFunction<LabelDrawable>(&OpenVulkano::Vulkan::EncodeLabelDrawable);
|
||||
}
|
||||
Reference in New Issue
Block a user