X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src2%2FcreaImageIOWxTreeView.h;h=126c9410a6aabe86abfa02274f783ad9c7609874;hb=e13ea6551e8721b11998dc33ddccf3f89458f173;hp=23325339e94dbeb800a8998bfc56757520d57270;hpb=82026cc5a9a36392c481513cd86091714eca51d1;p=creaImageIO.git diff --git a/src2/creaImageIOWxTreeView.h b/src2/creaImageIOWxTreeView.h index 2332533..126c941 100644 --- a/src2/creaImageIOWxTreeView.h +++ b/src2/creaImageIOWxTreeView.h @@ -33,21 +33,54 @@ 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 OnSelectedChanged(wxListEvent& event); + ///Returns the last selected level + virtual unsigned int GetLastSelectedLevel(){return mLastLevel;} - /// Callback for column click + /// 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); - /// Callback for first item edition - void OnBeginLabelEdit(wxListEvent& 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); - /// Callback when first item edition ends - void OnEndLabelEdit(wxListEvent& event); + ///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 @@ -58,6 +91,17 @@ namespace creaImageIO 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; @@ -66,45 +110,70 @@ namespace creaImageIO wxListCtrl* GetCtrl(int l) { return mLevelList[l].wxCtrl; } /// return the wxSplitter of one level wxSplitterWindow* GetSplitter(int l) { return mLevelList[l].wxSplitter; } - //Returns the maximum number of levels - int GetNumberOfLevels(){ return mLevelList.size(); } - /// Gets the user selected data from the level passed as a parameter - std::vector GetSelected(int level); - ///Validates the selected images - void ValidateSelectedImages(); - ///Gets selected filenames - void GetSelectedAsString(std::vector&s); - /// Gets the next nodes on the list, be it up(true) or down(false). + //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 ); - ///Creates the color palette for the first level - void CreateColorPalette(); - ///Selects the lowest level (images) - void SelectLowerLevel(); - - + ///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; - ///Boolean that defines the direction of the organization - ///True is ascending order and false is descending - bool mDirection; - ///The last selected item on the list - long mLastSelected; - ///The last selection of nodes (for every level, except the last) - std::vector mSelected; - ///The last selection of nodes (for the last level) - std::vector mLastLevelSelected; - ///The color map - typedef std::map ColorMap; - typedef std::pair NodeColorPair; + 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; - ///Boolean declaring if the last level selection has been made - bool mSelectionMade; - bool mProcess; + ///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() };