summaryrefslogtreecommitdiff
path: root/src/gui/render/RenderModel.cpp
diff options
context:
space:
mode:
authorSimon Robertshaw <simon@hardwired.org.uk>2013-03-24 12:24:17 (GMT)
committer Simon Robertshaw <simon@hardwired.org.uk>2013-03-24 12:24:17 (GMT)
commit9b5b85f9b01cbda7ef9a7ec2a15b2a35630a5b9d (patch)
treeac7d040253b459ce102e476cb19ab59e3cfa90d7 /src/gui/render/RenderModel.cpp
parent6bf98ccdca39936a3c51367862eed7c49f8786ec (diff)
parentbdc69f31c0be94191015838886bdcc2bc67f1acb (diff)
downloadpowder-9b5b85f9b01cbda7ef9a7ec2a15b2a35630a5b9d.zip
powder-9b5b85f9b01cbda7ef9a7ec2a15b2a35630a5b9d.tar.gz
Merge branch 'reorganisation' of github.com:FacialTurd/The-Powder-Toy
Diffstat (limited to 'src/gui/render/RenderModel.cpp')
-rw-r--r--src/gui/render/RenderModel.cpp135
1 files changed, 135 insertions, 0 deletions
diff --git a/src/gui/render/RenderModel.cpp b/src/gui/render/RenderModel.cpp
new file mode 100644
index 0000000..b17f6fc
--- /dev/null
+++ b/src/gui/render/RenderModel.cpp
@@ -0,0 +1,135 @@
+#include "RenderModel.h"
+
+RenderModel::RenderModel():
+ renderer(NULL)
+{
+
+}
+
+void RenderModel::AddObserver(RenderView * observer)
+{
+ observers.push_back(observer);
+ observer->NotifyRendererChanged(this);
+ observer->NotifyRenderChanged(this);
+ observer->NotifyDisplayChanged(this);
+ observer->NotifyColourChanged(this);
+}
+
+void RenderModel::SetRenderMode(unsigned int renderMode)
+{
+ if(renderer)
+ renderer->AddRenderMode(renderMode);
+ notifyRenderChanged();
+}
+
+void RenderModel::UnsetRenderMode(unsigned int renderMode)
+{
+ if(renderer)
+ renderer->RemoveRenderMode(renderMode);
+ notifyRenderChanged();
+}
+
+unsigned int RenderModel::GetRenderMode()
+{
+ if(renderer)
+ return renderer->render_mode;
+ else
+ return 0;
+}
+
+void RenderModel::SetDisplayMode(unsigned int displayMode)
+{
+ if(renderer)
+ renderer->AddDisplayMode(displayMode);
+ notifyDisplayChanged();
+}
+
+void RenderModel::UnsetDisplayMode(unsigned int displayMode)
+{
+ if(renderer)
+ renderer->RemoveDisplayMode(displayMode);
+ notifyDisplayChanged();
+}
+
+unsigned int RenderModel::GetDisplayMode()
+{
+ if(renderer)
+ return renderer->display_mode;
+ else
+ return 0;
+}
+
+void RenderModel::SetColourMode(unsigned int colourMode)
+{
+ if(renderer)
+ renderer->SetColourMode(colourMode);
+ notifyColourChanged();
+}
+
+unsigned int RenderModel::GetColourMode()
+{
+ if(renderer)
+ return renderer->colour_mode;
+ else
+ return 0;
+}
+
+void RenderModel::LoadRenderPreset(int presetNum)
+{
+ RenderPreset preset = renderer->renderModePresets[presetNum];
+ renderer->SetRenderMode(preset.RenderModes);
+ renderer->SetDisplayMode(preset.DisplayModes);
+ renderer->SetColourMode(preset.ColourMode);
+ notifyRenderChanged();
+ notifyDisplayChanged();
+ notifyColourChanged();
+}
+
+void RenderModel::SetRenderer(Renderer * ren)
+{
+ renderer = ren;
+ notifyRendererChanged();
+ notifyRenderChanged();
+ notifyDisplayChanged();
+ notifyColourChanged();
+}
+
+Renderer * RenderModel::GetRenderer()
+{
+ return renderer;
+}
+
+void RenderModel::notifyRendererChanged()
+{
+ for(int i = 0; i < observers.size(); i++)
+ {
+ observers[i]->NotifyRendererChanged(this);
+ }
+}
+
+void RenderModel::notifyRenderChanged()
+{
+ for(int i = 0; i < observers.size(); i++)
+ {
+ observers[i]->NotifyRenderChanged(this);
+ }
+}
+
+void RenderModel::notifyDisplayChanged()
+{
+ for(int i = 0; i < observers.size(); i++)
+ {
+ observers[i]->NotifyDisplayChanged(this);
+ }
+}
+
+void RenderModel::notifyColourChanged()
+{
+ for(int i = 0; i < observers.size(); i++)
+ {
+ observers[i]->NotifyColourChanged(this);
+ }
+}
+
+RenderModel::~RenderModel() {
+}