X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/f1f01b21410b676a9c35c93251d5739bb65c711d..dc805abad5bf3fee5e72f42fec64bdf9fe9dda4e:/Constructor/src/not.cpp diff --git a/Constructor/src/not.cpp b/Constructor/src/not.cpp index 2fc63e2..ff076c2 100644 --- a/Constructor/src/not.cpp +++ b/Constructor/src/not.cpp @@ -1,4 +1,5 @@ #include "not.h" +#include "cistern.h" Not::Not(int orientacion) { @@ -42,7 +43,6 @@ Not::Not(int orientacion) } set_size_request(image->get_width(), image->get_height()); name = "not"; - menulist.push_back( Gtk::Menu_Helpers::ImageMenuElem("Conectar", menu_image_linea,SigC::slot(*this, &CItem::on_menu_popup_conectar) ) ) ; } Not::~Not() @@ -51,22 +51,38 @@ Not::~Not() bool Not::on_button_press_event(GdkEventButton *event) { - if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 1)) { - if ( CItem::logic_connect ) { + WorkPlace::pointed = ID; + t_line tmp_line; + if (CItem::logic_connect) { + if (CItem::gate_id != -1) { + if ( detect_click_position((int)event->x, (int)event->y) == IN && !in_connected && !workplace->get_logic_item(CItem::gate_id)->get_out_logic_connect()) { + tmp_line.logic_id = CItem::gate_id; + workplace->get_logic_item(CItem::gate_id)->set_out_connected(true); + set_in_connected(true); + tmp_line.store_id = ID; + workplace->lista_lineas_logic.push_back(tmp_line); + workplace->queue_draw(); + CItem::gate_id = -1; + } + } else + CItem::gate_id = ID; if ( detect_click_position((int)event->x, (int)event->y ) == OUT && !out_connected ) { CItem::gate_id = ID; - WorkPlace::pointed = ID; } if ( detect_click_position((int)event->x, (int)event->y ) == IN && !in_connected) { CItem::gate_id = ID; - WorkPlace::pointed = ID; } } list_pointed->push_back(name); combo_entry->set_popdown_strings(*list_pointed); combo_entry->get_entry()->set_text (name); workplace->queue_draw(); + char f[40]; + Glib::ustring text; + sprintf(f," Conector OUT = %d Conector IN = %d",out_connected, in_connected); + text = name+f; + status_bar->push ( text, 0); } if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 2)){ @@ -139,8 +155,18 @@ void Not::save(FILE *archivo) dato += c_y; for ( int i=0; i<=vec_connector.size()-1&&!vec_connector.empty(); i++) { if ( vec_connector[i].type == IN ) { - dato += "\t\t"; - dato += vec_connector[i].name_dest + "\n"; + if ( vec_connector[i].cistern_connector == 1 ) { + dato += "\t\t"; + dato += vec_connector[i].name_dest + "\n"; + } + if ( vec_connector[i].cistern_connector == 0 ) { + dato += "\t\t"; + dato += vec_connector[i].name_dest + "\n"; + } + if ( vec_connector[i].cistern_connector == -1 ) { + dato += "\t\t"; + dato += vec_connector[i].name_dest + "\n"; + } } else { dato += "\t\t"; dato += vec_connector[i].name_dest + "\n"; @@ -156,7 +182,7 @@ bool Not::check_connection() t_logic_connector temp; std::list::iterator i = workplace->lista_lineas_in.begin(); while ( i != workplace->lista_lineas_in.end() ) { - if ( workplace->get_logic_item((*i).logic_id)->get_id() == ID ) { + if ( (*i).logic_id == ID ) { temp.type = OUT; temp.name_dest = workplace->get_item((*i).store_id)->get_name(); vec_connector.push_back(temp); @@ -167,15 +193,45 @@ bool Not::check_connection() i = workplace->lista_lineas_out.begin(); while ( i != workplace->lista_lineas_out.end() ) { - if (workplace->get_logic_item((*i).logic_id)->get_id() == ID ) { + if ( (*i).logic_id == ID ) { temp.type = IN; temp.name_dest = workplace->get_item((*i).store_id)->get_name(); + if ( dynamic_cast(workplace->get_item((*i).store_id)) ) { + if ( (*i).cistern_out1 ) + temp.cistern_connector = 1; //arriba + else + temp.cistern_connector = 0; //abajo + } else + temp.cistern_connector = -1; //si no es tanque. + vec_connector.push_back(temp); + cant_in++; + } + i++; + } + + i = workplace->lista_lineas_logic.begin(); + while ( i != workplace->lista_lineas_logic.end() ) { + if ( (*i).logic_id == ID ) { + temp.type = OUT; + temp.name_dest = workplace->get_logic_item((*i).store_id)->get_name(); vec_connector.push_back(temp); cant_in++; } i++; } - return true;// (in_connected == out_connected ) ==true; + + i = workplace->lista_lineas_logic.begin(); + while ( i != workplace->lista_lineas_logic.end() ) { + if ( (*i).store_id == ID ) { + temp.type = IN; + temp.name_dest = workplace->get_logic_item((*i).logic_id)->get_name(); + vec_connector.push_back(temp); + cant_out++; + } + i++; + } + + return true; } ConnectorType Not::detect_click_position(int _a, int _b) @@ -258,3 +314,51 @@ void Not::set_in_connected(bool _o) { in_connected = _o; } + +bool Not::get_out_logic_connect() +{ + return out_connected; +} + +bool Not::get_in_logic_connect() +{ + return in_connected; +} + +void Not::draw_connectors() +{ + Glib::RefPtr window = get_window(); + int a,b,c,d; + switch (imgActual) { + case 0: + a = in_x-x; + b = in_y-y-5; + c = out_x-x-10; + d = out_y-y-5; + break; + case 1: + a = in_x-x-5; + b = in_y-y; + c = out_x-x-5; + d = out_y-y-10; + break; + case 2: + a = in_x-x-10; + b = in_y-y-5; + c = out_x-x; + d = out_y-y-5; + break; + case 3: + a = in_x-x-5; + b = in_y-y-10; + c = out_x-x-5; + d = out_y-y; + } + gc->set_foreground(red); + gc->set_background(red); + window->draw_rectangle(gc, 1, a, b, 10, 10); + gc->set_foreground(blue); + gc->set_background(blue); + window->draw_rectangle(gc, 1, c, d, 10, 10); + queue_draw(); +}