]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Model/src/union.cpp
* Se mejora la deteccion de conexiones en el constructor
[z.facultad/75.42/plaqui.git] / Model / src / union.cpp
index 58bc8e1a06570df69e2bef416f4b19ef16ca80a8..f581a67033e1211f2bc2dedec8973623f6cebfea 100644 (file)
@@ -95,7 +95,41 @@ void Union::recieve_msg(int msg, IConector *who, void *data)
 void Union::update(int dir)
 {
        // Si ya me actualice, no lo tengo que hacer de nuevo
 void Union::update(int dir)
 {
        // Si ya me actualice, no lo tengo que hacer de nuevo
-       if (updated) return;
+       RGB c_in1, c_in2;
+       unsigned r=0,g=0,b=0;
+       float c_f1, c_f2; // para ver los flujos de cada uno
+
+       if (updated) {
+               std::list<IConector *>::iterator i = in_list.begin();
+               if (i != in_list.end()) {
+                       PlantItem *o = (PlantItem *)(*i);
+                       c_in1 = o->get_color();
+                       c_f1 = o->get_actual_flow();
+                       i++;
+                       o = (PlantItem *)(*i);
+                       c_in2 = o->get_color();
+                       c_f2 = o->get_actual_flow();
+               }
+
+               set_color( RGB(r,g,b) );
+               if ((c_f1 != 0) && (c_f2 != 0)) {
+                       // Si ambas entradas traen flujo, sumo sus colores
+                       int total = c_f1+c_f2;
+                       r = ((int)((c_in1.r()*c_f1/total+c_in2.r()*c_f2/total)))%256;
+                       g = ((int)((c_in1.g()*c_f1/total+c_in2.g()*c_f2/total)))%256;
+                       b = ((int)((c_in1.b()*c_f1/total+c_in2.b()*c_f2/total)))%256;
+                       set_color(RGB(r,g,b));
+               } else {
+                       // Veo que entrada trae color
+                       if (c_f1 != 0) {
+                               set_color( c_in1 );
+                       }
+                       if (c_f2 != 0) {
+                               set_color( c_in2 );
+                       }
+               }
+               return;
+       }
        // Seteo mi actualizar en true para evitar entrar de nuevo
        // FIXME : 99999 == INFINITO!!
        actual_flow = 99999;
        // Seteo mi actualizar en true para evitar entrar de nuevo
        // FIXME : 99999 == INFINITO!!
        actual_flow = 99999;
@@ -111,41 +145,8 @@ void Union::update(int dir)
 
 void Union::simulate()
 {
 
 void Union::simulate()
 {
-       RGB c_in1, c_in2;
-       unsigned r=0,g=0,b=0;
-       float c_f1, c_f2; // para ver los flujos de cada uno
-
-       if (!updated) {
-               return;
-       }
-       std::list<IConector *>::iterator i = in_list.begin();
-       if (i != in_list.end()) {
-               PlantItem *o = (PlantItem *)(*i);
-               c_in1 = o->get_color();
-               c_f1 = o->get_actual_flow();
-               i++;
-               o = (PlantItem *)(*i);
-               c_in2 = o->get_color();
-               c_f2 = o->get_actual_flow();
-       }
+       if (!updated) return;
 
 
-       set_color( RGB(r,g,b) );
-       if ((c_f1 != 0) && (c_f2 != 0)) {
-               // Si ambas entradas traen flujo, sumo sus colores
-               r = ((c_in1.r()+c_in2.r())/2)%256;
-               g = ((c_in1.g()+c_in2.g())/2)%256;
-               b = ((c_in1.b()+c_in2.b())/2)%256;
-               set_color(RGB(r,g,b));
-       } else {
-               // Veo que entrada trae color
-               if (c_f1 != 0) {
-                       set_color( c_in1 );
-               }
-               if (c_f2 != 0) {
-                       set_color( c_in2 );
-               }
-       }
-               
 #ifdef DEBUG
        std::cout << name << "::Flujo actual = " << actual_flow << std::endl;
 #endif
 #ifdef DEBUG
        std::cout << name << "::Flujo actual = " << actual_flow << std::endl;
 #endif