X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/07f4e929e15451f6af8ec4d941bcee6742917d0d..6983220ff84632481c1628720fe15b8f3ac1c9cb:/Constructor/workplace.cpp?ds=inline diff --git a/Constructor/workplace.cpp b/Constructor/workplace.cpp index 418f6b7..e1fa47d 100644 --- a/Constructor/workplace.cpp +++ b/Constructor/workplace.cpp @@ -1,9 +1,8 @@ #include "workplace.h" +#include "item.h" WorkPlace::WorkPlace( BaseObjectType* cobject, const Glib::RefPtr &refGlade):Gtk::Fixed(cobject) { - refGlade->get_widget_derived("viewport",viewport); - viewport->workplace = this; } WorkPlace::~WorkPlace() @@ -21,14 +20,12 @@ bool WorkPlace::on_expose_event(GdkEventExpose *event) get_window()->draw_point (get_style()->get_black_gc(), x+1,y); get_window()->draw_point (get_style()->get_black_gc(), x-1,y); } - return true; -} - -bool WorkPlace::on_button_press_event(GdkEventButton *event) -{ - if ((event->type==GDK_BUTTON_RELEASE) && (event->button ==1)) { - get_pointer(viewport->temp.w, viewport->temp.z); - get_window()->draw_line (get_style()->get_black_gc(), viewport->temp.x,viewport->temp.y,viewport->temp.w,viewport->temp.z); + + std::list::iterator i = lista_lineas.begin(); + while ( i != lista_lineas.end() ) { + t_line temp = *i; + get_window()->draw_line (get_style()->get_black_gc(), temp.logic->get_position_x(),temp.logic->get_position_y(), temp.store->get_position_x(),temp.store->get_position_y()); + i++; } return true; } @@ -46,3 +43,15 @@ void WorkPlace::delete_item(int _id) i++; } } + +CItem* WorkPlace::get_logic_item(int _id) +{ + std::list::iterator i = lista_logic_Items->begin(); + while ( i != lista_logic_Items->end() ){ + CItem *temp = *i; + if ( temp->get_id() == _id ) + return temp; + i++; + } + return NULL; +}