X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/94fc2a6d3148acc30d1b0415336a1c2259632a18..26a40f607344c63baa4b00f41fc88e02d5084817:/Constructor/include/constructor.h?ds=sidebyside diff --git a/Constructor/include/constructor.h b/Constructor/include/constructor.h index 044e068..5ba90be 100644 --- a/Constructor/include/constructor.h +++ b/Constructor/include/constructor.h @@ -11,7 +11,7 @@ #include #include #include -#include +#include #include "workplace.h" #include "item.h" #include "splitter.h" @@ -25,7 +25,40 @@ #include "or.h" #include "not.h" #include "libxml/parser.h" - +/**La clase principal de esta aplicación es la clase + * Constructor. Ella es la encargada de obtener e + * inicializar todos los elementos de la ventana + * principal, ya sean botones, cuadros de diálogo, barras + * de herramientas, etc. + * + * Para cada botón referenciado por esta clase, es + * conectado a ellos una señal, que será el método que + * deben invocar al ser presionados. + * + * Uno de los métodos mas importantes de esta clase es + * on_item_drop_drag_recived() que es la encargada de + * crear un nuevo elemento si es arrastrado desde la barra + * de elementos, o de moverlo dentro del área de trabajo + * si este ya estaba creado. + * + * Para facilitar el diseño y disminuir la complejidad, la + * grilla fue dividida en sectores de 32x32 pixels, lo que + * permite que el usuario no tenga que ser muy preciso a + * la hora de soltar un item en el área de trabajo. + * + * Cada nuevo elemento creado es almacenado en una lista + * de elementos ( listaItems ) de transporte o + * almacenamiento de fluido, o de elementos lógicos, según + * cual sea ( lista_logic_items). + * + * Otra de las funciones principales es "check_connection()" + * que recorre todos los items de ambas listas y verifica + * que se haya formado en el momento del diseño un + * circuito posible. + * + * Esta clase contiene los métodos necesarios para guardar + * y cargar un archivo XML cuyo formato se explica mas adelante. + */ class Constructor : public Gtk::Window { public: Constructor(BaseObjectType* cobject, const Glib::RefPtr& refGlade); @@ -42,13 +75,15 @@ class Constructor : public Gtk::Window { Gtk::ImageMenuItem *main_menu_quit,*main_menu_new, *edit_menu_del, *edit_menu_delete_all, *main_menu_save, *main_menu_open; Gtk::CheckButton *chk_btn_logica; Gtk::FileSelection *file_selection, *file_open_selection; - Gtk::Entry *combo_entry; + Gtk::Combo *combo_entry; Gtk::Dialog *dlg_connect; Gtk::Label *dlg_label; + Gtk::Statusbar *status_bar; Glib::RefPtr ico_canio, ico_y, ico_codo, ico_tanque, ico_bomba, ico_exclusa, ico_drain, ico_and, ico_or, ico_not; Glib::RefPtr ico_last; std::list listTargets; std::list listaItems, lista_logic_Items; + std::list list_pointed; WorkPlace *workplace; bool logica; bool can_drop(CItem *, int , int); @@ -69,7 +104,7 @@ class Constructor : public Gtk::Window { virtual void on_main_menu_save(); virtual void on_edit_menu_del(); virtual void on_edit_menu_delete_all(); - virtual void on_chk_btn_clicked(); + virtual void on_chk_btn_logica_clicked(); virtual void on_btn_open_cancel_clicked(); virtual void on_btn_file_ok_clicked(); virtual void on_btn_file_cancel_clicked(); @@ -101,6 +136,8 @@ class Constructor : public Gtk::Window { virtual void on_item_drop_drag_received(const Glib::RefPtr& context, int x, int y, GtkSelectionData* selection_data, guint info, guint time); // Carga desde un XML + void create_lines(xmlNodePtr nodo); + void create_line(xmlNodePtr nodo, int logic_id); Pump *loadBomba(xmlNodePtr nodo); Conduct *loadConduct(xmlNodePtr nodo); Exclusa *loadExclusa(xmlNodePtr nodo); @@ -108,5 +145,9 @@ class Constructor : public Gtk::Window { Union *loadUnion(xmlNodePtr nodo); Drain *loadDrain(xmlNodePtr nodo); Splitter *loadCodo(xmlNodePtr nodo); + And *loadAnd(xmlNodePtr nodo); + Not *loadNot(xmlNodePtr nodo); + Or *loadOr(xmlNodePtr nodo); + Gdk::Color loadColor(xmlNodePtr nodo); }; #endif