X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/5042b6492969385725852d3cf90959abb52a7398..ed55685399f3dd28a22f229c9f384facbed4d48d:/Constructor/src/pump.cpp?ds=inline diff --git a/Constructor/src/pump.cpp b/Constructor/src/pump.cpp index 7526f6b..9663b0b 100644 --- a/Constructor/src/pump.cpp +++ b/Constructor/src/pump.cpp @@ -32,6 +32,7 @@ Pump::Pump(int orientacion) connect_vec.push_back(temp); } + Pump::~Pump() { } @@ -42,15 +43,15 @@ bool Pump::on_button_press_event(GdkEventButton *event) if ((event->type == GDK_BUTTON_PRESS) && ( event->button == 1)) { combo_entry->set_text(name); WorkPlace::pointed = ID; - if (CItem::logic_connect) { + if (CItem::logic_connect && CItem::gate_id != -1) { if ( detect_click_position(event->x, event->y) == IN) { - tmp_line.logic = workplace->get_logic_item(CItem::gate_id); - tmp_line.store = this; + tmp_line.logic_id = workplace->get_logic_item(CItem::gate_id)->get_id(); + tmp_line.store_id = ID; workplace->lista_lineas_in.push_back(tmp_line); workplace->queue_draw(); - } else { - tmp_line.logic = workplace->get_logic_item(CItem::gate_id); - tmp_line.store = this; + } else if (detect_click_position(event->x, event->y) == OUT) { + tmp_line.logic_id = workplace->get_logic_item(CItem::gate_id)->get_id(); + tmp_line.store_id = ID; workplace->lista_lineas_out.push_back(tmp_line); workplace->queue_draw(); } @@ -246,3 +247,17 @@ void Pump::update_logic_position() out_y = y + 32; } } + +bool Pump::on_expose_event(GdkEventExpose* event) +{ + CItem::on_expose_event(event); + Glib::RefPtr window = get_window(); + + gc->set_foreground(red); + gc->set_background(red); + window->draw_rectangle(gc, 1, image->get_width()-32, 0, 32, 16); + gc->set_foreground(blue); + gc->set_background(blue); + window->draw_rectangle(gc, 1, image->get_width()-32, 16, 32, 16); + return true; +}