hibiscus/core/engine/engine.cpp

57 lines
1.6 KiB
C++
Raw Normal View History

2023-05-26 21:41:51 +00:00
#include "enginever.hpp"
#include "engine.hpp"
#include <pragmautil.hpp>
#include <core/graphics/drawable.hpp>
2023-05-26 21:41:51 +00:00
namespace hibis {
Engine::Engine(Renderer* renderer, LoggerCallback logger) {
this->mRenderer = renderer;
mLoggerCallback = logger;
mPreviousProcessTick = std::chrono::steady_clock::now();
mPreviousPhysicsProcessTick = std::chrono::steady_clock::now();
2023-05-26 21:41:51 +00:00
//watch.start();
this->mLoggerCallback(Information, "Started Hibis [using v" + (std::string)getEngineVersion() + "]!");
2023-05-26 21:41:51 +00:00
}
Engine::~Engine() {
//watch.stop();
}
void Engine::runNodeProcesses() {
TODO("check if delta calc is correct")
2023-05-27 23:14:27 +00:00
TODO("get workaround for MSVC being fucking stupid (std::chrono + std::this_thread)")
const std::chrono::time_point<std::chrono::steady_clock> current = std::chrono::steady_clock::now();
auto delta = std::chrono::duration<float>(current - mPreviousProcessTick);
2023-05-26 21:41:51 +00:00
for (Node* node : mNodeList) {
node->process(delta.count());
2023-05-26 21:41:51 +00:00
}
mPreviousProcessTick = std::chrono::steady_clock::now();
2023-05-26 21:41:51 +00:00
}
void Engine::runNodePhysicsProcesses() {
const std::chrono::time_point<std::chrono::steady_clock> current = std::chrono::steady_clock::now();
auto delta = std::chrono::duration<float>(current - mPreviousProcessTick);
2023-05-26 21:41:51 +00:00
for (Node* node : mNodeList) {
node->physicsProcess(delta.count());
2023-05-26 21:41:51 +00:00
}
mPreviousProcessTick = std::chrono::steady_clock::now();
2023-05-26 21:41:51 +00:00
}
void Engine::drawNodes() {
TODO("check if this works")
for (Node* node : mNodeList) {
if (Drawable* drawNode = (Drawable*)&node) {
drawNode->draw(mRenderer);
}
}
2023-05-26 21:41:51 +00:00
}
const char* Engine::getEngineVersion() { return HIBIS_VERSION; }
}