]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Constructor/include/workplace.h
Mini bugfix.
[z.facultad/75.42/plaqui.git] / Constructor / include / workplace.h
index fe827174459313d65e8addc4ee954e049a96981e..908a2311b210f569fe7d20635ec0e87089c6e100 100644 (file)
@@ -5,18 +5,43 @@
 #include <gdkmm/gc.h>
 #include <gtkmm.h>
 #include <libglademm.h>
-/**Esta clase define el area de trabajo.
-  *Ella se encarga de eliminarlos y dibujar las lineas logicas que los conectan
-*/
+
 
 ///Indico que la clase CItem existe para poder compilar.
 class CItem;
 
-///Esta estructura define una linea entre un item logico y uno de transporte.
+//Indico que la clase CItem existe para poder compilar.
+class CItem;
+
+/**Esta estructura define una linea entre un item logico y uno de transporte,
+  *tambien indica cual de las dos salidas del tanque esta conectada.
+  */
 typedef struct {
        int logic_id, store_id;
+       bool cistern_out1;
 }t_line;
 
+
+/**
+ * Area de trabajo.
+ * Ella se encarga de eliminar los items y dibujar las lineas logicas que los
+ * conectan.
+ * Esta clase es la encarga de de manejar el Area trabajo.
+ * Deriva de Gtk::DrawingArea pues es donde se van a
+ * dibujar todos los elementos. Una de sus principales
+ * tareas es redibujarse cuando sea necesario y al mismo
+ * tiempo, redibujar los elementos que contiene, como
+ * pueden ser los items de la planta o las lineas logicas
+ * que conectan los mismos.
+ *
+ * Para lograr esto, se ha redefinido el metodo virtual
+ * (contenido en la clase ancestro) on_expose_event() de
+ * manera conveniente.
+ *
+ * Tambien se encarga de eliminar correctamente un item, 
+ * eliminando al mismo tiempo las lineas que llegan o 
+ * salen de el.
+ */
 class WorkPlace:public Gtk::Fixed {
        public:
                ///Constructor.
@@ -37,11 +62,14 @@ class WorkPlace:public Gtk::Fixed {
                ///Borra las lineas que esten conectadas con el item de ID == _id.
                void delete_line(int _id);      
        
-               ///Devuelve un puntero al item  de transporte _id.
+               ///Devuelve un puntero al item logico cuyo ID es _id.   
                CItem *get_logic_item(int _id);
        
-               ///Devuelve un puntero al item logico cuyo ID es _id.
+               ///Devuelve un puntero al item  de transporte _id.              
                CItem *get_item(int _id);
+
+               int get_item_id(const std::string &s);
+               int get_logic_id(const std::string &s);
        
                ///Actualiza las posiciones de los conectores logicos.
                void update_logic_position();
@@ -49,11 +77,17 @@ class WorkPlace:public Gtk::Fixed {
                ///Punteros a las listas de items.
                std::list<CItem *> *listaItems, *lista_logic_Items;
                
+               ///Verifica si hay nombres repetidos.
+               virtual bool chek_name(Glib::ustring _name, int _id);
+               
                /** Listas de lineas que van de una compuerta a la entrada de un item y de la salida de un item a una compuerta
-                         lista_lineas_in =  compuerta --> (entrada) item
-                         lista_lineas_out= compuerta --> (salida) item
+                  * lista_lineas_in = (salida) compuerta --> (entrada) item
+                  * lista_lineas_out= (entrada) compuerta --> (salida) item
+                  * lista_lineas_logic = (salida) compuerta --> (entrada) compuerta.
+                  * Esta ultima lista contiene las lineas que van desde la compuerta seleccionada que se guarda CItem::en gate_id hasta
+                  * la compuerta clickeada en segundo termino.
                */
-               std::list<t_line> lista_lineas_in, lista_lineas_out;
+               std::list<t_line> lista_lineas_in, lista_lineas_out, lista_lineas_logic;
                
                /**Variable global que identifica cual item logico fue apuntado para
                  *conectarlo mediante una linea a un item de transporte