X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/5042b6492969385725852d3cf90959abb52a7398..101179f2d7bcc4de75c326d3e9d01694c84d07ca:/Constructor/src/or.cpp?ds=sidebyside diff --git a/Constructor/src/or.cpp b/Constructor/src/or.cpp index 60f8eed..d7e8a78 100644 --- a/Constructor/src/or.cpp +++ b/Constructor/src/or.cpp @@ -2,6 +2,10 @@ Or::Or() { + in_x = x; + in_y = y+16; + out_x = x+32; + out_y = y+16; imageN = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/or_n.png"); imageS = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/or_s.png"); imageE = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-constructor/pixmaps/or_e.png"); @@ -21,10 +25,14 @@ Or::~Or() bool Or::on_button_press_event(GdkEventButton *event) { if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 1)) { - if (CItem::logic_connect) + if ( CItem::logic_connect ) { CItem::gate_id = ID; - combo_entry->set_text(name); - WorkPlace::pointed = ID; + WorkPlace::pointed = ID; + workplace->queue_draw(); + } + list_pointed->push_back(name); + combo_entry->set_popdown_strings(*list_pointed); + combo_entry->get_entry()->set_text (name); } if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 2)){ @@ -34,16 +42,32 @@ bool Or::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); @@ -66,10 +90,130 @@ void Or::on_menu_popup_rotar() void Or::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 ) { + 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 Or::check_connection() { - return true; + int cant_in = 0, cant_out =0; + 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 ) { + temp.type = OUT; + temp.name_dest = workplace->get_item((*i).store_id)->get_name(); + vec_connector.push_back(temp); + cant_out++; + } + i++; + } + + i = workplace->lista_lineas_out.begin(); + while ( i != workplace->lista_lineas_out.end() ) { + if ( workplace->get_logic_item((*i).logic_id)->get_id() == ID ) { + temp.type = IN; + temp.name_dest = workplace->get_item((*i).store_id)->get_name(); + vec_connector.push_back(temp); + cant_in++; + } + i++; + } + + //FIXME la or tiene n entradas y una salida!!!!!!!!!!!!!!!!!! + return true;// (cant_in == cant_out ); +} + +ConnectorType Or::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 Or::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 Or::get_in_logic_connect_position(int& _a, int& _b) +{ + _a = in_x; + _b = in_y; +} + +void Or::get_out_logic_connect_position(int& _a, int& _b) +{ + _a =out_x; + _b =out_y; }