2024-04-26 01:17:47 +08:00
|
|
|
|
#pragma once
|
2024-04-27 03:09:16 +08:00
|
|
|
|
//
|
|
|
|
|
//#include<hgl/graph/VKVertexAttribBuffer.h>
|
|
|
|
|
//#include<hgl/graph/VKIndexBuffer.h>
|
|
|
|
|
//#include<hgl/graph/AABB.h>
|
|
|
|
|
//
|
|
|
|
|
//VK_NAMESPACE_BEGIN
|
|
|
|
|
//
|
|
|
|
|
///*
|
|
|
|
|
// 1.截止2024.4.27,根据vulkan.gpuinfo.org统计,只有9%的设备maxVertexInputAttributes为16,不存在低于16的设备。
|
|
|
|
|
// 9.0%的设备为28 - 31
|
|
|
|
|
// 70.7%的设备为32
|
|
|
|
|
// 9.6%的设备为64
|
|
|
|
|
//
|
|
|
|
|
// 由于我们暂时没有发现需要使用16个以上属性的情况,所以这里暂定使用16。
|
|
|
|
|
// (如果时间过去久远,可再次查询此值是否可改成更高的值,以及是否需要)
|
|
|
|
|
//
|
|
|
|
|
// 2.为何va_name使用char[][]而不是String以及动态分配内存?
|
|
|
|
|
//
|
|
|
|
|
// 就是为了必避动态分配内存,以及可以直接memcpy处理,所以此处这样定义。
|
|
|
|
|
//*/
|
|
|
|
|
//
|
|
|
|
|
//struct VABAccessInfo
|
|
|
|
|
//{
|
|
|
|
|
// char va_name[VERTEX_ATTRIB_NAME_MAX_LENGTH+1];
|
|
|
|
|
// VABAccess vab_access;
|
|
|
|
|
//};
|
|
|
|
|
//
|
|
|
|
|
//constexpr const uint HGL_MAX_VERTEX_ATTRIB_COUNT=16; ///<最大顶点属性数量
|
|
|
|
|
//
|
|
|
|
|
//struct PrimitiveData
|
|
|
|
|
//{
|
|
|
|
|
// VkDeviceSize vertex_count;
|
|
|
|
|
//
|
|
|
|
|
// uint32_t va_count;
|
|
|
|
|
//
|
|
|
|
|
// VABAccessInfo vab_list[HGL_MAX_VERTEX_ATTRIB_COUNT];
|
|
|
|
|
//
|
|
|
|
|
// IBAccess ib_access;
|
|
|
|
|
//
|
|
|
|
|
// AABB BoundingBox;
|
|
|
|
|
//
|
|
|
|
|
//public:
|
|
|
|
|
//
|
|
|
|
|
// void Clear()
|
|
|
|
|
// {
|
|
|
|
|
// hgl_zero(*this);
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// const int GetVABIndex(const char *name)const
|
|
|
|
|
// {
|
|
|
|
|
// for(int i=0;i<va_count;i++)
|
|
|
|
|
// {
|
|
|
|
|
// if(hgl::strcmp(vab_list[i].va_name,name)==0)
|
|
|
|
|
// return(i);
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// return(-1);
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// VABAccess *GetVAB(const char *name)
|
|
|
|
|
// {
|
|
|
|
|
// if(!name||!*name)
|
|
|
|
|
// return(nullptr);
|
|
|
|
|
//
|
|
|
|
|
// const int index=GetVABIndex(name);
|
|
|
|
|
//
|
|
|
|
|
// if(index==-1)
|
|
|
|
|
// return(nullptr);
|
|
|
|
|
//
|
|
|
|
|
// return &(vab_list[index].vab_access);
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// const int AddVAB(const char *name,VAB *vab,VkDeviceSize start=0)
|
|
|
|
|
// {
|
|
|
|
|
// if(va_count>=HGL_MAX_VERTEX_ATTRIB_COUNT)
|
|
|
|
|
// return(-1);
|
|
|
|
|
//
|
|
|
|
|
// VABAccessInfo *vai=vab_list+va_count;
|
|
|
|
|
//
|
|
|
|
|
// hgl::strcpy(vai->va_name,VERTEX_ATTRIB_NAME_MAX_LENGTH,name);
|
|
|
|
|
// vai->vab_access.vab=vab;
|
|
|
|
|
// vai->vab_access.start=start;
|
|
|
|
|
//
|
|
|
|
|
// #ifdef _DEBUG
|
|
|
|
|
// DebugUtils *du=device->GetDebugUtils();
|
|
|
|
|
//
|
|
|
|
|
// if(du)
|
|
|
|
|
// {
|
|
|
|
|
// du->SetBuffer(vab->GetBuffer(),prim_name+":VAB:Buffer:"+name);
|
|
|
|
|
// du->SetDeviceMemory(vab->GetVkMemory(),prim_name+":VAB:Memory:"+name);
|
|
|
|
|
// }
|
|
|
|
|
// #endif//_DEBUG
|
|
|
|
|
//
|
|
|
|
|
// return(va_count++);
|
|
|
|
|
// }
|
|
|
|
|
//};//struct PrimitiveData
|
|
|
|
|
//
|
|
|
|
|
//constexpr const uint PRIMITIVE_DATA_SIZE=sizeof(PrimitiveData);
|
2024-04-27 02:19:01 +08:00
|
|
|
|
|
2024-04-26 01:17:47 +08:00
|
|
|
|
VK_NAMESPACE_END
|