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