]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blob - Constructor/src/cistern.cpp
628d69fa78529190d4263e72be50a606e8f1cb35
[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                                 tmp_line.logic_id =  workplace->get_logic_item(CItem::gate_id)->get_id();
57                                 workplace->get_logic_item(CItem::gate_id)->set_out_connected(true);
58                                 tmp_line.store_id = ID;
59                                 workplace->lista_lineas_out.push_back(tmp_line);
60                                 workplace->queue_draw();
61                         } else if (detect_click_position((int)event->x, (int)event->y) == OUT )  { 
62                                 if (dynamic_cast<Not *>(workplace->get_logic_item(CItem::gate_id))) {
63                                         if ( !dynamic_cast<Not *>(workplace->get_logic_item(CItem::gate_id))->get_out_logic_connect()) {
64                                                 workplace->get_logic_item(CItem::gate_id)->set_in_connected(true);
65                                                 tmp_line.logic_id =  CItem::gate_id;
66                                                 tmp_line.store_id = ID;
67                                                 workplace->lista_lineas_out.push_back(tmp_line);
68                                                 workplace->queue_draw();
69                                         }
70                                 } else {
71                                         tmp_line.logic_id =  CItem::gate_id;
72                                         tmp_line.store_id = ID;
73                                         workplace->lista_lineas_out.push_back(tmp_line);
74                                         workplace->queue_draw();
75                                 }                                       
76                         }
77                         CItem::gate_id = -1;
78                 }
79                 char f[10], g[10];
80                 Glib::ustring text;
81                 sprintf(f,"%.1f  ",capacidad);
82                 sprintf(g,"%.1f",contenido_inicial);
83                 text = name+"  Capacidad: ";
84                 text += f;
85                 text += "Contenido Inicial: ";
86                 text += g;
87                 status_bar->push ( text, 0);            
88         }
89         
90         if ((event->type == GDK_BUTTON_PRESS) && ( event->button ==2)){
91                 image = null; 
92                 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);
93                 imgActual++;
94                 switch (imgActual) {
95                         case 1:
96                                 image = imageO;
97                                 in_x = x + image->get_width()-5;
98                                 in_y = y + 16;
99                                 out_x = x+16;
100                                 out_y = y + image->get_height();
101                                 break;
102                         default: 
103                                 imgActual = 0;
104                                 image = imageE;                 
105                                 in_x = x+5;
106                                 in_y = y+16;
107                                 out_x = x + image->get_width() -16;
108                                 out_y = y + image->get_height();
109                 }
110                 set_size_request(image->get_width(),image->get_height());
111                 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);
112         }
113         
114         if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 3)){
115                 menu_popup.popup(event->button, event->time);
116                  return true; //It has been handled.
117         }
118         
119         if ((event->type == GDK_2BUTTON_PRESS) && (event->button ==1)){
120                 cistern_pty_wnd->spin_capacidad->set_value( capacidad );
121                 cistern_pty_wnd->spin_inicial->set_value( contenido_inicial );
122                 cistern_pty_wnd->txt_cistern_name->set_text( name );
123                 cistern_pty_wnd->show();
124         }               
125         workplace->queue_draw();
126         return true;
127 }
128
129 void Cistern::on_menu_popup_rotar()
130 {
131         GdkEventButton event; 
132                 event.type = GDK_BUTTON_PRESS;
133                 event.button = 2;
134         Cistern::on_button_press_event(&event);
135 }
136
137 void Cistern::on_menu_popup_propiedades()
138 {
139         GdkEventButton event; 
140                 event.type = GDK_2BUTTON_PRESS;
141                 event.button = 1;
142         Cistern::on_button_press_event(&event);
143 }
144
145 void Cistern::set_capacidad(double _cap)
146 {
147         capacidad = _cap;
148 }
149
150 void Cistern::set_liquid_color(Gdk::Color _color)
151 {
152         liquid_color = _color;
153 }
154
155 void Cistern::set_contenido_inicial(double _ini)
156 {
157         contenido_inicial = _ini;
158 }
159
160 double Cistern::get_capacidad()
161 {
162         return capacidad;
163 }
164
165 double Cistern::get_contenido_inicial()
166 {
167         return contenido_inicial;
168 }
169
170 Gdk::Color Cistern::get_liquid_color()
171 {
172         return liquid_color;
173 }
174
175 void Cistern::save(FILE *archivo)
176 {
177         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];
178         Glib::ustring  con0, con1;
179         con0 = "\t\t\t<entrada>"+get_other_name(connect_vec[0].id_dest)+"</entrada>\n";
180         con1 = "\t\t\t<salida>"+get_other_name(connect_vec[1].id_dest)+"</salida>\n";
181         sprintf(c_red,"\t\t\t<rojo>%d</rojo>\n",liquid_color.get_red());
182         sprintf(c_green,"\t\t\t<verde>%d</verde>\n",liquid_color.get_green());
183         sprintf(c_blue,"\t\t\t<azul>%d</azul>\n",liquid_color.get_blue());
184         sprintf(c_x,"\t\t<x>%d</x>\n",x);
185         sprintf(c_y,"\t\t<y>%d</y>\n",y);
186         sprintf(c_id,"%d",ID);
187         sprintf(c_cap,"\t\t<capacidad>%.2f</capacidad>\n", capacidad);
188         sprintf(c_ini,"\t\t<inicial>%.2f</inicial>\n", contenido_inicial);
189         sprintf(c_img,"\t\t<orientacion>%d</orientacion>\n",imgActual);
190         Glib::ustring dato;
191         dato = "\t<tanque nombre=\""+name+"\" id=\"";
192         dato += c_id;
193         dato += "\">\n";
194         dato += c_cap;
195         dato += c_ini;
196         dato += "\t\t<color>\n";
197         dato += c_red;
198         dato += c_green;
199         dato += c_blue;
200         dato += "\t\t</color>\n";
201         dato += "\t\t<conector>\n"+con0+con1+"\t\t</conector>\n";
202         dato += c_img;
203         dato += c_x; 
204         dato += c_y;
205         dato += "\t</tanque>\n";
206         fprintf(archivo,dato.c_str());  
207 }
208
209 bool Cistern::check_connection()
210 {
211         CItem * _item, *_item1;
212         ConnectorType temp0, temp1;
213         switch (get_img_actual()) {
214                 case 0:
215                         temp0 = is_other_connection_area( get_position_x() + 16, get_position_y() - 5, &_item);//arriba - entrada
216                         temp1 = is_other_connection_area( get_position_x()+get_image()->get_width() + 5 , get_position_y()+get_image()->get_height() -16, &_item1);//abajo - salida             
217                         break;
218                 case 1:
219                         temp0 = is_other_connection_area( get_position_x()+get_image()->get_width() - 16, get_position_y() - 5, &_item);//arriba - entrada
220                         temp1 = is_other_connection_area( get_position_x() -5, get_position_y()+get_image()->get_height()-16, &_item1); //abajo - salida
221         }
222         if (temp0 == OUT && temp1 == IN) { 
223                 connect_vec[0].id_dest = _item->get_id();
224                 connect_vec[1].id_dest = _item1->get_id();
225                 return (is_connected = true);
226         }
227         return is_connected;
228 }
229
230 ConnectorType Cistern::get_connector_type(int _a, int _b)
231 {
232         switch (imgActual) {
233                 case 0: if ( (_a <= x+22)&&(_a>=x+10)&&(_b<=y+10)&&(_b > y) )//arriba
234                                                 return connect_vec[0].type;
235                                         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
236                                                 return connect_vec[1].type;
237                                         break;
238                 case 1: if ( (_a <= x+image->get_width()-10)&&(_a>=x+image->get_width()-22)&&(_b<=y+10)&&(_b > y) )//arriba
239                                                 return connect_vec[0].type;
240                                         if ( (_a <= x +10)&&(_a > x)&&(_b<=y+image->get_height()-10)&&(_b >=y+image->get_height()-22) )//abajo
241                                                 return connect_vec[1].type;
242         }
243         return UNDEF;
244 }
245
246 void Cistern::set_default_connector()
247 {
248         connect_vec[0].type = IN;
249         connect_vec[1].type = OUT;
250 }
251
252 void Cistern::get_in_logic_connect_position(int& _a, int& _b)
253 {
254         _a = in_x;
255         _b = in_y;
256 }
257
258 void Cistern::get_out_logic_connect_position(int& _a, int& _b)
259 {
260         _a = out_x;
261         _b = out_y;
262 }
263         
264 ConnectorType Cistern::detect_click_position(int _a, int _b)
265 {
266         switch(imgActual) {
267                 case 0:
268                         if ( (_a<=32) &&(_a>=0)&&(_b<=32)&&(_b>=0) )
269                                 return IN;
270                         if ( (_a<=image->get_width())&&(_a>=image->get_width()-32)&&(_b<=image->get_height())&&(_b>=image->get_height()-32) )
271                                 return OUT;
272                         break;
273                 case 1:
274                         if ( (_a<=image->get_width()) &&(_a>=image->get_width()-32)&&(_b<=32)&&(_b>=0) )
275                                 return IN;
276                         if ( (_a<=32)&&(_a>=0)&&(_b<=image->get_height())&&(_b>=image->get_height()-32) )
277                                 return OUT;
278                 }
279                 return UNDEF;
280 }
281                 
282 void Cistern::update_logic_position()
283 {
284         switch (imgActual) {
285                 case 1:
286                         in_x = x + image->get_width()-5;
287                         in_y = y + 16;
288                         out_x = x+16;
289                         out_y = y + image->get_height();
290                         break;
291                 case 0: 
292                         in_x = x+5;
293                         in_y = y+16;
294                         out_x = x + image->get_width() -16;
295                         out_y = y + image->get_height();
296         }
297 }
298
299 void Cistern::draw_connectors()
300 {
301         if ( in_x != -1 ) {
302                 Glib::RefPtr<Gdk::Window> window = get_window();
303                 gc->set_foreground(blue);
304                 window->draw_rectangle(gc, 1, in_x-5-x, in_y-y, 10, 10);
305                 window->draw_rectangle(gc, 1, out_x-5-x, out_y-y-10, 10, 10);
306                 queue_draw();
307         }
308 }