X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/f1f01b21410b676a9c35c93251d5739bb65c711d..1855f998e5c0e51e2c1958724ac84cc13a87d84c:/Constructor/src/or.cpp diff --git a/Constructor/src/or.cpp b/Constructor/src/or.cpp index 4cbd535..7be809e 100644 --- a/Constructor/src/or.cpp +++ b/Constructor/src/or.cpp @@ -52,19 +52,33 @@ Or::~Or() bool Or::on_button_press_event(GdkEventButton *event) { if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 1)) { + 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 && !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(); + } + } else + CItem::gate_id = ID; + } if ( CItem::logic_connect ) { 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 ) { - 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); + 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)){ @@ -254,3 +268,46 @@ void Or::set_out_connected(bool _o) { out_connected = _o; } + +bool Or::get_out_logic_connect() +{ + return out_connected; +} + +void Or::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(); +}