[WIP] Gizmo update codes;

This commit is contained in:
hyzboy 2024-07-01 23:31:18 +08:00
parent 7903ac32c1
commit eb70cb1ea4
7 changed files with 103 additions and 48 deletions

2
CMCore

@ -1 +1 @@
Subproject commit 538d19781a7818e1333d9ee5a8c165dcff072a25 Subproject commit 913bcfcfb2fbee1b0bc748e2e979e8d5c66ec09e

View File

@ -14,6 +14,6 @@ CreateProject(01_PlaneGrid3D PlaneGrid3D.cpp)
CreateProject(02_RayPicking RayPicking.cpp) CreateProject(02_RayPicking RayPicking.cpp)
CreateProject(03_MetricCellsGrid MetricCellsGrid.cpp) CreateProject(03_MetricCellsGrid MetricCellsGrid.cpp)
CreateProject(04_Gizmo3DMove Gizmo3DMove.cpp Gizmo.h GizmoResource.cpp) CreateProject(04_Gizmo3DTest GizmoTest.cpp Gizmo3DMove.cpp Gizmo.h GizmoResource.cpp)
#CreateProject(03_BlenderAxis BlenderAxis.cpp) #CreateProject(03_BlenderAxis BlenderAxis.cpp)

View File

@ -4,16 +4,7 @@
VK_NAMESPACE_BEGIN VK_NAMESPACE_BEGIN
class PrimitiveCreater; bool InitGizmoResource(GPUDevice *);
void FreeGizmoResource();
class GizmoResource
{
protected:
public:
};//class GizmoResource
VK_NAMESPACE_END VK_NAMESPACE_END

View File

