X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/667418327423ba116d24751926a95a2f1235849c..8c6ff4ec334bdde66833cda6ea1eee4c0b187650:/Constructor/src/and.cpp diff --git a/Constructor/src/and.cpp b/Constructor/src/and.cpp index 9ee2867..bdc1f0e 100644 --- a/Constructor/src/and.cpp +++ b/Constructor/src/and.cpp @@ -1,17 +1,47 @@ #include "and.h" - -And::And() +#include "cistern.h" +And::And(int orientacion) { + is_logic = true; + out_connected = false; imageN = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/and_n.png"); imageS = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/and_s.png"); imageE = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/and_e.png"); imageO = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/and_o.png"); null = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/null.png"); - imgActual = 0; - image = imageE; + imgActual = orientacion; + switch (imgActual) { + case 1: + image = imageS; + in_x = x +16; + in_y = y; + out_x = x+16; + out_y = y+32; + break; + case 2: + image = imageO; + in_x = x+32; + in_y = y+16; + out_x = x; + out_y = y+16; + break; + case 3: + image = imageN; + in_x = x+16; + in_y = y+32; + out_x = x+16; + out_y = y; + break; + default: + imgActual = 0; + image = imageE; + in_x = x; + in_y = y+16; + out_x = x+32; + out_y = y+16; + } set_size_request(image->get_width(), image->get_height()); name = "and"; - menulist.push_back( Gtk::Menu_Helpers::ImageMenuElem("Conectar", menu_image_linea,SigC::slot(*this, &CItem::on_menu_popup_conectar) ) ) ; } And::~And() @@ -20,8 +50,37 @@ And::~And() bool And::on_button_press_event(GdkEventButton *event) { - if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 1)) - combo_entry->set_text(name); + if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 1)) { + WorkPlace::pointed = ID; + t_line tmp_line; + std::cout << CItem::gate_id << std::endl; + if (CItem::logic_connect) { + if (CItem::gate_id != -1 ) { + if ( detect_click_position((int)event->x, (int)event->y ) == IN && CItem::gate_id != ID && !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); + 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 ( CItem::logic_connect && detect_click_position((int)event->x, (int)event->y ) == OUT && !out_connected) { + CItem::gate_id = 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[20]; + Glib::ustring text; + sprintf(f," Conector OUT = %d",out_connected); + text = name+f; + status_bar->push ( text, 0); + } if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 2)){ image = null; @@ -30,24 +89,41 @@ bool And::on_button_press_event(GdkEventButton *event) switch (imgActual) { case 1: image = imageS; + in_x = x +16; + in_y = y; + out_x = x+16; + out_y = y+32; break; case 2: image = imageO; + in_x = x+32; + in_y = y+16; + out_x = x; + out_y = y+16; break; case 3: image = imageN; + in_x = x+16; + in_y = y+32; + out_x = x+16; + out_y = y; break; default: imgActual = 0; image = imageE; + in_x = x; + in_y = y+16; + out_x = x+32; + out_y = y+16; } 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); } if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 3)){ menu_popup.popup(event->button, event->time); - return true; //It has been handled. + return true; //It has been handled. } + workplace->queue_draw(); return true; } void And::on_menu_popup_rotar() @@ -60,31 +136,211 @@ void And::on_menu_popup_rotar() void And::save(FILE *archivo) { + vec_connector.clear(); + check_connection(); + Glib::ustring dato; + char c_img[50], c_x[50], c_y[50], c_id[50]; + sprintf(c_id,"%d",ID); + sprintf(c_img,"\t\t%d\n",imgActual); + sprintf(c_x,"\t\t%d\n",x); + sprintf(c_y,"\t\t%d\n",y); + dato = "\t\n"; + dato += c_img; + dato += c_x; + dato += c_y; + for ( int i=0; i<=vec_connector.size()-1&&!vec_connector.empty(); i++) { + if ( vec_connector[i].type == IN ) { + 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"; + } + } + dato += "\t\n"; + fprintf(archivo, dato.c_str() ); +} + +bool And::check_connection() +{ + t_logic_connector temp; + std::list::iterator i = workplace->lista_lineas_in.begin(); + while ( i != workplace->lista_lineas_in.end() ) { + if ( (*i).logic_id== ID ) { + temp.type = OUT; + temp.name_dest = workplace->get_item((*i).store_id)->get_name(); + vec_connector.push_back(temp); + } + i++; + } + + i = workplace->lista_lineas_out.begin(); + while ( i != workplace->lista_lineas_out.end() ) { + 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); + } + 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); + } + i++; + } + + 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); + } + i++; + } + + return true; //out_connected; +} + +ConnectorType And::detect_click_position(int _a, int _b) +{ + switch (imgActual) { + case 0: + if ( (_a<=32 )&&(_a>=22)&&(_b<=20)&&(_b>=10) ) + return OUT; + if ( (_a<=10)&&(_a>=0)&&(_b<=20)&&(_b>=10) ) + return IN; + break; + case 1: + if ( (_a<=20 )&&(_a>=10)&&(_b<=32)&&(_b>=22) ) + return OUT; + if ( (_a<=20)&&(_a>=10)&&(_b<=10)&&(_b>=0) ) + return IN; + break; + case 2: + if ( (_a<=10 )&&(_a>=0)&&(_b<=20)&&(_b>=10) ) + return OUT; + if ( (_a<=32)&&(_a>=22)&&(_b<=20)&&(_b>=10) ) + return IN; + break; + case 3: + if ( (_a<=20 )&&(_a>=10)&&(_b<=10)&&(_b>=0) ) + return OUT; + if ( (_a<=20)&&(_a>=10)&&(_b<=32)&&(_b>=22) ) + return IN; + } + return UNDEF; +} +void And::update_logic_position() +{ + switch (imgActual) { + case 0: + in_x = x; + in_y = y+16; + out_x = x+32; + out_y = y+16; + break; + case 1: + in_x = x+16; + in_y = y; + out_x = x+16; + out_y = y+32; + break; + case 2: + in_x = x+32; + in_y = y+16; + out_x = x; + out_y = y+16; + break; + case 3: + in_x = x+16; + in_y = y+32; + out_x = x+16; + out_y = y; + } } +void And::get_in_logic_connect_position(int& _a, int& _b) +{ + _a = in_x; + _b = in_y; +} -// CAMBIAR TODO ESTO!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -bool And::check_connection() +void And::get_out_logic_connect_position(int& _a, int& _b) { - /*switch (get_img_actual()) { - case 0: - if ( is_other_connection_area( get_position_x()-5, get_position_y()+16) && - is_other_connection_area( get_position_x()+get_image()->get_width()-16, +get_position_y()+get_image()->get_height() + 5) ) - return true; - case 1: - if ( is_other_connection_area( get_position_x()+get_image()->get_width() - 16, get_position_y() -5) && - is_other_connection_area( get_position_x()-5, get_position_y()+get_image()->get_height()-16) ) - return true; - case 2: - if ( is_other_connection_area( get_position_x() + 16, get_position_y() -5) && - is_other_connection_area( get_position_x()+get_image()->get_width()+5, get_position_y()+get_image()->get_height()-16) ) - return true; - case 3: - if ( is_other_connection_area( get_position_x()+get_image()->get_width()+5, get_position_y() +16) && - is_other_connection_area( get_position_x() + 16, get_position_y()+get_image()->get_height() + 5) ) - return true; + _a =out_x; + _b =out_y; +} + +void And::set_out_connected(bool _o) +{ + out_connected = _o; +} + +bool And::get_out_logic_connect() +{ + return out_connected; +} + +void And::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; } - return false;*/ - return true; + 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(); }