]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blob - Constructor/src/cistern.cpp
no se pueden repetir los nombres de los items
[z.facultad/75.42/plaqui.git] / Constructor / src / cistern.cpp
1 #include "cistern.h"
2 #include "cisternptywnd.h"
3 #include "not.h"
4
5 Cistern::Cistern(int orientacion)
6 {
7         in_x = x+5;
8         in_y = y+16;
9         out_x = x + 48;
10         out_y = y + 64;
11         capacidad = 100.0;
12         contenido_inicial = 0;
13         imageE = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/tanque_e.png");
14         imageO = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/tanque_o.png");
15         null = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/tanque_null.png");
16         imgActual = orientacion;
17         switch (imgActual) {
18                 case 1:
19                         image = imageO;
20                         break;
21                 default: 
22                         imgActual = 0;
23                         image = imageE;                 
24         }
25         set_size_request(image->get_width(), image->get_height());
26
27         Glib::RefPtr<Gnome::Glade::Xml> ref = Gnome::Glade::Xml::create(PACKAGE_DATA_DIR"/plaqui-constructor/dialogs/constructor.glade", "cistern_pty_wnd");
28         ref->get_widget_derived("cistern_pty_wnd",cistern_pty_wnd);
29         cistern_pty_wnd->cistern = this;
30         cistern_pty_wnd->set_title("Propiedades del Tanque");   
31         name = "tanque";
32         
33         Connector temp;
34         temp.id_dest = -1;
35         temp.type = IN;
36         connect_vec.push_back(temp); // entrada arriba
37         temp.type = OUT;
38         connect_vec.push_back(temp); // entrada abajo
39 }
40
41 Cistern::~Cistern()
42 {
43 }
44
45 bool Cistern::on_button_press_event(GdkEventButton *event)
46 {
47         GdkEventExpose e;
48         t_line tmp_line;
49         if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 1)) {
50                 WorkPlace::pointed = ID;
51                 list_pointed->push_back(name);
52                 combo_entry->set_popdown_strings(*list_pointed);
53                 combo_entry->get_entry()->set_text (name);
54                 if (CItem::logic_connect && CItem::gate_id != -1) {
55                         if ( detect_click_position((int)event->x, (int)event->y) == IN){
56                                 if (dynamic_cast<Not *>(workplace->get_logic_item(CItem::gate_id))) {
57                                         if ( !dynamic_cast<Not *>(workplace->get_logic_item(CItem::gate_id))->get_out_logic_connect()) {
58                                                 workplace->get_logic_item(CItem::gate_id)->set_in_connected(true);
59                                                 tmp_line.logic_id =  CItem::gate_id;
60                                                 tmp_line.cistern_out1 = true;
61                                                 tmp_line.store_id = ID;
62                                                 workplace->lista_lineas_out.push_back(tmp_line);
63                                                 workplace->queue_draw();
64                                         }
65                                 } else {
66                                                 tmp_line.logic_id =  CItem::gate_id;
67                                                 tmp_line.cistern_out1 = true;
68                                                 tmp_line.store_id = ID;
69                                                 workplace->lista_lineas_out.push_back(tmp_line);
70                                                 workplace->queue_draw();                                        
71                                 }
72                         } else if (detect_click_position((int)event->x, (int)event->y) == OUT )  { 
73                                 if (dynamic_cast<Not *>(workplace->get_logic_item(CItem::gate_id))) {
74                                         if ( !dynamic_cast<Not *>(workplace->get_logic_item(CItem::gate_id))->get_in_logic_connect()) {
75                                                 workplace->get_logic_item(CItem::gate_id)->set_in_connected(true);
76                                                 tmp_line.logic_id =  CItem::gate_id;
77                                                 tmp_line.store_id = ID;
78                                                 tmp_line.cistern_out1 = false;
79                                                 workplace->lista_lineas_out.push_back(tmp_line);
80                                                 workplace->queue_draw();
81                                         }
82                                 } else {
83                                         tmp_line.logic_id =  CItem::gate_id;
84                                         tmp_line.store_id = ID;
85                                         tmp_line.cistern_out1 = false;
86                                         workplace->lista_lineas_out.push_back(tmp_line);
87                                         workplace->queue_draw();
88                                 }                                       
89                         }
90                         CItem::gate_id = -1;
91                 }
92                 char f[20], g[25];
93                 Glib::ustring text;
94                 sprintf(f,"  Capacidad: %.1f  ",capacidad);
95                 sprintf(g,"Contenido Inicial: %.1f",contenido_inicial);
96                 text = name+ f;
97                 text += g;
98                 status_bar->push ( text, 0);            
99         }
100         
101         if ((event->type == GDK_BUTTON_PRESS) && ( event->button ==2)){
102                 image = null; 
103                 image->render_to_drawable(get_window(),get_style()->get_black_gc(),0,0,0,0,image->get_width(),image->get_height(),Gdk::RGB_DITHER_NONE,0,0);
104                 imgActual++;
105                 switch (imgActual) {
106                         case 1:
107                                 image = imageO;
108                                 in_x = x + image->get_width()-5;
109                                 in_y = y + 16;
110                                 out_x = x+16;
111                                 out_y = y + image->get_height();
112                                 break;
113                         default: 
114                                 imgActual = 0;
115                                 image = imageE;                 
116                                 in_x = x+5;
117                                 in_y = y+16;
118                                 out_x = x + image->get_width() -16;
119                                 out_y = y + image->get_height();
120                 }
121                 set_size_request(image->get_width(),image->get_height());
122                 image->render_to_drawable(get_window(),get_style()->get_black_gc(),0,0,0,0,image->get_width(),image->get_height(),Gdk::RGB_DITHER_NONE,0,0);
123         }
124         
125         if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 3)){
126                 menu_popup.popup(event->button, event->time);
127                  return true; //It has been handled.
128         }
129         
130         if ((event->type == GDK_2BUTTON_PRESS) && (event->button ==1)){
131                 cistern_pty_wnd->spin_capacidad->set_value( capacidad );
132                 cistern_pty_wnd->spin_inicial->set_value( contenido_inicial );
133                 cistern_pty_wnd->txt_cistern_name->set_text( name );
134                 cistern_pty_wnd->show();
135         }               
136         workplace->queue_draw();
137         return true;
138 }
139
140 void Cistern::on_menu_popup_rotar()
141 {
142         GdkEventButton event; 
143                 event.type = GDK_BUTTON_PRESS;
144                 event.button = 2;
145         Cistern::on_button_press_event(&event);
146 }
147
148 void Cistern::on_menu_popup_propiedades()
149 {
150         GdkEventButton event; 
151                 event.type = GDK_2BUTTON_PRESS;
152                 event.button = 1;
153         Cistern::on_button_press_event(&event);
154 }
155
156 void Cistern::set_capacidad(double _cap)
157 {
158         capacidad = _cap;
159 }
160
161 void Cistern::set_liquid_color(Gdk::Color _color)
162 {
163         liquid_color = _color;
164 }
165
166 void Cistern::set_contenido_inicial(double _ini)
167 {
168         contenido_inicial = _ini;
169 }
170
171 double Cistern::get_capacidad()
172 {
173         return capacidad;
174 }
175
176 double Cistern::get_contenido_inicial()
177 {
178         return contenido_inicial;
179 }
180
181 Gdk::Color Cistern::get_liquid_color()
182 {
183         return liquid_color;
184 }
185
186 void Cistern::save(FILE *archivo)
187 {
188         char c_id[50], c_cap[50], c_x[50], c_y[50], c_img[50], c_ini[50], c_red[50], c_green[50], c_blue[50];
189         Glib::ustring  con0, con1;
190         con0 = "\t\t\t<entrada>"+get_other_name(connect_vec[0].id_dest)+"</entrada>\n";
191         con1 = "\t\t\t<salida>"+get_other_name(connect_vec[1].id_dest)+"</salida>\n";
192         sprintf(c_red,"\t\t\t<rojo>%d</rojo>\n",liquid_color.get_red());
193         sprintf(c_green,"\t\t\t<verde>%d</verde>\n",liquid_color.get_green());
194         sprintf(c_blue,"\t\t\t<azul>%d</azul>\n",liquid_color.get_blue());
195         sprintf(c_x,"\t\t<x>%d</x>\n",x);
196         sprintf(c_y,"\t\t<y>%d</y>\n",y);
197         sprintf(c_id,"%d",ID);
198         sprintf(c_cap,"\t\t<capacidad>%.2f</capacidad>\n", capacidad);
199         sprintf(c_ini,"\t\t<inicial>%.2f</inicial>\n", contenido_inicial);
200         sprintf(c_img,"\t\t<orientacion>%d</orientacion>\n",imgActual);
201         Glib::ustring dato;
202         dato = "\t<tanque nombre=\""+name+"\" id=\"";
203         dato += c_id;
204         dato += "\">\n";
205         dato += c_cap;
206         dato += c_ini;
207         dato += "\t\t<color>\n";
208         dato += c_red;
209         dato += c_green;
210         dato += c_blue;
211         dato += "\t\t</color>\n";
212         dato += "\t\t<conector>\n"+con0+con1+"\t\t</conector>\n";
213         dato += c_img;
214         dato += c_x; 
215         dato += c_y;
216         dato += "\t</tanque>\n";
217         fprintf(archivo,dato.c_str());  
218 }
219
220 bool Cistern::check_connection()
221 {
222         CItem * _item, *_item1;
223         ConnectorType temp0, temp1;
224         switch (get_img_actual()) {
225                 case 0:
226                         temp0 = is_other_connection_area( get_position_x() + 16, get_position_y() - 5, &_item);//arriba - entrada
227                         temp1 = is_other_connection_area( get_position_x()+get_image()->get_width() + 5 , get_position_y()+get_image()->get_height() -16, &_item1);//abajo - salida             
228                         break;
229                 case 1:
230                         temp0 = is_other_connection_area( get_position_x()+get_image()->get_width() - 16, get_position_y() - 5, &_item);//arriba - entrada
231                         temp1 = is_other_connection_area( get_position_x() -5, get_position_y()+get_image()->get_height()-16, &_item1); //abajo - salida
232         }
233         if (temp0 == OUT && temp1 == IN) { 
234                 connect_vec[0].id_dest = _item->get_id();
235                 connect_vec[1].id_dest = _item1->get_id();
236                 return (is_connected = true);
237         }
238         return is_connected;
239 }
240
241 ConnectorType Cistern::get_connector_type(int _a, int _b)
242 {
243         switch (imgActual) {
244                 case 0: if ( (_a <= x+22)&&(_a>=x+10)&&(_b<=y+10)&&(_b > y) )//arriba
245                                                 return connect_vec[0].type;
246                                         if ( (_a <= x+image->get_width()-1)&&(_a >=x+image->get_width()-10)&&(_b<=y+image->get_height()-10)&&(_b >=y+image->get_height()-22) )//abajo
247                                                 return connect_vec[1].type;
248                                         break;
249                 case 1: if ( (_a <= x+image->get_width()-10)&&(_a>=x+image->get_width()-22)&&(_b<=y+10)&&(_b > y) )//arriba
250                                                 return connect_vec[0].type;
251                                         if ( (_a <= x +10)&&(_a > x)&&(_b<=y+image->get_height()-10)&&(_b >=y+image->get_height()-22) )//abajo
252                                                 return connect_vec[1].type;
253         }
254         return UNDEF;
255 }
256
257 void Cistern::set_default_connector()
258 {
259         connect_vec[0].type = IN;
260         connect_vec[1].type = OUT;
261 }
262
263 void Cistern::get_in_logic_connect_position(int& _a, int& _b)
264 {
265         _a = in_x;
266         _b = in_y;
267 }
268
269 void Cistern::get_out_logic_connect_position(int& _a, int& _b)
270 {
271         _a = out_x;
272         _b = out_y;
273 }
274         
275 ConnectorType Cistern::detect_click_position(int _a, int _b)
276 {
277         switch(imgActual) {
278                 case 0:
279                         if ( (_a<=32) &&(_a>=0)&&(_b<=32)&&(_b>=0) )
280                                 return IN;
281                         if ( (_a<=image->get_width())&&(_a>=image->get_width()-32)&&(_b<=image->get_height())&&(_b>=image->get_height()-32) )
282                                 return OUT;
283                         break;
284                 case 1:
285                         if ( (_a<=image->get_width()) &&(_a>=image->get_width()-32)&&(_b<=32)&&(_b>=0) )
286                                 return IN;
287                         if ( (_a<=32)&&(_a>=0)&&(_b<=image->get_height())&&(_b>=image->get_height()-32) )
288                                 return OUT;
289                 }
290                 return UNDEF;
291 }
292                 
293 void Cistern::update_logic_position()
294 {
295         switch (imgActual) {
296                 case 1:
297                         in_x = x + image->get_width()-5;
298                         in_y = y + 16;
299                         out_x = x+16;
300                         out_y = y + image->get_height();
301                         break;
302                 case 0: 
303                         in_x = x+5;
304                         in_y = y+16;
305                         out_x = x + image->get_width() -16;
306                         out_y = y + image->get_height();
307         }
308 }
309
310 void Cistern::draw_connectors()
311 {
312         if ( in_x != -1 ) {
313                 Glib::RefPtr<Gdk::Window> window = get_window();
314                 gc->set_foreground(blue);
315                 window->draw_rectangle(gc, 1, in_x-5-x, in_y-y, 10, 10);
316                 window->draw_rectangle(gc, 1, out_x-5-x, out_y-y-10, 10, 10);
317                 queue_draw();
318         }
319 }