游戏引擎从零开始(2)-增加Application和入口

前言

前面花几篇文章把整体的框架搭建好,稍安勿躁。

本章节在引擎内增加Application基类和入口类EntryPoint,业务层增加Application的继承类。另调整部分代码。

先整体看下,文件的增删修改

engine文件夹更名为->Hazel

删掉了Test类,将Application移到引擎内的Hazel文件夹内

增加Application & 入口EntryPoint

Hazel引擎里的Application基类

先删掉上一节中 Sandbox中临时的Application文件。和引擎里的Application不是一回事。

Application是一个基类,负责整个渲染Loop、日志、资源初始化等操作,相当于引擎运行时的入口。

在业务工程Sandbox内有SandboxApp类,继承自Application,实现业务自己特殊的逻辑。

游戏引擎内都会有一个Run函数,实现一个大的Loop循环,定时的更新状态、处理输入、渲染上屏。

Application头文件,声明Run()函数,和一个CreateApplication()函数。

Hazel/src/Hazel/Application.h

c++ 复制代码
#ifndef SANBOX_APPLICATION_H
#define SANBOX_APPLICATION_H

namespace Hazel{
class Application {
public:
    Application();
    virtual ~Application();
    void Run();
};
    Application* CreateApplication();
}



#endif //SANBOX_APPLICATION_H

Hazel/src/Hazel/Application.cpp

c++ 复制代码
#include "Application.h"

namespace Hazel{
    Application::Application() {

    }

    Application::~Application() {

    }

    void Application::Run() {
        while(true) {

        }
    }

}

引擎入口类

将应用的运行封装到EntryPoint.h中,业务方使用引擎的逻辑也包含进来,对业务方透明。

一方面降低业务方使用的难度,另一方面将重要的逻辑内敛到引擎内部。

Hazel/src/Hazel/EntryPoint.h

c++ 复制代码
#ifndef SANBOX_ENTRYPOINT_H
#define SANBOX_ENTRYPOINT_H

#ifdef HZ_PLATFORM_WINDOWS
extern Hazel::Application* Hazel::CreateApplication();


int main(int argc, char** argv) {

    auto app = Hazel::CreateApplication();
    app->Run();
    delete app;
}
#endif
#endif //SANBOX_ENTRYPOINT_H

引擎统一的对外头文件 Hazel.h

方便业务方使用,在引擎里设计一个Hazel.h头文件,将引擎里需要对外输出的头文件统一放到这里。

Hazel/src/Hazel.h

c++ 复制代码
#ifndef SANBOX_HAZEL_H
#define SANBOX_HAZEL_H

#include <stdio.h>
#include "Hazel/Application.h"

#endif //SANBOX_HAZEL_H

// -----Entry Point-------
#include "Hazel/EntryPoint.h"

引擎中的CMakeList.txt

scss 复制代码
cmake_minimum_required(VERSION 2.8)
project(hazel)
set(SRC_LIST src/Hazel/Application.cpp)
add_library(hazel STATIC ${SRC_LIST})

业务Sandbox里的app实现类

CreateApplication()放到业务app层实现,即由业务决定创建哪个App,可能会有多个选择哟~

c++ 复制代码
#include <Hazel.h> 

class Sandbox : public Hazel::Application {
public:
    Sandbox(){

    }

    ~Sandbox()
    {

    }
};

Hazel::Application* Hazel::CreateApplication() {
    return new Sandbox();
}

总结

本章节,实现了引擎的Application类和入口类EntryPoint,后续新增加的模块,不断的集成到Application和EntryPoint中。

完整代码参考增加Application和入口

相关推荐
陈天伟教授5 小时前
图解人工智能(60)人工智能应用-AI游戏
人工智能·游戏
魔士于安5 小时前
Shader forge技术美术专用
游戏·unity·游戏引擎·贴图·技术美术·模型
Y学院7 小时前
C#游戏脚本开发全流程(Unity通用完整版)
游戏·unity·c#
yyuuuzz8 小时前
游戏云服务器推荐的技术选择思路
大数据·运维·服务器·游戏·云计算·aws
SmalBox9 小时前
【节点】[Grid节点]原理解析与实际应用
unity3d·游戏开发·图形学
xinhuanjieyi1 天前
html修复游戏种太阳错误
前端·游戏·html
魔士于安1 天前
unity 音乐会场景 unity2022
游戏·unity·游戏引擎·贴图·模型
码来的小朋友1 天前
[python] 我开发了一个有20个关卡随机地图的迷宫游戏
python·游戏·pygame
不羁的木木1 天前
《HarmonyOS 6.1 新能力实战之智感握姿》第四篇:进阶应用——横屏游戏手柄模式
游戏·华为·harmonyos
Swift社区1 天前
鸿蒙游戏Runtime解析:Store如何驱动整个游戏世界?
游戏·华为·harmonyos