optimized VulkanAppFramework and many examples that I moved Camera to VulkanApplicationFrame from CameraAppFramework

This commit is contained in:
2022-03-09 20:55:09 +08:00
parent 15e80cbc5a
commit 885cd735cd
9 changed files with 75 additions and 294 deletions

View File

@@ -26,9 +26,7 @@ struct TileBitmap
};
class TestApp:public VulkanApplicationFramework
{
Camera cam;
{
ObjectList<TileBitmap> tile_list;
TileData *tile_data=nullptr;
@@ -44,7 +42,6 @@ private:
MaterialInstance * material_instance =nullptr;
Renderable * render_obj =nullptr;
RenderableInstance *render_instance =nullptr;
GPUBuffer * ubo_camera_info =nullptr;
Pipeline * pipeline =nullptr;
@@ -162,33 +159,17 @@ private:
if(!material_instance)
return(false);
BindCameraUBO(material_instance);
pipeline=CreatePipeline(material_instance,InlinePipeline::Solid2D,Prim::SolidRectangles);
sampler=db->CreateSampler();
if(!material_instance->BindUBO(DescriptorSetsType::Global,"g_camera",ubo_camera_info))return(false);
if(!material_instance->BindSampler(DescriptorSetsType::Value,"tex",tile_data->GetTexture(),sampler))return(false);
return(true);
}
bool InitUBO()
{
const VkExtent2D extent=sc_render_target->GetExtent();
cam.width=extent.width;
cam.height=extent.height;
cam.RefreshCameraInfo();
ubo_camera_info=db->CreateUBO(sizeof(CameraInfo),&cam.info);
if(!ubo_camera_info)
return(false);
return(true);
}
bool InitVBO()
{
const uint tile_count=tile_list.GetCount();
@@ -217,9 +198,6 @@ public:
if(!InitTileTexture())
return(false);
if(!InitUBO())
return(false);
if(!InitMaterial())
return(false);
@@ -233,12 +211,7 @@ public:
void Resize(int w,int h)override
{
cam.width=w;
cam.height=h;
cam.RefreshCameraInfo();
ubo_camera_info->Write(&cam.info);
VulkanApplicationFramework::Resize(w,h);
BuildCommandBuffer(render_instance);
}