]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Model/src/plantitem.cpp
Mini bugfix.
[z.facultad/75.42/plaqui.git] / Model / src / plantitem.cpp
index 9405a945455e2191f23b9df591bcd5fd32e69482..34360b0485336bc0eb1b99ac16a68171820f9cd8 100644 (file)
@@ -1,6 +1,6 @@
 
 
-
 #include "plantitem.h"
 #include "plantitem.h"
+#include <iostream>
 
 using namespace PlaQui::Model;
 
 
 using namespace PlaQui::Model;
 
@@ -9,6 +9,7 @@ PlantItem::PlantItem(const std::string &_name):IConector(0, 0)
        name = _name;
        updated = false;
        fluid_color = RGB(255,255,255);
        name = _name;
        updated = false;
        fluid_color = RGB(255,255,255);
+       color_updated = false;
 }
 
 PlantItem::PlantItem(unsigned ins, unsigned outs):IConector(ins, outs)
 }
 
 PlantItem::PlantItem(unsigned ins, unsigned outs):IConector(ins, outs)
@@ -27,11 +28,33 @@ void PlantItem::recieve_msg(int msg, IConector *who, void *data)
                        // TODO
                        return;
                break;
                        // TODO
                        return;
                break;
+               case MSG_QUERY_COLOR:
+                       if (color_updated) {
+                               who->recieve_msg(MSG_RESPONSE_COLOR, this, &fluid_color);
+                               return;
+                       }
+                       update_color();
+                       who->recieve_msg(MSG_RESPONSE_COLOR, this, &fluid_color);
+               break;
+               case MSG_RESPONSE_COLOR:
+               {
+                       RGB *c = ((RGB *)data);
+                       set_color(*c);
+               }
+               break;
                default:
                        IConector::recieve_msg(msg, who, data);
        }
 }
 
                default:
                        IConector::recieve_msg(msg, who, data);
        }
 }
 
+void PlantItem::update_color()
+{
+       if (color_updated) return;
+
+       color_updated = true;
+       send_msg(IConector::IN, MSG_QUERY_COLOR);
+}
+
 void PlantItem::get_state_as_xml(std::stringstream &out)
 {
        out << "\t<float name=\"" << name << "\">" << std::endl;
 void PlantItem::get_state_as_xml(std::stringstream &out)
 {
        out << "\t<float name=\"" << name << "\">" << std::endl;
@@ -44,5 +67,5 @@ void PlantItem::get_state_as_xml(std::stringstream &out)
        out << "\t</color>" << std::endl;
 
        // Para que quede bonito
        out << "\t</color>" << std::endl;
 
        // Para que quede bonito
-       actual_flow = 99999;
+       actual_flow = INFINITO;
 }
 }