X-Git-Url: https://git.llucax.com/z.facultad/75.52/treemulator.git/blobdiff_plain/9939d45f997d2855218e3acf5b51222e9680ce31..16ec4547406edcae627dd3ec4bdc448ef605b11a:/viewer/view_btree.h diff --git a/viewer/view_btree.h b/viewer/view_btree.h index e3a5c68..bb955bd 100644 --- a/viewer/view_btree.h +++ b/viewer/view_btree.h @@ -6,18 +6,27 @@ #include #include "btree.h" - -#define NODE_WIDTH 500 -#define NODE_HEIGHT 50 +#include "view_node.h" using namespace Gnome; +class ViewNode; + class ViewBTree : public Canvas::Group, public BTree { public: - ViewBTree (Canvas::Group *parent, std::string filename); + ViewBTree (Canvas::Group *parent, std::string filename, uint block_size, int type); + + void Clear (); + void HighliteKey (Clave &k); static double byte_to_pixels; + static double node_width; + static double node_height; + + typedef SigC::Signal2 type_signal_selected; + type_signal_selected signal_selected (); protected: + type_signal_selected m_signal_selected; int max_level; /* Lo saco de la raiz */ /* Posicion X por nivel */ std::map pos_x; @@ -25,17 +34,12 @@ class ViewBTree : public Canvas::Group, public BTree { /* Un nodo que quiera ser puesto 2 veces es un bug :) */ std::map node_placed; - void AddNode (uint num); - -}; - -class ViewNode : public Canvas::Group { public: - ViewNode (Canvas::Group *parent, uint num, BTreeNodeHeader &header, std::list &keys); + void AddNode (uint num, uint padre = 0); + void on_item_selected (BTreeData *, uint, ViewNode *); + void on_item_activated (BTreeData *, uint, ViewNode *); - std::list& getChilds () { return hijos; } - private: - std::list hijos; + ViewNode *last_selected; }; #endif