data around everywhere thing I had going on beforemaster
parent
a6e18bbb54
commit
3ff6fb0b14
@ -0,0 +1,66 @@
|
|||||||
|
#pragma once
|
||||||
|
#include <mutex>
|
||||||
|
#include <Logger.h>
|
||||||
|
#include <list>
|
||||||
|
|
||||||
|
class Gui {
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
Gui() {
|
||||||
|
container_lock.lock();
|
||||||
|
renderable_container.push_back(this);
|
||||||
|
container_lock.unlock();
|
||||||
|
};
|
||||||
|
virtual ~Gui() {
|
||||||
|
container_lock.lock();
|
||||||
|
renderable_container.remove(this);
|
||||||
|
container_lock.unlock();
|
||||||
|
};
|
||||||
|
|
||||||
|
virtual void render_gui() = 0;
|
||||||
|
virtual void update_gui() = 0;
|
||||||
|
|
||||||
|
// Instead of rendering nil, we can pass our render call if we would like
|
||||||
|
bool renderable() { return rendering; };
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
// Whatever class that wants to call this must be a friend!!!
|
||||||
|
friend class Application;
|
||||||
|
static void do_render() {
|
||||||
|
for (auto i : renderable_container) {
|
||||||
|
i->update_gui();
|
||||||
|
if (i->renderable())
|
||||||
|
i->render_gui();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
static std::mutex container_lock;
|
||||||
|
static std::list<Gui*> renderable_container;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
bool rendering = false;
|
||||||
|
// Derived class will handle imgui calls
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -0,0 +1,4 @@
|
|||||||
|
#include "Gui.h"
|
||||||
|
|
||||||
|
std::mutex Gui::container_lock;
|
||||||
|
std::list<Gui*> Gui::renderable_container;
|
Loading…
Reference in new issue