@ -40,16 +40,17 @@ namespace
ENUM_CLASS_RANGE(Plane,Cylinder) ENUM_CLASS_RANGE(Plane,Cylinder)
}; };
static Material * material =nullptr; static RenderResource * gizmo_rr =nullptr;
static MaterialInstance * mtl_inst[size_t(GizmoColor::RANGE_SIZE)]{}; static Material * gizmo_material =nullptr;
static Pipeline * pipeline =nullptr; static MaterialInstance * gizmo_mtl_inst[size_t(GizmoColor::RANGE_SIZE)]{};
static VertexDataManager * vdm =nullptr; static Pipeline * gizmo_pipeline =nullptr;
static VertexDataManager * gizmo_vdm =nullptr;
static PrimitiveCreater * prim_creater=nullptr; static PrimitiveCreater * gizmo_prim_creater =nullptr;
static Primitive * prim[size_t(GizmoShape::RANGE_SIZE)]{}; static Primitive * gizmo_prim[size_t(GizmoShape::RANGE_SIZE)]{};
bool InitGizmoMI(RenderResource *rr) bool InitGizmoMI()
{ {
constexpr const COLOR gizmo_color[size_t(GizmoColor::RANGE_SIZE)]= constexpr const COLOR gizmo_color[size_t(GizmoColor::RANGE_SIZE)]=
{ {
@ -63,7 +64,7 @@ namespace
COLOR::BlenderYellow, COLOR::BlenderYellow,
}; };
if(!rr||!material) if(!gizmo_rr||!gizmo_material)
return(false); return(false);
Color4f color; Color4f color;
@ -72,8 +73,8 @@ namespace
{ {
color=GetColor4f(gizmo_color[i],1.0); color=GetColor4f(gizmo_color[i],1.0);
mtl_inst[i]=rr->CreateMaterialInstance(material,nullptr,&color); gizmo_mtl_inst[i]=gizmo_rr->CreateMaterialInstance(gizmo_material,nullptr,&color);
if(!mtl_inst[i]) if(!gizmo_mtl_inst[i])
return(false); return(false);
} }
@ -81,12 +82,13 @@ namespace
} }
}//namespace }//namespace
bool InitGizmoResource(RenderResource *rr) bool InitGizmoResource(GPUDevice *device)
{ {
if(!rr) gizmo_rr=new RenderResource(device);
if(!gizmo_rr)
return(false); return(false);
GPUDevice *device=rr->GetDevice();
RenderPass *render_pass=device->GetRenderPass(); RenderPass *render_pass=device->GetRenderPass();
{ {
@ -100,36 +102,36 @@ bool InitGizmoResource(RenderResource *rr)
if(!mci) if(!mci)
return(false); return(false);
material=rr->CreateMaterial(mci); gizmo_material=gizmo_rr->CreateMaterial(mci);
if(!material) if(!gizmo_material)
return(false); return(false);
} }
if(!InitGizmoMI(rr)) if(!InitGizmoMI())
return(false); return(false);
{ {
pipeline=render_pass->CreatePipeline(material,InlinePipeline::Solid3D,Prim::Triangles); gizmo_pipeline=render_pass->CreatePipeline(gizmo_material,InlinePipeline::Solid3D,Prim::Triangles);
if(!pipeline) if(!gizmo_pipeline)
return(false); return(false);
} }
{ {
vdm=new VertexDataManager(device,material->GetDefaultVIL()); gizmo_vdm=new VertexDataManager(device,gizmo_material->GetDefaultVIL());
if(!vdm) if(!gizmo_vdm)
return(false); return(false);
if(!vdm->Init( HGL_SIZE_1MB, //最大顶点数量 if(!gizmo_vdm->Init(HGL_SIZE_1MB, //最大顶点数量
HGL_SIZE_1MB, //最大索引数量 HGL_SIZE_1MB, //最大索引数量
IndexType::U16)) //索引类型 IndexType::U16)) //索引类型
return(false); return(false);
} }
{ {
prim_creater=new PrimitiveCreater(vdm); gizmo_prim_creater=new PrimitiveCreater(gizmo_vdm);
if(!prim_creater) if(!gizmo_prim_creater)
return(false); return(false);
} }
@ -137,7 +139,7 @@ bool InitGizmoResource(RenderResource *rr)
using namespace inline_geometry; using namespace inline_geometry;
{ {
prim[size_t(GizmoShape::Plane)]=CreatePlane(prim_creater); gizmo_prim[size_t(GizmoShape::Plane)]=CreatePlane(gizmo_prim_creater);
} }
{ {
@ -147,11 +149,11 @@ bool InitGizmoResource(RenderResource *rr)
cci.tangent=false; cci.tangent=false;
cci.tex_coord=false; cci.tex_coord=false;
prim[size_t(GizmoShape::Cube)]=CreateCube(prim_creater,&cci); gizmo_prim[size_t(GizmoShape::Cube)]=CreateCube(gizmo_prim_creater,&cci);
} }
{ {
prim[size_t(GizmoShape::Sphere)]=CreateSphere(prim_creater,8); gizmo_prim[size_t(GizmoShape::Sphere)]=CreateSphere(gizmo_prim_creater,8);
} }
{ {
@ -162,7 +164,7 @@ bool InitGizmoResource(RenderResource *rr)
cci.numberSlices=8; //圆锥底部分割数 cci.numberSlices=8; //圆锥底部分割数
cci.numberStacks=1; //圆锥高度分割数 cci.numberStacks=1; //圆锥高度分割数
prim[size_t(GizmoShape::Cone)]=CreateCone(prim_creater,&cci); gizmo_prim[size_t(GizmoShape::Cone)]=CreateCone(gizmo_prim_creater,&cci);
} }
{ {
@ -172,12 +174,12 @@ bool InitGizmoResource(RenderResource *rr)
cci.numberSlices=8; //圆柱底部分割数 cci.numberSlices=8; //圆柱底部分割数
cci.radius =1; //圆柱半径 cci.radius =1; //圆柱半径
prim[size_t(GizmoShape::Cylinder)]=CreateCylinder(prim_creater,&cci); gizmo_prim[size_t(GizmoShape::Cylinder)]=CreateCylinder(gizmo_prim_creater,&cci);
} }
ENUM_CLASS_FOR(GizmoShape,int,i) ENUM_CLASS_FOR(GizmoShape,int,i)
{ {
if(!prim[i]) if(!gizmo_prim[i])
return(false); return(false);
} }
} }
@ -185,4 +187,15 @@ bool InitGizmoResource(RenderResource *rr)
return(true); return(true);
} }
void FreeGizmoResource()
{
SAFE_CLEAR_OBJECT_ARRAY(gizmo_prim)
SAFE_CLEAR(gizmo_prim_creater);
SAFE_CLEAR(gizmo_vdm);
// SAFE_CLEAR(gizmo_pipeline);
// SAFE_CLEAR_OBJECT_ARRAY(gizmo_mtl_inst)
//SAFE_CLEAR(gizmo_material);
SAFE_CLEAR(gizmo_rr);
}
VK_NAMESPACE_END VK_NAMESPACE_END

