2025-01-24 13:23:57 +08:00
|
|
|
|
#pragma once
|
2025-01-25 20:07:52 +08:00
|
|
|
|
#include<hgl/type/object/TickObject.h>
|
2025-01-28 22:20:48 +08:00
|
|
|
|
#include<hgl/graph/RenderFramework.h>
|
2025-01-29 18:10:37 +08:00
|
|
|
|
#include<hgl/graph/VKRenderResource.h>
|
2025-05-09 01:34:46 +08:00
|
|
|
|
#include<hgl/graph/mtl/MaterialLibrary.h>
|
2025-05-30 00:32:45 +08:00
|
|
|
|
#include<hgl/graph/Renderer.h>
|
2025-06-04 01:09:05 +08:00
|
|
|
|
#include<hgl/graph/Scene.h>
|
2025-01-24 13:23:57 +08:00
|
|
|
|
#include<hgl/Time.h>
|
2025-01-28 20:03:44 +08:00
|
|
|
|
//#include<iostream>
|
2025-01-24 13:23:57 +08:00
|
|
|
|
|
|
|
|
|
namespace hgl
|
|
|
|
|
{
|
2025-01-29 18:10:37 +08:00
|
|
|
|
namespace graph::mtl
|
|
|
|
|
{
|
|
|
|
|
class MaterialCreateInfo;
|
|
|
|
|
}
|
|
|
|
|
|
2025-01-28 20:03:44 +08:00
|
|
|
|
/**
|
|
|
|
|
* 工作对象</p>
|
2025-01-28 21:04:48 +08:00
|
|
|
|
*
|
|
|
|
|
* WorkObject被定义为工作对象,所有的渲染控制都需要被写在WorkObject的Render函数下。
|
2025-01-28 20:03:44 +08:00
|
|
|
|
*/
|
2025-01-25 20:07:52 +08:00
|
|
|
|
class WorkObject:public TickObject
|
2025-01-24 13:23:57 +08:00
|
|
|
|
{
|
2025-01-25 17:17:55 +08:00
|
|
|
|
graph::RenderFramework *render_framework=nullptr;
|
2025-01-24 13:23:57 +08:00
|
|
|
|
|
|
|
|
|
bool destroy_flag=false;
|
2025-06-04 00:04:46 +08:00
|
|
|
|
bool render_dirty=true;
|
2025-01-24 13:23:57 +08:00
|
|
|
|
|
2025-01-25 17:17:55 +08:00
|
|
|
|
protected:
|
|
|
|
|
|
2025-06-04 00:04:46 +08:00
|
|
|
|
//以下数据均取自RenderFramework
|
2025-05-30 00:32:45 +08:00
|
|
|
|
|
2025-06-04 00:04:46 +08:00
|
|
|
|
graph::RenderResource *db=nullptr; //暂时的,未来会被更好的机制替代
|
2025-05-30 00:32:45 +08:00
|
|
|
|
|
2025-06-04 00:04:46 +08:00
|
|
|
|
graph::Scene * scene=nullptr; //场景
|
2025-05-30 00:32:45 +08:00
|
|
|
|
graph::Renderer * renderer=nullptr; //渲染器
|
2025-01-25 17:17:55 +08:00
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
|
|
graph::RenderFramework * GetRenderFramework (){return render_framework;}
|
2025-05-17 20:26:36 +08:00
|
|
|
|
graph::VulkanDevice * GetDevice (){return render_framework->GetDevice();}
|
|
|
|
|
graph::VulkanDevAttr * GetDevAttr (){return render_framework->GetDevAttr();}
|
2025-05-22 01:11:30 +08:00
|
|
|
|
graph::TextureManager * GetTextureManager (){return render_framework->GetTextureManager();}
|
2025-01-25 17:17:55 +08:00
|
|
|
|
|
2025-06-04 01:09:05 +08:00
|
|
|
|
const VkExtent2D & GetExtent (){return renderer->GetExtent();}
|
|
|
|
|
|
|
|
|
|
graph::Scene * GetScene (){return scene;}
|
|
|
|
|
graph::SceneNode * GetSceneRoot (){return scene->GetRootNode();}
|
|
|
|
|
graph::Renderer * GetRenderer (){return renderer;}
|
2025-06-07 05:49:07 +08:00
|
|
|
|
graph::Camera * GetCamera (){return renderer->GetCamera();}
|
|
|
|
|
graph::CameraControl * GetCameraControl (){return render_framework->GetDefaultCameraControl();}
|
2025-02-01 16:32:08 +08:00
|
|
|
|
|
2025-06-11 01:05:24 +08:00
|
|
|
|
bool GetMouseCoord (Vector2i *mc)const{return render_framework->GetMouseCoord(mc);}
|
|
|
|
|
|
2025-01-24 13:23:57 +08:00
|
|
|
|
public:
|
|
|
|
|
|
2025-05-30 00:32:45 +08:00
|
|
|
|
const bool IsDestroy ()const{return destroy_flag;}
|
|
|
|
|
void MarkDestory(){destroy_flag=true;}
|
2025-01-24 13:23:57 +08:00
|
|
|
|
|
2025-06-04 00:04:46 +08:00
|
|
|
|
const bool IsRenderDirty ()const{return render_dirty;}
|
|
|
|
|
void MarkRenderDirty(){render_dirty=true;}
|
|
|
|
|
|
2025-01-24 13:23:57 +08:00
|
|
|
|
public:
|
|
|
|
|
|
2025-06-04 01:09:05 +08:00
|
|
|
|
WorkObject(graph::RenderFramework *,graph::Renderer *r=nullptr);
|
2025-01-24 13:23:57 +08:00
|
|
|
|
virtual ~WorkObject()=default;
|
|
|
|
|
|
2025-05-22 01:11:30 +08:00
|
|
|
|
virtual bool Init()=0;
|
|
|
|
|
|
2025-06-04 01:09:05 +08:00
|
|
|
|
virtual void OnRendererChange(graph::RenderFramework *rf,graph::Renderer *r);
|
2025-02-05 23:36:53 +08:00
|
|
|
|
|
|
|
|
|
virtual void OnResize(const VkExtent2D &){}
|
2025-01-24 13:23:57 +08:00
|
|
|
|
|
2025-03-13 23:36:47 +08:00
|
|
|
|
virtual void Tick(double){}
|
|
|
|
|
|
2025-01-28 20:48:43 +08:00
|
|
|
|
virtual void Render(double delta_time);
|
2025-01-28 21:04:48 +08:00
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
|
|
template<typename ...ARGS>
|
|
|
|
|
graph::Pipeline *CreatePipeline(ARGS...args)
|
|
|
|
|
{
|
2025-06-04 01:09:05 +08:00
|
|
|
|
return renderer->GetRenderPass()->CreatePipeline(args...);
|
2025-01-28 21:04:48 +08:00
|
|
|
|
}
|
2025-01-28 22:20:48 +08:00
|
|
|
|
|
2025-05-18 01:33:48 +08:00
|
|
|
|
graph::MaterialInstance *CreateMaterialInstance(const AnsiString &mi_name,const graph::mtl::MaterialCreateInfo *mci,const graph::VILConfig *vil_cfg=nullptr)
|
2025-01-29 18:10:37 +08:00
|
|
|
|
{
|
2025-05-18 01:33:48 +08:00
|
|
|
|
return db->CreateMaterialInstance(mi_name,mci,vil_cfg);
|
2025-01-29 18:10:37 +08:00
|
|
|
|
}
|
|
|
|
|
|
2025-05-09 01:34:46 +08:00
|
|
|
|
graph::MaterialInstance *CreateMaterialInstance(const AnsiString &mtl_name,graph::mtl::MaterialCreateConfig *mtl_cfg,const graph::VILConfig *vil_cfg=nullptr)
|
|
|
|
|
{
|
2025-05-18 01:33:48 +08:00
|
|
|
|
AutoDelete<graph::mtl::MaterialCreateInfo> mci=graph::mtl::CreateMaterialCreateInfo(GetDevAttr(),mtl_name,mtl_cfg);
|
2025-05-09 01:34:46 +08:00
|
|
|
|
|
2025-05-18 01:33:48 +08:00
|
|
|
|
return db->CreateMaterialInstance(mtl_name,mci,vil_cfg);
|
2025-05-09 01:34:46 +08:00
|
|
|
|
}
|
|
|
|
|
|
2025-06-11 01:05:24 +08:00
|
|
|
|
AutoDelete<graph::PrimitiveCreater> GetPrimitiveCreater(graph::Material *mtl)
|
|
|
|
|
{
|
|
|
|
|
if(!mtl)
|
|
|
|
|
return(nullptr);
|
|
|
|
|
|
|
|
|
|
return(new graph::PrimitiveCreater(GetDevice(),mtl->GetDefaultVIL()));
|
|
|
|
|
}
|
|
|
|
|
|
2025-06-10 23:46:19 +08:00
|
|
|
|
AutoDelete<graph::PrimitiveCreater> GetPrimitiveCreater(graph::MaterialInstance *mi)
|
|
|
|
|
{
|
|
|
|
|
if(!mi)
|
|
|
|
|
return(nullptr);
|
|
|
|
|
|
|
|
|
|
return(new graph::PrimitiveCreater(GetDevice(),mi->GetVIL()));
|
|
|
|
|
}
|
|
|
|
|
|
2025-03-14 00:17:19 +08:00
|
|
|
|
graph::Primitive *CreatePrimitive( const AnsiString &name,
|
|
|
|
|
const uint32_t vertices_count,
|
|
|
|
|
const graph::VIL *vil,
|
|
|
|
|
const std::initializer_list<graph::VertexAttribDataPtr> &vad_list);
|
|
|
|
|
|
2025-05-18 02:19:14 +08:00
|
|
|
|
graph::Mesh *CreateMesh(const AnsiString &name,
|
2025-03-14 00:17:19 +08:00
|
|
|
|
const uint32_t vertices_count,
|
|
|
|
|
graph::MaterialInstance *mi,
|
|
|
|
|
graph::Pipeline *pipeline,
|
|
|
|
|
const std::initializer_list<graph::VertexAttribDataPtr> &vad_list);
|
2025-06-14 18:47:54 +08:00
|
|
|
|
|
|
|
|
|
public: //Component 相关
|
|
|
|
|
|
|
|
|
|
template<typename C,typename ...ARGS>
|
|
|
|
|
inline C *CreateComponent(ARGS...args)
|
|
|
|
|
{
|
|
|
|
|
auto manager=C::GetDefaultManager(); //取得默认管理器
|
|
|
|
|
|
|
|
|
|
if(!manager)
|
|
|
|
|
{
|
|
|
|
|
// LOG_ERROR(OS_TEXT("CreateComponent failed, no default manager!"));
|
|
|
|
|
return(nullptr);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return manager->CreateComponent(args...); //创建组件
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template<typename C,typename ...ARGS>
|
|
|
|
|
inline C *CreateComponent(graph::SceneNode *parent_node,ARGS...args)
|
|
|
|
|
{
|
|
|
|
|
if(!parent_node)
|
|
|
|
|
{
|
|
|
|
|
// LOG_ERROR(OS_TEXT("CreateComponent failed, parent node is null!"));
|
|
|
|
|
return(nullptr);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
C *c=this->CreateComponent<C>(args...); //创建组件
|
|
|
|
|
|
|
|
|
|
if(!c)
|
|
|
|
|
{
|
|
|
|
|
// LOG_ERROR(OS_TEXT("CreateComponent failed, create component failed!"));
|
|
|
|
|
return(nullptr);
|
|
|
|
|
}
|
|
|
|
|
|
2025-06-15 02:03:38 +08:00
|
|
|
|
/**
|
|
|
|
|
* 如果此处出现转换错误,请检查是否包含了对应的Component头文件。
|
|
|
|
|
*/
|
2025-06-14 18:47:54 +08:00
|
|
|
|
parent_node->AttachComponent(c); //将组件附加到父节点
|
|
|
|
|
|
|
|
|
|
return c;
|
|
|
|
|
}
|
2025-06-14 23:42:50 +08:00
|
|
|
|
|
|
|
|
|
template<typename C,typename ...ARGS>
|
|
|
|
|
inline C *CreateComponent(const graph::Matrix4f &mat,graph::SceneNode *parent_node,ARGS...args)
|
|
|
|
|
{
|
|
|
|
|
if(!parent_node)
|
|
|
|
|
{
|
|
|
|
|
// LOG_ERROR(OS_TEXT("CreateComponent failed, parent node is null!"));
|
|
|
|
|
return(nullptr);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
C *c=this->CreateComponent<C>(args...); //创建组件
|
|
|
|
|
|
|
|
|
|
if(!c)
|
|
|
|
|
{
|
|
|
|
|
// LOG_ERROR(OS_TEXT("CreateComponent failed, create component failed!"));
|
|
|
|
|
return(nullptr);
|
|
|
|
|
}
|
|
|
|
|
|
2025-06-15 02:03:38 +08:00
|
|
|
|
/**
|
|
|
|
|
* 如果此处出现转换错误,请检查是否包含了对应的Component头文件。
|
|
|
|
|
*/
|
2025-06-14 23:42:50 +08:00
|
|
|
|
parent_node->AttachComponent(c); //将组件附加到父节点
|
|
|
|
|
|
|
|
|
|
c->graph::SceneOrient::SetLocalMatrix(mat);
|
|
|
|
|
|
|
|
|
|
return c;
|
|
|
|
|
}
|
2025-01-24 13:23:57 +08:00
|
|
|
|
};//class WorkObject
|
2025-01-28 21:04:48 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 但我们认为游戏开发者不应该关注如何控制渲染,而应该关注如何处理游戏逻辑.
|
|
|
|
|
* 所以我们在WorkObject的基础上再提供RenderWorkObject派生类,用于直接封装好的渲染场景树控制。
|
|
|
|
|
*
|
|
|
|
|
* 开发者仅需要将要渲染的物件放置于场景树即可。
|
|
|
|
|
|
|
|
|
|
* 但开发者也可以直接使用WorkObject,自行管理这些事。
|
|
|
|
|
* */
|
2025-01-24 13:23:57 +08:00
|
|
|
|
}//namespcae hgl
|