ULRE/src/SceneGraph/Vulkan/VKRenderable.cpp

106 lines
3.2 KiB
C++
Raw Normal View History

#include<hgl/graph/VKRenderable.h>
2021-06-16 20:29:25 +08:00
#include<hgl/graph/VKMaterialInstance.h>
#include<hgl/graph/VKMaterialParameters.h>
#include<hgl/graph/VKMaterial.h>
#include<hgl/graph/VKVertexAttribBuffer.h>
2023-07-28 20:17:46 +08:00
#include<hgl/log/LogInfo.h>
VK_NAMESPACE_BEGIN
VertexInputData::VertexInputData(const uint32_t c,const uint32_t vc,const IndexBufferData *ibd)
{
binding_count=c;
buffer_list=new VkBuffer[binding_count];
buffer_offset=new VkDeviceSize[binding_count];
vertex_count=vc;
index_buffer=ibd;
}
VertexInputData::~VertexInputData()
{
delete[] buffer_list;
delete[] buffer_offset;
}
Renderable::Renderable(Primitive *r,MaterialInstance *mi,Pipeline *p,VertexInputData *vi)
{
2022-06-24 18:00:22 +08:00
primitive=r;
pipeline=p;
2021-06-16 20:29:25 +08:00
mat_inst=mi;
vertex_input=vi;
}
Renderable::~Renderable()
{
2022-06-24 18:00:22 +08:00
//需要在这里添加删除pipeline/desc_sets/primitive引用计数的代码
delete vertex_input;
}
2023-05-02 18:56:55 +08:00
Renderable *CreateRenderable(Primitive *prim,MaterialInstance *mi,Pipeline *p)
{
2023-05-02 18:56:55 +08:00
if(!prim||!mi||!p)return(nullptr);
const VIL *vil=mi->GetVIL();
const uint32_t input_count=vil->GetCount(VertexInputGroup::Basic); //不统计Bone/LocalToWorld组的
const UTF8String &mtl_name=mi->GetMaterial()->GetName();
2023-05-02 18:56:55 +08:00
if(prim->GetBufferCount()<input_count) //小于材质要求的数量?那自然是不行的
{
LOG_ERROR("[FATAL ERROR] input buffer count of Renderable lesser than Material, Material name: "+mtl_name);
return(nullptr);
}
2024-04-24 01:38:55 +08:00
VAB *vab;
VertexInputData *vid=new VertexInputData(input_count,prim->GetVertexCount(),prim->GetIndexBufferData());
const VertexInputFormat *vif=vil->GetVIFList(VertexInputGroup::Basic);
2024-04-24 01:38:55 +08:00
VABAccess vad;
for(uint i=0;i<input_count;i++)
{
2024-04-24 01:44:01 +08:00
//注: VIF来自于材质但VAB来自于Primitive。
2024-04-03 19:26:22 +08:00
// 两个并不一定一样排序也不一定一样。所以不能让PRIMTIVE直接提供BUFFER_LIST/OFFSET来搞一次性绑定。
2024-04-24 01:44:01 +08:00
if(!prim->GetVABAccess(vif->name,&vad))
{
2024-04-24 01:44:01 +08:00
LOG_ERROR("[FATAL ERROR] not found VAB \""+AnsiString(vif->name)+"\" in Material: "+mtl_name);
return(nullptr);
}
2024-04-24 01:38:55 +08:00
vab=vad.vab;
2024-04-24 01:38:55 +08:00
if(vab->GetFormat()!=vif->format)
{
2024-04-24 01:44:01 +08:00
LOG_ERROR( "[FATAL ERROR] VAB \""+UTF8String(vif->name)+
UTF8String("\" format can't match Renderable, Material(")+mtl_name+
UTF8String(") Format(")+GetVulkanFormatName(vif->format)+
2024-04-24 01:44:01 +08:00
UTF8String("), VAB Format(")+GetVulkanFormatName(vab->GetFormat())+
")");
return(nullptr);
}
2024-04-24 01:38:55 +08:00
if(vab->GetStride()!=vif->stride)
{
2024-04-24 01:44:01 +08:00
LOG_ERROR( "[FATAL ERROR] VAB \""+UTF8String(vif->name)+
UTF8String("\" stride can't match Renderable, Material(")+mtl_name+
UTF8String(") stride(")+UTF8String::numberOf(vif->stride)+
2024-04-24 01:44:01 +08:00
UTF8String("), VAB stride(")+UTF8String::numberOf(vab->GetStride())+
")");
return(nullptr);
}
vid->buffer_offset[i]=vad.offset;
2024-04-24 01:38:55 +08:00
vid->buffer_list[i]=vab->GetBuffer();
++vif;
}
return(new Renderable(prim,mi,p,vid));
}
2020-11-03 22:29:32 +08:00
VK_NAMESPACE_END