X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src2%2FcreaImageIOWxTreeView.h;h=126c9410a6aabe86abfa02274f783ad9c7609874;hb=e13ea6551e8721b11998dc33ddccf3f89458f173;hp=e0e46d77708432450f386539d438456476d59e1e;hpb=c3aa732dfcdd65de1766d43844631906927c8b65;p=creaImageIO.git diff --git a/src2/creaImageIOWxTreeView.h b/src2/creaImageIOWxTreeView.h index e0e46d7..126c941 100644 --- a/src2/creaImageIOWxTreeView.h +++ b/src2/creaImageIOWxTreeView.h @@ -12,6 +12,7 @@ namespace creaImageIO { + /** * \ingroup View */ @@ -23,7 +24,8 @@ namespace creaImageIO { public: /// Ctor - WxTreeView(TreeHandler*, wxWindow* parent, const wxWindowID id); + WxTreeView(TreeHandler*, GimmickView*, + wxWindow* parent, const wxWindowID id); /// Virtual destructor virtual ~WxTreeView(); @@ -31,23 +33,75 @@ namespace creaImageIO /// Updates the view of a level given the selected items of upper level virtual void UpdateLevel( int ); - ///Removes selected nodes on given level - virtual void RemoveSelected( int ); + ///Removes selected nodes on given level + virtual void RemoveSelected(); - /// Callback for selection change - void OnSelected(wxListEvent& event); + ///Returns the last selected level + virtual unsigned int GetLastSelectedLevel(){return mLastLevel;} + /// Callback for item selection + void OnItemSelected(wxListEvent& event); + /// Callback for item deselection + void OnItemDeSelected(wxListEvent& event); + + /// Callback for column click + void OnColClick(wxListEvent& event); + + /// Callback when the user needs the items sorted + void OnPopupSort(wxCommandEvent& event); + + ///Callback when the user need the items filtered + void OnPopupFilter(wxCommandEvent& event); + + ///Callback when the user needs the item copied to the local disk + void OnLocalCopy(wxCommandEvent& event); + + ///Callback when the user needs to edit a field + void OnEditField(wxCommandEvent& event); + + ///Callback on mouse click + void OnMouseClick(wxMouseEvent& event); + + /// Displays a menu for items + void OnItemMenu(wxListEvent &event); + + /// Gets the attributes that are being shown and the ones that have been blocked on a specific level + void GetAttributes(std::vector& areShown, std::vector& notShown, int level); + + ///Sets the non visible attributes and refreshes the GUI + void SetNonVisibleAttributes(const std::vector& notShown, int level); + + ///Creates a new listctrl + void CreateCtrl(std::vector& notShown, int nlevel); + + ///Returns true if the attribute passed as a parameter is visible or not + bool IsAttributeVisible(const std::string& val, int level); + + /// Actual processing of item selection/deselection + /// Called by OnItemSelected and OnItemDeSelected + // void ProcessItem private: /// The struct holding the data for one level /// Holds the wx control and other data /// such as the vector of attribute keys corresponding to the columns struct LevelType { - // The + // The List Control wxListCtrl* wxCtrl; wxSplitterWindow* wxSplitter; std::vector key; + // The vector of currently selected nodes of the level + std::vector Selected; + // True iff the vector Selected is up to date + bool SelectedUpToDate; + // The column used for sorting + unsigned int SortColumn; + ///Boolean that defines the direction of the sort + ///True is ascending order and false is descending + bool SortAscending; + //The vector of not shown attributes + std::vector notShownAtts; }; /// The vector of levels : one for each level of the tree std::vector mLevelList; @@ -56,21 +110,78 @@ namespace creaImageIO wxListCtrl* GetCtrl(int l) { return mLevelList[l].wxCtrl; } /// return the wxSplitter of one level wxSplitterWindow* GetSplitter(int l) { return mLevelList[l].wxSplitter; } - - std::vector GetSelected(int level); - - - - // Updates the view of a level given the selected items of upper level - // Recursive method + //Returns the maximum number of levels + int GetNumberOfLevels(){ return mLevelList.size(); } + /// Gets the user selected data from the level passed as a parameter + /// Updates the vector if necessary + const std::vector& GetSelected(int level); + /// Set the bool SelectedUpToDate for level l + void SetSelectedUpToDate(int l, bool v) { mLevelList[l].SelectedUpToDate = v; } + /// Get the bool SelectedUpToDate for level l + bool GetSelectedUpToDate(int l) { return mLevelList[l].SelectedUpToDate; } + ///Validates the selected images + void ValidateSelectedImages(bool isSelection); + ///Gets selected filenames + void GetSelectedAsString(std::vector&s); + ///Gets the filenames of the given nodes and returns them on the given vector. Is recursive. + void GetFilenamesAsString(const std::vector& nodes, std::vector&s); + /// Gets the next nodes on the list, be it up(true) or down(false). + void GetNodes(std::vector& nodes, bool direction); + /// Updates the view of a level given the selected items of upper level + /// Recursive method virtual void RecursiveUpdateLevel( int ); + ///Selects all the elements of a level + void SelectAll(int level); + ///UnSelects all the elements of a level + void UnSelectAll(int level); + + void OnKeyDown(wxListEvent &event); + /// Sorts the level + void SortLevel(int level); + + /// Currently Selected Column + int mColumnSelected; + ///The last selected item on the list (left click) + long mLastSelected; + + ///The last selected item on the list (right click) + long mLastRightSelected; + + ///The last selected level (by right click) + int mLastRightLevel; + ///The color map + typedef std::map ColorMap; + typedef std::pair NodeColorPair; + ColorMap mColorMap; + ///Initial color palette + std::vector mColorPalette; + + wxMenu* menu; + + wxObject* senderCtrl; + int mAscendingID; + int mDescendingID; + int mFilterID; + unsigned int mLastLevel; + + wxMenu* menuItem; + int mAnonymizingID; + int mLocalCopyID; + int mEditFieldID; + + // If set to true then OnSelectedChanged returns immediately. + // Used to do avoid useless process during multiple selections + // or sorting + bool mIgnoreSelectedChanged; DECLARE_EVENT_TABLE() }; // EO class WxTreeView //===================================================================== - + + + } // EO namespace creaImageIO