diff options
author | mattkae <mattkae@protonmail.com> | 2022-10-09 15:11:13 -0400 |
---|---|---|
committer | mattkae <mattkae@protonmail.com> | 2022-10-09 15:11:13 -0400 |
commit | cc8bbef4bc8257b65757396e4431e2ca9b5f30ff (patch) | |
tree | 08a821eb6ac514b44703a7093dd61f411af0651e /themes/main.cpp | |
parent | f6f3a4bad025e65542cd518b551ba0cc3e1898b3 (diff) |
At least I have a working sun theme, but this will have to wait until next summer I suppose
Diffstat (limited to 'themes/main.cpp')
-rw-r--r-- | themes/main.cpp | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/themes/main.cpp b/themes/main.cpp index ae91ba7..4e82ca0 100644 --- a/themes/main.cpp +++ b/themes/main.cpp @@ -5,6 +5,7 @@ #include "mathlib.h" #include "types.h" #include "TreeShape.h" +#include "SummerTheme.h" #include "LeafParticleRender.h" #include "Snowflake.h" #include <cstdio> @@ -15,7 +16,8 @@ enum Theme { Default = 0, Autumn, Winter, - Spring + Spring, + Summer }; struct AutumnTheme { @@ -74,6 +76,7 @@ EM_BOOL selectNone(int eventType, const EmscriptenMouseEvent* mouseEvent, void* EM_BOOL selectAutumn(int eventType, const EmscriptenMouseEvent* mouseEvent, void* userData); EM_BOOL selectWinter(int eventType, const EmscriptenMouseEvent* mouseEvent, void* userData); EM_BOOL selectSpring(int eventType, const EmscriptenMouseEvent* mouseEvent, void* userData); +EM_BOOL selectSummer(int eventType, const EmscriptenMouseEvent* mouseEvent, void* userData); WebglContext context; Renderer2d renderer2d; @@ -83,6 +86,7 @@ Theme activeTheme = Theme::Default; AutumnTheme autumnTheme; WinterTheme winterTheme; SpringTheme springTheme; +SummerTheme summerTheme; int main() { context.init("#theme_canvas"); @@ -90,6 +94,7 @@ int main() { emscripten_set_click_callback("#theme_button_autumn", NULL, false, selectAutumn); emscripten_set_click_callback("#theme_button_winter", NULL, false, selectWinter); emscripten_set_click_callback("#theme_button_spring", NULL, false, selectSpring); + emscripten_set_click_callback("#theme_button_summer", NULL, false, selectSummer); return 0; } @@ -119,6 +124,10 @@ void load(Theme theme) { renderer3d.load(&context); springTheme.load(&renderer3d); break; + case Theme::Summer: + renderer2d.load(&context); + summerTheme.load(&renderer2d); + break; default: break; } @@ -136,6 +145,9 @@ void update(f32 dtSeconds, void* userData) { case Theme::Spring: springTheme.update(dtSeconds); break; + case Theme::Summer: + summerTheme.update(dtSeconds); + break; default: break; } @@ -154,6 +166,10 @@ void update(f32 dtSeconds, void* userData) { renderer3d.render(); springTheme.render(&renderer3d); break; + case Theme::Summer: + renderer2d.render(); + summerTheme.render(&renderer2d); + break; default: break; } @@ -170,6 +186,9 @@ void unload() { case Theme::Spring: springTheme.unload(); break; + case Theme::Summer: + summerTheme.unload(); + break; default: break; } @@ -207,6 +226,12 @@ EM_BOOL selectSpring(int eventType, const EmscriptenMouseEvent* mouseEvent, void return true; } +EM_BOOL selectSummer(int eventType, const EmscriptenMouseEvent* mouseEvent, void* userData) { + printf("Summer theme selected\n"); + load(Theme::Summer); + return true; +} + // -- Autumn theme void AutumnTheme::load(Renderer2d* renderer) { renderer->clearColor = Vector4(252, 210, 153, 255).toNormalizedColor(); |