X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/07f4e929e15451f6af8ec4d941bcee6742917d0d..d664a4c16bb56138b53e8d6dba92e199bd3ea6c7:/Constructor/workplace.cpp?ds=sidebyside diff --git a/Constructor/workplace.cpp b/Constructor/workplace.cpp index 418f6b7..652cf01 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,18 @@ 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); + + + Glib::RefPtr gc = get_style()->get_black_gc(); + Gdk::Color color; + color.set_rgb(255,0,0); + gc->set_rgb_bg_color(color); + get_style()->set_black(color); + 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; } @@ -39,10 +42,45 @@ void WorkPlace::delete_item(int _id) while ( i != listaItems->end() ){ CItem *temp = *i; if ( temp->get_id() == _id ){ + delete_line(_id); listaItems->erase(i); delete temp; break; } i++; } + i = lista_logic_Items->begin(); + while ( i != lista_logic_Items->end() ){ + CItem *temp = *i; + if ( temp->get_id() == _id ){ + delete_line(_id); + listaItems->erase(i); + delete temp; + break; + } + 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; +} + +void WorkPlace::delete_line(int _id) +{ + std::list::iterator i = lista_lineas.begin(); + while ( i != lista_lineas.end() ){ + if ( (*i).logic->get_id() == _id || (*i).store->get_id == _id) + lista_lineas.erase(i); + i++; + } }