2023-05-26 21:41:51 +00:00
|
|
|
#include "enginever.hpp"
|
|
|
|
#include "engine.hpp"
|
2023-05-27 17:11:46 +00:00
|
|
|
#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->renderer = renderer;
|
|
|
|
loggerCallback = logger;
|
2023-05-27 17:11:46 +00:00
|
|
|
previousProcessTick = std::chrono::steady_clock::now();
|
|
|
|
previousPhysicsProcessTick = std::chrono::steady_clock::now();
|
2023-05-26 21:41:51 +00:00
|
|
|
|
|
|
|
//watch.start();
|
|
|
|
|
2023-05-27 17:11:46 +00:00
|
|
|
this->loggerCallback(Information, "Started Hibis [using v" + (std::string)getEngineVersion() + "]!");
|
2023-05-26 21:41:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Engine::~Engine() {
|
|
|
|
//watch.stop();
|
|
|
|
}
|
|
|
|
|
|
|
|
void Engine::runNodeProcesses() {
|
2023-05-27 17:11:46 +00:00
|
|
|
TODO("check if delta calc is correct")
|
|
|
|
const std::chrono::time_point<std::chrono::steady_clock> current = std::chrono::steady_clock::now();
|
|
|
|
auto delta = std::chrono::duration<float>(current - previousProcessTick);
|
2023-05-26 21:41:51 +00:00
|
|
|
|
|
|
|
for (Node* node : nodeList) {
|
2023-05-27 17:11:46 +00:00
|
|
|
node->process(delta.count());
|
2023-05-26 21:41:51 +00:00
|
|
|
}
|
|
|
|
|
2023-05-27 17:11:46 +00:00
|
|
|
previousProcessTick = std::chrono::steady_clock::now();
|
2023-05-26 21:41:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void Engine::runNodePhysicsProcesses() {
|
2023-05-27 17:11:46 +00:00
|
|
|
const std::chrono::time_point<std::chrono::steady_clock> current = std::chrono::steady_clock::now();
|
|
|
|
auto delta = std::chrono::duration<float>(current - previousProcessTick);
|
2023-05-26 21:41:51 +00:00
|
|
|
|
|
|
|
for (Node* node : nodeList) {
|
2023-05-27 17:11:46 +00:00
|
|
|
node->physicsProcess(delta.count());
|
2023-05-26 21:41:51 +00:00
|
|
|
}
|
|
|
|
|
2023-05-27 17:11:46 +00:00
|
|
|
previousProcessTick = std::chrono::steady_clock::now();
|
2023-05-26 21:41:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void Engine::drawNodes() {
|
2023-05-27 17:11:46 +00:00
|
|
|
TODO("check if this works")
|
|
|
|
for (Node* node : nodeList) {
|
|
|
|
if (Drawable* drawNode = (Drawable*)&node) {
|
|
|
|
drawNode->draw(renderer);
|
|
|
|
}
|
|
|
|
}
|
2023-05-26 21:41:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const char* Engine::getEngineVersion() { return HIBIS_VERSION; }
|
|
|
|
}
|