game cleanup

This commit is contained in:
lightling 2022-04-03 15:47:16 -04:00
parent 20b3fd7d97
commit 2d659b0646
Signed by: lightling
GPG key ID: 016F11E0AA296B67
2 changed files with 10 additions and 28 deletions

View file

@ -48,7 +48,6 @@ Game::~Game()
// we don't need to explicitly clean up those DirectX objects // we don't need to explicitly clean up those DirectX objects
// - If we weren't using smart pointers, we'd need // - If we weren't using smart pointers, we'd need
// to call Release() on each DirectX object created in Game // to call Release() on each DirectX object created in Game
} }
// -------------------------------------------------------- // --------------------------------------------------------
@ -57,10 +56,7 @@ Game::~Game()
// -------------------------------------------------------- // --------------------------------------------------------
void Game::Init() void Game::Init()
{ {
// Helper methods for loading shaders, creating some basic LoadShadersAndMaterials();
// geometry to draw and some simple camera matrices.
// - You'll be expanding and/or replacing these later
LoadShaders();
LoadTextures(); LoadTextures();
LoadLighting(); LoadLighting();
CreateBasicGeometry(); CreateBasicGeometry();
@ -72,14 +68,9 @@ void Game::Init()
} }
// -------------------------------------------------------- // --------------------------------------------------------
// Loads shaders from compiled shader object (.cso) files // Loads shaders from compiled shader object (.cso) files and pushes them to materials
// and also created the Input Layout that describes our
// vertex data to the rendering pipeline.
// - Input Layout creation is done here because it must
// be verified against vertex shader byte code
// - We'll have that byte code already loaded below
// -------------------------------------------------------- // --------------------------------------------------------
void Game::LoadShaders() void Game::LoadShadersAndMaterials()
{ {
vertexShader = std::make_shared<SimpleVertexShader>(device, context, GetFullPathTo_Wide(L"VertexShader.cso").c_str()); vertexShader = std::make_shared<SimpleVertexShader>(device, context, GetFullPathTo_Wide(L"VertexShader.cso").c_str());
pixelShader = std::make_shared<SimplePixelShader>(device, context, GetFullPathTo_Wide(L"SimplePixelShader.cso").c_str()); pixelShader = std::make_shared<SimplePixelShader>(device, context, GetFullPathTo_Wide(L"SimplePixelShader.cso").c_str());
@ -92,6 +83,9 @@ void Game::LoadShaders()
}; };
} }
// --------------------------------------------------------
// Loads textures and pushes them to the loaded materials
// --------------------------------------------------------
void Game::LoadTextures() void Game::LoadTextures()
{ {
Microsoft::WRL::ComPtr<ID3D11SamplerState> sampler; Microsoft::WRL::ComPtr<ID3D11SamplerState> sampler;
@ -116,6 +110,9 @@ void Game::LoadTextures()
materials[1]->LoadTexture(L"Assets/Textures/HQGame/structure-endgame-floor_emissive.png", TEXTYPE_EMISSIVE, device.Get(), context.Get()); materials[1]->LoadTexture(L"Assets/Textures/HQGame/structure-endgame-floor_emissive.png", TEXTYPE_EMISSIVE, device.Get(), context.Get());
} }
// --------------------------------------------------------
// Instantiates all the lighting in the scene
// --------------------------------------------------------
void Game::LoadLighting() void Game::LoadLighting()
{ {
ambient = XMFLOAT3(0.1f, 0.1f, 0.15f); ambient = XMFLOAT3(0.1f, 0.1f, 0.15f);
@ -195,7 +192,6 @@ void Game::OnResize()
// -------------------------------------------------------- // --------------------------------------------------------
void Game::Update(float deltaTime, float totalTime) void Game::Update(float deltaTime, float totalTime)
{ {
// Example input checking: Quit if the escape key is pressed
if (Input::GetInstance().KeyDown(VK_ESCAPE)) if (Input::GetInstance().KeyDown(VK_ESCAPE))
Quit(); Quit();
@ -204,10 +200,6 @@ void Game::Update(float deltaTime, float totalTime)
for (int i = 0; i < entities.size(); ++i) for (int i = 0; i < entities.size(); ++i)
{ {
entities[i]->GetTransform()->SetRotation(sin(totalTime / 720) * 360, 0, 0); entities[i]->GetTransform()->SetRotation(sin(totalTime / 720) * 360, 0, 0);
//entities[i]->GetMaterial()->SetRoughness(sin(totalTime) * 0.5f + 0.49f);
//entities[i]->GetMaterial()->SetUVOffset(DirectX::XMFLOAT2(cos(totalTime * 4) * 0.5f + 0.49f, cos(totalTime * 4) * 0.5f + 0.49f));
//entities[i]->GetMaterial()->SetUVScale(DirectX::XMFLOAT2(sin(totalTime) * 0.5f + 0.49f, sin(totalTime) * 0.5f + 0.49f));
//entities[i]->GetMaterial()->SetEmitAmount(cos(totalTime) * 0.5f + 0.49f);
} }
} }

12
Game.h
View file

@ -15,33 +15,23 @@
class Game class Game
: public DXCore : public DXCore
{ {
public: public:
Game(HINSTANCE hInstance); Game(HINSTANCE hInstance);
~Game(); ~Game();
// Overridden setup and game loop methods, which
// will be called automatically
void Init(); void Init();
void OnResize(); void OnResize();
void Update(float deltaTime, float totalTime); void Update(float deltaTime, float totalTime);
void Draw(float deltaTime, float totalTime); void Draw(float deltaTime, float totalTime);
private: private:
// Should we use vsync to limit the frame rate? // Should we use vsync to limit the frame rate?
bool vsync; bool vsync;
// Initialization helper methods - feel free to customize, combine, etc. void LoadShadersAndMaterials();
void LoadShaders();
void LoadTextures(); void LoadTextures();
void LoadLighting(); void LoadLighting();
void CreateBasicGeometry(); void CreateBasicGeometry();
// Note the usage of ComPtr below
// - This is a smart pointer for objects that abide by the
// Component Object Model, which DirectX objects do
// - More info here: https://github.com/Microsoft/DirectXTK/wiki/ComPtr
// Shaders and shader-related constructs // Shaders and shader-related constructs
std::shared_ptr<SimplePixelShader> pixelShader; std::shared_ptr<SimplePixelShader> pixelShader;