ULRE/example/Gizmo/PlaneGrid3D.cpp

136 lines
3.0 KiB
C++
Raw Normal View History

2023-10-05 00:50:31 +08:00
// PlaneGrid3D
2019-05-27 22:48:01 +08:00
#include"VulkanAppFramework.h"
#include<hgl/filesystem/FileSystem.h>
#include<hgl/graph/InlineGeometry.h>
2020-10-21 12:39:22 +08:00
#include<hgl/graph/VKRenderResource.h>
2019-05-27 22:48:01 +08:00
#include<hgl/graph/RenderList.h>
2020-11-19 22:12:31 +08:00
#include<hgl/graph/Camera.h>
#include<hgl/graph/mtl/Material3DCreateConfig.h>
#include<hgl/graph/VKVertexInputConfig.h>
2019-05-27 22:48:01 +08:00
using namespace hgl;
using namespace hgl::graph;
class TestApp:public SceneAppFramework
2019-05-27 22:48:01 +08:00
{
private:
Material * material =nullptr;
Pipeline * pipeline =nullptr;
2019-05-27 22:48:01 +08:00
Primitive * prim_plane_grid =nullptr;
MaterialInstance * material_instance[3]{};
2019-05-27 22:48:01 +08:00
private:
bool InitMDP()
{
mtl::Material3DCreateConfig cfg(device->GetDeviceAttribute(),"VertexLuminance3D",Prim::Lines);
cfg.local_to_world=true;
cfg.position_format=VAT_VEC2;
2024-06-12 09:55:50 +08:00
material=db->LoadMaterial("Std3D/VertexLum3D",&cfg);
if(!material)return(false);
VILConfig vil_config;
vil_config.Add(VAN::Luminance,VF_V1UN8);
2023-10-05 00:50:31 +08:00
Color4f GridColor;
COLOR ce=COLOR::BlenderAxisRed;
for(uint i=0;i<3;i++)
{
2023-10-05 00:50:31 +08:00
GridColor=GetColor4f(ce,1.0);
material_instance[i]=db->CreateMaterialInstance(material,&vil_config,&GridColor);
2023-10-05 00:50:31 +08:00
ce=COLOR((int)ce+1);
}
pipeline=CreatePipeline(material_instance[0],InlinePipeline::Solid3D,Prim::Lines);
return pipeline;
}
bool CreateRenderObject()
2019-05-27 22:48:01 +08:00
{
using namespace inline_geometry;
struct PlaneGridCreateInfo pgci;
2019-05-27 22:48:01 +08:00
pgci.grid_size.Set(32,32);
pgci.sub_count.Set(8,8);
pgci.lum=180;
pgci.sub_lum=255;
PrimitiveCreater pc(device,material_instance[0]->GetVIL());
2024-06-01 12:07:34 +08:00
prim_plane_grid=CreatePlaneGrid2D(&pc,&pgci);
2024-03-04 13:13:33 +08:00
return prim_plane_grid;
}
2023-10-13 19:22:11 +08:00
Renderable *Add(MaterialInstance *mi,const Matrix4f &mat)
{
2024-03-04 13:13:33 +08:00
Renderable *ri=db->CreateRenderable(prim_plane_grid,mi,pipeline);
if(!ri)
return(nullptr);
render_root.CreateSubNode(mat,ri);
return ri;
2019-05-27 22:48:01 +08:00
}
bool InitScene()
{
Add(material_instance[0],Matrix4f(1.0f));
Add(material_instance[1],rotate(HGL_RAD_90,0,1,0));
Add(material_instance[2],rotate(HGL_RAD_90,1,0,0));
2023-09-29 02:59:10 +08:00
camera->pos=Vector3f(32,32,32);
2022-01-27 10:20:49 +08:00
camera_control->SetTarget(Vector3f(0,0,0));
camera_control->Refresh();
// camera_control->SetReserveDirection(true,true); //反转x,y
2023-10-11 19:38:12 +08:00
render_root.RefreshMatrix();
render_list->Expend(&render_root);
return(true);
}
2019-05-27 22:48:01 +08:00
public:
2024-06-01 12:07:34 +08:00
~TestApp()
{
SAFE_CLEAR(prim_plane_grid);
}
bool Init(uint width,uint height) override
2019-05-27 22:48:01 +08:00
{
if(!SceneAppFramework::Init(width,height))
2019-05-27 22:48:01 +08:00
return(false);
if(!InitMDP())
2019-05-27 22:48:01 +08:00
return(false);
if(!CreateRenderObject())
return(false);
2019-05-27 22:48:01 +08:00
if(!InitScene())
return(false);
return(true);
}
};//class TestApp:public CameraAppFramework
2019-05-27 22:48:01 +08:00
int main(int,char **)
{
return RunApp<TestApp>(1280,720);
2019-05-27 22:48:01 +08:00
}