5 using namespace PlaQui::Model;
7 Union::Union(const std::string &_name):Transport(_name)
22 void Union::recieve_msg(int msg, IConector *who, void *data)
26 // Verifico si esta conectado a mi entrada o a mi salida
27 std::list<IConector *>::iterator i;
28 for(i=in_list.begin(); i!=in_list.end(); i++) {
29 if ((*i) == who) pos = IN;
32 case MSG_QUERY_MAX_FLOW_OUT: {
33 // Me preguntan por el flujo máximo.
34 // Primero me actualizo, y luego respondo
35 float m_data = *((float *)data)*2;
39 float tmp = actual_flow/2.0f;
40 who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &tmp);
47 who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &tmp);
48 if (in_on_zero == 1) {
52 tmp = actual_flow/2.0f;
54 send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &tmp);
58 actual_flow = (m_data<actual_flow)?m_data:actual_flow;
59 actual_flow = (actual_flow<max_flow)?actual_flow:max_flow;
63 actual_flow = actual_flow/2.0f;
65 actual_flow = max_flow/2.0f;
70 send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &actual_flow);
71 tmp = (in_on_zero==0)?actual_flow/2.0f:actual_flow;
72 who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &tmp);
75 if (pos == IN) in_ready++;
78 case MSG_RESPONSE_MAX_FLOW: {
79 float max = *((float *)data);
81 if (max < actual_flow) actual_flow = max;
82 if (in_on_zero == 2) actual_flow = 0;
84 if (((2*max) < actual_flow) && (max != 0)) {
86 if (in_on_zero == 1) actual_flow /= 2.0;
91 case MSG_RESPONSE_COLOR:
93 color1 = *((RGB *)data);
94 entrada1 = static_cast<PlantItem *>(who);
95 flow1 = entrada1->get_actual_flow();
97 } else if ((in_colors == 1) && (entrada1 != who)) {
98 color2 = *((RGB *)data);
99 flow2 = static_cast<PlantItem *>(who)->get_actual_flow();
101 if (color1 == color2) {
102 std::cout << "TODO MAL" << std::endl << std::endl;
105 /* Ya tengo mis 2 colores, los sumo */
110 float suma = flow1+flow2;
112 r = (int)(color1.r()*flow1/suma + color2.r()*flow2/suma)/n;
113 g = (int)(color1.g()*flow1/suma + color2.g()*flow2/suma)/n;
114 b = (int)(color1.b()*flow1/suma + color2.b()*flow2/suma)/n;
118 set_color(RGB(r,g,b));
120 set_color(RGB(0,0,0));
122 color_updated = true;
126 Transport::recieve_msg(msg, who, data);
130 void Union::update(int dir)
132 // Si ya me actualice, no lo tengo que hacer de nuevo
135 // Seteo mi actualizar en true para evitar entrar de nuevo
136 // FIXME : 99999 == INFINITO!!
141 send_msg(IN, MSG_QUERY_MAX_FLOW_IN, (void *)&max_flow);
144 send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, (void *)&max_flow);
148 void Union::simulate()
150 if (!updated) return;
153 std::cout << name << "::Flujo actual = " << actual_flow << std::endl;
156 color_updated = false;
159 color_updated = false;