]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Constructor/item.h
cambios drasticos producen cuelgues obvios, etapa de revision, pueden mirarlo libremente
[z.facultad/75.42/plaqui.git] / Constructor / item.h
index 7c1e771e8c8643c0f85bc55a9de45d82d5637104..1654bf3dfda7171931e50136542f1e25da359ecd 100644 (file)
 #include <gtkmm/entry.h>
 #include "itemptywnd.h"
 
 #include <gtkmm/entry.h>
 #include "itemptywnd.h"
 
+typedef enum { NONE, RIGHT, LEFT, MIDDLE } ConnectorSide;
+typedef enum { UNDEF, IN, OUT } ConnectorType;
+
+class Connector {
+       public: 
+               int id_dest;
+               ConnectorType type;
+               Connector& operator= (Connector & c) {
+                       id_dest = c.id_dest;
+                       type = c.type;
+                       return *this;
+               }
+};
+
 class WorkPlace;
        
 class CItem:public Gtk::DrawingArea {
 class WorkPlace;
        
 class CItem:public Gtk::DrawingArea {
@@ -27,8 +41,6 @@ public:
        int get_position_x();
        int get_position_y();
        int get_id();
        int get_position_x();
        int get_position_y();
        int get_id();
-       int get_conector_in();
-       int get_conector_out();
        int get_img_actual();
        Glib::ustring get_name();
        double get_caudal();
        int get_img_actual();
        Glib::ustring get_name();
        double get_caudal();
@@ -36,20 +48,23 @@ public:
        void set_id(int _id);
        void set_caudal(double _caudal);
        void set_name(Glib::ustring _name);
        void set_id(int _id);
        void set_caudal(double _caudal);
        void set_name(Glib::ustring _name);
-       void set_conector_in(int _in);
-       void set_conector_out(int _out);
        bool is_occupied_area(int _a, int _b);
        bool is_occupied_area(int _a, int _b);
-       bool is_other_connection_area(int _a, int _b);
+       ConnectorType is_other_connection_area(int _a, int _b);
        virtual void save(FILE *archivo) = 0;
        virtual bool check_connection()=0;
        virtual void save(FILE *archivo) = 0;
        virtual bool check_connection()=0;
-       virtual bool is_connection_area(int _a, int _b)=0;
+//     virtual ConnectorType is_connection_area(int _a, int _b)=0;
+       virtual ConnectorType get_connector_type( int _a, int _b );
        WorkPlace *workplace;
        Gtk::Entry *combo_entry;
        std::list<CItem *> *listaItems;
        bool is_union;
        WorkPlace *workplace;
        Gtk::Entry *combo_entry;
        std::list<CItem *> *listaItems;
        bool is_union;
+       bool is_connected;
+       //  Hay que ocultarlo --- problemas con el get y el set!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
+       //  0 = izquierda/arriba , 1 = derecha/abajo , 2 = medio.   tomando como referencia la imagen inicial de cada item cuando corresponda
+       std::vector<Connector> connect_vec;
 protected:
        int imgActual;
 protected:
        int imgActual;
-       int ID, conector_in, conector_out; 
+       int ID;
        Glib::ustring name;
        double caudal_max;
        Gtk::Menu menu_popup;
        Glib::ustring name;
        double caudal_max;
        Gtk::Menu menu_popup;