View File

@ -0,0 +1,41 @@
#include"VulkanAppFramework.h"
#include"Gizmo.h"
using namespace hgl;
using namespace hgl::graph;
class TestApp:public SceneAppFramework
{
private:
bool InitGizmo()
{
if(!InitGizmoResource(device))
return(false);
return(true);
}
public:
bool Init(uint w,uint h)
{
if(!SceneAppFramework::Init(w,h))
return(false);
if(!InitGizmo())
return(false);
return(true);
}
~TestApp()
{
FreeGizmoResource();
}
};//class TestApp:public SceneAppFramework
int main(int,char **)
{
return RunApp<TestApp>(1280,720);
}

View File

@ -35,7 +35,6 @@ constexpr const COLOR AxisColor[4]=
COLOR::GhostWhite, COLOR::GhostWhite,
COLOR::BlanchedAlmond, COLOR::BlanchedAlmond,
COLOR::AntiqueWhite COLOR::AntiqueWhite
}; };
constexpr const os_char *tex_filename[]= constexpr const os_char *tex_filename[]=

View File

@ -39,7 +39,7 @@ void main()
//直接光颜色 //直接光颜色
vec3 direct_color=intensity*SUN_COLOR*mi.Color.rgb; vec3 direct_color=intensity*SUN_COLOR*mi.Color.rgb;
vec3 SpecularColor=vec3(0); vec3 spec_color=vec3(0);
if(intensity>0.0) if(intensity>0.0)
{ {
@ -62,12 +62,14 @@ void main()
bool CustomVertexShader(ShaderCreateInfoVertex *vsc) override bool CustomVertexShader(ShaderCreateInfoVertex *vsc) override
{ {
if(!Std3DMaterial::CustomVertexShader(vsc)) vsc->AddInput(VAT_VEC3,VAN::Normal);
return(false);
vsc->AddOutput(SVT_VEC4,"Position"); vsc->AddOutput(SVT_VEC4,"Position");
vsc->AddOutput(SVT_VEC3,"Normal"); vsc->AddOutput(SVT_VEC3,"Normal");
if(!Std3DMaterial::CustomVertexShader(vsc)) //会根据是否有GetNormal函数来决定是否添加Normal计算代码所以需要放在AddInput后面
return(false);
vsc->SetMain(vs_main); vsc->SetMain(vs_main);
return(true); return(true);
} }
@ -79,6 +81,15 @@ void main()
fsc->SetMain(fs_main); fsc->SetMain(fs_main);
return(true); return(true);
} }
bool EndCustomShader() override
{
mci->SetMaterialInstance(mi_codes, //材质实例glsl代码
mi_bytes, //材质实例数据大小
VK_SHADER_STAGE_FRAGMENT_BIT); //只在Vertex Shader中使用材质实例最终数据
return(true);
}
};//class MaterialGizmo3D:public Std3DMaterial };//class MaterialGizmo3D:public Std3DMaterial
}//namespace }//namespace