removed VertexInputDataGroup, Renderable only have basic vertexinputdata
This commit is contained in:
parent
1e03e28f0b
commit
2eac17ac61
@ -9,26 +9,38 @@
|
|||||||
#include<hgl/graph/VKMaterialInstance.h>
|
#include<hgl/graph/VKMaterialInstance.h>
|
||||||
#include<hgl/graph/VertexAttrib.h>
|
#include<hgl/graph/VertexAttrib.h>
|
||||||
VK_NAMESPACE_BEGIN
|
VK_NAMESPACE_BEGIN
|
||||||
|
|
||||||
struct VertexInputData
|
struct VertexInputData
|
||||||
{
|
{
|
||||||
uint32_t first_binding;
|
|
||||||
uint32_t binding_count;
|
uint32_t binding_count;
|
||||||
VkBuffer *buffer_list;
|
VkBuffer *buffer_list;
|
||||||
VkDeviceSize *buffer_offset;
|
VkDeviceSize *buffer_offset;
|
||||||
};
|
|
||||||
|
|
||||||
struct VertexInputDataGroup
|
uint32_t vertex_count;
|
||||||
{
|
|
||||||
const VIL *vil;
|
|
||||||
|
|
||||||
VertexInputData vid[size_t(VertexInputGroup::RANGE_SIZE)];
|
const IndexBufferData *index_buffer;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
VertexInputDataGroup(const VIL *);
|
VertexInputData(const uint32_t,const uint32_t,const IndexBufferData *);
|
||||||
~VertexInputDataGroup();
|
~VertexInputData();
|
||||||
};
|
|
||||||
|
const bool Comp(const VertexInputData *vid)const
|
||||||
|
{
|
||||||
|
if(binding_count!=vid->binding_count)return(false);
|
||||||
|
|
||||||
|
for(uint32_t i=0;i<binding_count;i++)
|
||||||
|
{
|
||||||
|
if(buffer_list[i]!=vid->buffer_list[i])return(false);
|
||||||
|
if(buffer_offset[i]!=vid->buffer_offset[i])return(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(vertex_count!=vid->vertex_count)return(false);
|
||||||
|
|
||||||
|
if(index_buffer!=vid->index_buffer)return(false);
|
||||||
|
|
||||||
|
return(true);
|
||||||
|
}
|
||||||
|
};//struct VertexInputData
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 可渲染对象<br>
|
* 可渲染对象<br>
|
||||||
@ -39,13 +51,13 @@ class Renderable
|
|||||||
MaterialInstance * mat_inst;
|
MaterialInstance * mat_inst;
|
||||||
Primitive * primitive;
|
Primitive * primitive;
|
||||||
|
|
||||||
VertexInputDataGroup *vid_group;
|
VertexInputData * vertex_input;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
friend Renderable *CreateRenderable(Primitive *,MaterialInstance *,Pipeline *);
|
friend Renderable *CreateRenderable(Primitive *,MaterialInstance *,Pipeline *);
|
||||||
|
|
||||||
Renderable(Primitive *,MaterialInstance *,Pipeline *,VertexInputDataGroup *);
|
Renderable(Primitive *,MaterialInstance *,Pipeline *,VertexInputData *);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
@ -60,16 +72,7 @@ public:
|
|||||||
Primitive * GetPrimitive (){return primitive;}
|
Primitive * GetPrimitive (){return primitive;}
|
||||||
const AABB & GetBoundingBox ()const{return primitive->GetBoundingBox();}
|
const AABB & GetBoundingBox ()const{return primitive->GetBoundingBox();}
|
||||||
|
|
||||||
const VertexInputData * GetVertexInputData (const VertexInputGroup &vig)const
|
const VertexInputData * GetVertexInputData ()const{return vertex_input;}
|
||||||
{
|
|
||||||
RANGE_CHECK_RETURN_NULLPTR(vig)
|
|
||||||
|
|
||||||
return vid_group->vid+size_t(vig);
|
|
||||||
}
|
|
||||||
|
|
||||||
IndexBuffer * GetIndexBuffer ()const{return primitive->GetIndexBuffer();}
|
|
||||||
const uint32_t GetIndexBufferOffset()const{return primitive->GetIndexBufferOffset();}
|
|
||||||
const uint32_t GetDrawCount ()const{return primitive->GetDrawCount();}
|
|
||||||
|
|
||||||
MaterialParameters *GetMP (const DescriptorSetType &type){return mat_inst->GetMP(type);}
|
MaterialParameters *GetMP (const DescriptorSetType &type){return mat_inst->GetMP(type);}
|
||||||
|
|
||||||
|
@ -5,50 +5,38 @@
|
|||||||
#include<hgl/graph/VKVertexAttribBuffer.h>
|
#include<hgl/graph/VKVertexAttribBuffer.h>
|
||||||
|
|
||||||
VK_NAMESPACE_BEGIN
|
VK_NAMESPACE_BEGIN
|
||||||
VertexInputDataGroup::VertexInputDataGroup(const VIL *vd)
|
VertexInputData::VertexInputData(const uint32_t c,const uint32_t vc,const IndexBufferData *ibd)
|
||||||
{
|
{
|
||||||
vil=vd;
|
binding_count=c;
|
||||||
|
|
||||||
uint first_binding=0;
|
buffer_list=new VkBuffer[binding_count];
|
||||||
|
buffer_offset=new VkDeviceSize[binding_count];
|
||||||
|
|
||||||
for(uint i=0;i<size_t(VertexInputGroup::RANGE_SIZE);i++)
|
vertex_count=vc;
|
||||||
{
|
|
||||||
vid[i].binding_count=vil->GetCount(VertexInputGroup(i));
|
|
||||||
|
|
||||||
if(vid[i].binding_count>0)
|
index_buffer=ibd;
|
||||||
{
|
|
||||||
vid[i].first_binding=vil->GetFirstBinding(VertexInputGroup(i));
|
|
||||||
|
|
||||||
vid[i].buffer_list=new VkBuffer[vid[i].binding_count];
|
|
||||||
vid[i].buffer_offset=new VkDeviceSize[vid[i].binding_count];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
VertexInputDataGroup::~VertexInputDataGroup()
|
VertexInputData::~VertexInputData()
|
||||||
{
|
{
|
||||||
for(uint i=0;i<size_t(VertexInputGroup::RANGE_SIZE);i++)
|
delete[] buffer_list;
|
||||||
if(vid[i].binding_count>0)
|
delete[] buffer_offset;
|
||||||
{
|
|
||||||
delete[] vid[i].buffer_list;
|
|
||||||
delete[] vid[i].buffer_offset;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Renderable::Renderable(Primitive *r,MaterialInstance *mi,Pipeline *p,VertexInputDataGroup *vidg)
|
Renderable::Renderable(Primitive *r,MaterialInstance *mi,Pipeline *p,VertexInputData *vi)
|
||||||
{
|
{
|
||||||
primitive=r;
|
primitive=r;
|
||||||
pipeline=p;
|
pipeline=p;
|
||||||
mat_inst=mi;
|
mat_inst=mi;
|
||||||
|
|
||||||
vid_group=vidg;
|
vertex_input=vi;
|
||||||
}
|
}
|
||||||
|
|
||||||
Renderable::~Renderable()
|
Renderable::~Renderable()
|
||||||
{
|
{
|
||||||
//需要在这里添加删除pipeline/desc_sets/primitive引用计数的代码
|
//需要在这里添加删除pipeline/desc_sets/primitive引用计数的代码
|
||||||
|
|
||||||
delete vid_group;
|
delete vertex_input;
|
||||||
}
|
}
|
||||||
|
|
||||||
Renderable *CreateRenderable(Primitive *prim,MaterialInstance *mi,Pipeline *p)
|
Renderable *CreateRenderable(Primitive *prim,MaterialInstance *mi,Pipeline *p)
|
||||||
@ -56,7 +44,7 @@ Renderable *CreateRenderable(Primitive *prim,MaterialInstance *mi,Pipeline *p)
|
|||||||
if(!prim||!mi||!p)return(nullptr);
|
if(!prim||!mi||!p)return(nullptr);
|
||||||
|
|
||||||
const VIL *vil=mi->GetVIL();
|
const VIL *vil=mi->GetVIL();
|
||||||
const uint input_count=vil->GetCount(VertexInputGroup::Basic); //不统计Bone/LocalToWorld组的
|
const uint32_t input_count=vil->GetCount(VertexInputGroup::Basic); //不统计Bone/LocalToWorld组的
|
||||||
const UTF8String &mtl_name=mi->GetMaterial()->GetName();
|
const UTF8String &mtl_name=mi->GetMaterial()->GetName();
|
||||||
|
|
||||||
if(prim->GetBufferCount()<input_count) //小于材质要求的数量?那自然是不行的
|
if(prim->GetBufferCount()<input_count) //小于材质要求的数量?那自然是不行的
|
||||||
@ -68,15 +56,13 @@ Renderable *CreateRenderable(Primitive *prim,MaterialInstance *mi,Pipeline *p)
|
|||||||
|
|
||||||
VBO *vbo;
|
VBO *vbo;
|
||||||
|
|
||||||
VertexInputDataGroup *vid_group=new VertexInputDataGroup(vil);
|
VertexInputData *vid=new VertexInputData(input_count,prim->GetVertexCount(),prim->GetIndexBuffer());
|
||||||
|
|
||||||
VertexInputData &vid=vid_group->vid[size_t(VertexInputGroup::Basic)];
|
|
||||||
|
|
||||||
const VertexInputFormat *vif=vil->GetFormatList(VertexInputGroup::Basic);
|
const VertexInputFormat *vif=vil->GetFormatList(VertexInputGroup::Basic);
|
||||||
|
|
||||||
for(uint i=0;i<input_count;i++)
|
for(uint i=0;i<input_count;i++)
|
||||||
{
|
{
|
||||||
vbo=prim->GetVBO(vif->name,vid.buffer_offset+i);
|
vbo=prim->GetVBO(vif->name,vid->buffer_offset+i);
|
||||||
|
|
||||||
if(!vbo)
|
if(!vbo)
|
||||||
{
|
{
|
||||||
@ -104,10 +90,10 @@ Renderable *CreateRenderable(Primitive *prim,MaterialInstance *mi,Pipeline *p)
|
|||||||
return(nullptr);
|
return(nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
vid.buffer_list[i]=vbo->GetBuffer();
|
vid->buffer_list[i]=vbo->GetBuffer();
|
||||||
++vif;
|
++vif;
|
||||||
}
|
}
|
||||||
|
|
||||||
return(new Renderable(prim,mi,p,vid_group));
|
return(new Renderable(prim,mi,p,vid));
|
||||||
}
|
}
|
||||||
VK_NAMESPACE_END
|
VK_NAMESPACE_END
|
||||||
|
Loading…
x
Reference in New Issue
Block a user