X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/ee2cb3d6c26ae319d20bde28f415393e96611ece..8991f15558a6b0fbcfd588abe073f6f0537a7f8d:/Constructor/src/cistern.cpp diff --git a/Constructor/src/cistern.cpp b/Constructor/src/cistern.cpp index d39a66c..7fd6108 100644 --- a/Constructor/src/cistern.cpp +++ b/Constructor/src/cistern.cpp @@ -1,8 +1,17 @@ #include "cistern.h" #include "cisternptywnd.h" +#include "not.h" Cistern::Cistern(int orientacion) { + in_x = x+5; + in_y = y+16; + out_x = x + 48; + out_y = y + 64; + capacidad = 100.0; + contenido_inicial = 0; + flotante_inf = 20; + flotante_sup = 80; imageE = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/tanque_e.png"); imageO = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/tanque_o.png"); null = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/tanque_null.png"); @@ -28,7 +37,7 @@ Cistern::Cistern(int orientacion) temp.type = IN; connect_vec.push_back(temp); // entrada arriba temp.type = OUT; - connect_vec.push_back(temp); // salida abajo + connect_vec.push_back(temp); // entrada abajo } Cistern::~Cistern() @@ -40,14 +49,55 @@ bool Cistern::on_button_press_event(GdkEventButton *event) GdkEventExpose e; t_line tmp_line; if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 1)) { - combo_entry->set_text(name); WorkPlace::pointed = ID; - if (CItem::logic_connect) { - tmp_line.logic = workplace->get_logic_item(CItem::quien); - tmp_line.store = this; - workplace->lista_lineas.push_back(tmp_line); - workplace->on_expose_event(&e); + list_pointed->push_back(name); + combo_entry->set_popdown_strings(*list_pointed); + combo_entry->get_entry()->set_text (name); + if (CItem::logic_connect && CItem::gate_id != -1) { + if ( detect_click_position((int)event->x, (int)event->y) == IN){ + if (dynamic_cast(workplace->get_logic_item(CItem::gate_id))) { + if ( !dynamic_cast(workplace->get_logic_item(CItem::gate_id))->get_in_logic_connect()) { + workplace->get_logic_item(CItem::gate_id)->set_in_connected(true); + tmp_line.logic_id = CItem::gate_id; + tmp_line.cistern_out1 = true; + tmp_line.store_id = ID; + workplace->lista_lineas_out.push_back(tmp_line); + workplace->queue_draw(); + } + } else { + tmp_line.logic_id = CItem::gate_id; + tmp_line.cistern_out1 = true; + tmp_line.store_id = ID; + workplace->lista_lineas_out.push_back(tmp_line); + workplace->queue_draw(); + } + } else if (detect_click_position((int)event->x, (int)event->y) == OUT ) { + if (dynamic_cast(workplace->get_logic_item(CItem::gate_id))) { + if ( !dynamic_cast(workplace->get_logic_item(CItem::gate_id))->get_in_logic_connect()) { + workplace->get_logic_item(CItem::gate_id)->set_in_connected(true); + tmp_line.logic_id = CItem::gate_id; + tmp_line.store_id = ID; + tmp_line.cistern_out1 = false; + workplace->lista_lineas_out.push_back(tmp_line); + workplace->queue_draw(); + } + } else { + tmp_line.logic_id = CItem::gate_id; + tmp_line.store_id = ID; + tmp_line.cistern_out1 = false; + workplace->lista_lineas_out.push_back(tmp_line); + workplace->queue_draw(); + } + } + CItem::gate_id = -1; } + char f[20], g[25]; + Glib::ustring text; + sprintf(f," Capacidad: %.1f ",capacidad); + sprintf(g,"Contenido Inicial: %.1f",contenido_inicial); + text = name+ f; + text += g; + status_bar->push ( text, 0); } if ((event->type == GDK_BUTTON_PRESS) && ( event->button ==2)){ @@ -57,10 +107,18 @@ bool Cistern::on_button_press_event(GdkEventButton *event) switch (imgActual) { case 1: image = imageO; + in_x = x + image->get_width()-5; + in_y = y + 16; + out_x = x+16; + out_y = y + image->get_height(); break; default: imgActual = 0; image = imageE; + in_x = x+5; + in_y = y+16; + out_x = x + image->get_width() -16; + out_y = y + image->get_height(); } set_size_request(image->get_width(),image->get_height()); 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); @@ -75,9 +133,11 @@ bool Cistern::on_button_press_event(GdkEventButton *event) cistern_pty_wnd->spin_capacidad->set_value( capacidad ); cistern_pty_wnd->spin_inicial->set_value( contenido_inicial ); cistern_pty_wnd->txt_cistern_name->set_text( name ); + cistern_pty_wnd->spin_flot_inf->set_value ( flotante_inf ); + cistern_pty_wnd->spin_flot_sup->set_value ( flotante_sup ); cistern_pty_wnd->show(); } - workplace->on_expose_event(&e); + workplace->queue_draw(); return true; } @@ -112,6 +172,17 @@ void Cistern::set_contenido_inicial(double _ini) contenido_inicial = _ini; } + +void Cistern::set_flotante_sup(double _s) +{ + flotante_sup = _s; +} + +void Cistern::set_flotante_inf(double _i) +{ + flotante_inf = _i; +} + double Cistern::get_capacidad() { return capacidad; @@ -122,6 +193,16 @@ double Cistern::get_contenido_inicial() return contenido_inicial; } +double Cistern::get_flotante_sup() +{ + return flotante_sup; +} + +double Cistern::get_flotante_inf() +{ + return flotante_inf; +} + Gdk::Color Cistern::get_liquid_color() { return liquid_color; @@ -129,7 +210,7 @@ Gdk::Color Cistern::get_liquid_color() void Cistern::save(FILE *archivo) { - 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]; + 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], c_float_s[50], c_float_i[50]; Glib::ustring con0, con1; con0 = "\t\t\t"+get_other_name(connect_vec[0].id_dest)+"\n"; con1 = "\t\t\t"+get_other_name(connect_vec[1].id_dest)+"\n"; @@ -141,7 +222,9 @@ void Cistern::save(FILE *archivo) sprintf(c_id,"%d",ID); sprintf(c_cap,"\t\t%.2f\n", capacidad); sprintf(c_ini,"\t\t%.2f\n", contenido_inicial); - sprintf(c_img,"\t\t%d\n",imgActual); + sprintf(c_float_s,"\t\t%.0f\n",flotante_sup); + sprintf(c_float_i,"\t\t\t%.0f\n",flotante_inf); + sprintf(c_img,"\t\t\t%d\n",imgActual); Glib::ustring dato; dato = "\t\n"; + dato += "\t\t\n"; + dato += c_float_s; + dato += c_float_i; + dato += "\t\t\n"; dato += c_img; dato += c_x; dato += c_y; @@ -204,15 +291,60 @@ void Cistern::set_default_connector() connect_vec[1].type = OUT; } -void Cistern::get_logic_connect_position(int& _a, int& _b) +void Cistern::get_in_logic_connect_position(int& _a, int& _b) +{ + _a = in_x; + _b = in_y; +} + +void Cistern::get_out_logic_connect_position(int& _a, int& _b) +{ + _a = out_x; + _b = out_y; +} + +ConnectorType Cistern::detect_click_position(int _a, int _b) { switch(imgActual) { - case 0: - _a = x; - _b = y + 10; + case 0: + if ( (_a<=32) &&(_a>=0)&&(_b<=32)&&(_b>=0) ) + return IN; + if ( (_a<=image->get_width())&&(_a>=image->get_width()-32)&&(_b<=image->get_height())&&(_b>=image->get_height()-32) ) + return OUT; + break; + case 1: + if ( (_a<=image->get_width()) &&(_a>=image->get_width()-32)&&(_b<=32)&&(_b>=0) ) + return IN; + if ( (_a<=32)&&(_a>=0)&&(_b<=image->get_height())&&(_b>=image->get_height()-32) ) + return OUT; + } + return UNDEF; +} + +void Cistern::update_logic_position() +{ + switch (imgActual) { + case 1: + in_x = x + image->get_width()-5; + in_y = y + 16; + out_x = x+16; + out_y = y + image->get_height(); break; - case 1: - _a = x +image->get_width(); - _b = y + 10; + case 0: + in_x = x+5; + in_y = y+16; + out_x = x + image->get_width() -16; + out_y = y + image->get_height(); + } +} + +void Cistern::draw_connectors() +{ + if ( in_x != -1 ) { + Glib::RefPtr window = get_window(); + gc->set_foreground(blue); + window->draw_rectangle(gc, 1, in_x-5-x, in_y-y, 10, 10); + window->draw_rectangle(gc, 1, out_x-5-x, out_y-y-10, 10, 10); + queue_draw(); } }