summaryrefslogtreecommitdiff
path: root/src/Activity.h
diff options
context:
space:
mode:
authorSimon Robertshaw <simon@hardwired.org.uk>2012-11-17 19:44:09 (GMT)
committer Simon Robertshaw <simon@hardwired.org.uk>2012-11-17 19:44:09 (GMT)
commit058a2edd75debbd0297f92572316daa704bd379f (patch)
treead303f091f9a08b209b91eb34a9fcad996a3de69 /src/Activity.h
parente3594aba9e05c6865d396418c028049cda92c2f3 (diff)
parent7a21ae192fe19868539956f3fe28e62b2c7c4429 (diff)
downloadpowder-058a2edd75debbd0297f92572316daa704bd379f.zip
powder-058a2edd75debbd0297f92572316daa704bd379f.tar.gz
Merge branch 'master' of github.com:FacialTurd/PowderToypp
Diffstat (limited to 'src/Activity.h')
-rw-r--r--src/Activity.h42
1 files changed, 42 insertions, 0 deletions
diff --git a/src/Activity.h b/src/Activity.h
new file mode 100644
index 0000000..0263467
--- /dev/null
+++ b/src/Activity.h
@@ -0,0 +1,42 @@
+#pragma once
+
+#include "interface/Window.h"
+
+class Activity
+{
+public:
+ virtual void Exit() {}
+ virtual void Show() {}
+ virtual void Hide() {}
+ virtual ~Activity() {}
+};
+
+class WindowActivity: public ui::Window, public Activity
+{
+public:
+ WindowActivity(ui::Point position, ui::Point size) :
+ ui::Window(position, size)
+ {
+ Show();
+ }
+ virtual void Exit()
+ {
+ Hide();
+ SelfDestruct();
+ }
+ virtual void Show()
+ {
+ if(ui::Engine::Ref().GetWindow() != this)
+ {
+ ui::Engine::Ref().ShowWindow(this);
+ }
+ }
+ virtual void Hide()
+ {
+ if(ui::Engine::Ref().GetWindow() == this)
+ {
+ ui::Engine::Ref().CloseWindow();
+ }
+ }
+ virtual ~WindowActivity() {}
+}; \ No newline at end of file