Slicer  4.11
Slicer is a multi-platform, free and open source software package for visualization and medical image computing
vtkMRMLSubjectHierarchyNode.h
Go to the documentation of this file.
1 /*==============================================================================
2 
3  Program: 3D Slicer
4 
5  Copyright (c) Laboratory for Percutaneous Surgery (PerkLab)
6  Queen's University, Kingston, ON, Canada. All Rights Reserved.
7 
8  See COPYRIGHT.txt
9  or http://www.slicer.org/copyright/copyright.txt for details.
10 
11  Unless required by applicable law or agreed to in writing, software
12  distributed under the License is distributed on an "AS IS" BASIS,
13  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  See the License for the specific language governing permissions and
15  limitations under the License.
16 
17  This file was originally developed by Csaba Pinter, PerkLab, Queen's University
18  and was supported through the Applied Cancer Research Unit program of Cancer Care
19  Ontario with funds provided by the Ontario Ministry of Health and Long-Term Care
20 
21 ==============================================================================*/
22 
23 // .NAME vtkMRMLSubjectHierarchyNode
24 // .SECTION Description
25 // MRML node to represent subject hierarchy tree
26 //
27 
28 #ifndef __vtkMRMLSubjectHierarchyNode_h
29 #define __vtkMRMLSubjectHierarchyNode_h
30 
31 // MRML includes
32 #include <vtkMRMLNode.h>
34 
35 class vtkCallbackCommand;
36 class vtkIdList;
37 class vtkMRMLDisplayNode;
40 
56 class VTK_MRML_EXPORT vtkMRMLSubjectHierarchyNode : public vtkMRMLNode
57 {
58 public:
59  static const vtkIdType INVALID_ITEM_ID;
60 
61  // Separator characters for (de)serializing the UID and the attributes map
62  static const std::string SUBJECTHIERARCHY_SEPARATOR;
63  static const std::string SUBJECTHIERARCHY_NAME_VALUE_SEPARATOR;
64 
65  // Attribute name to identify subject hierarchy 2.0 nodes in scene MRML files
66  static const std::string SUBJECTHIERARCHY_VERSION_ATTRIBUTE_NAME;
67 
68  enum
69  {
70  SubjectHierarchyItemAddedEvent = 62000,
94  };
95 
99  {
100  vtkIdList* itemIDsToShow = nullptr;
101  vtkMRMLAbstractViewNode* viewNode = nullptr;
102  };
103 
104 public:
105  static vtkMRMLSubjectHierarchyNode *New();
107  void PrintSelf(ostream& os, vtkIndent indent) override;
108 
109  vtkMRMLNode* CreateNodeInstance() override;
110 
112  virtual void ReadItemFromXML(const char** atts);
114  void WriteXML(ostream& of, int indent) override;
116  void WriteNodeBodyXML(ostream& of, int indent) override;
117 
119  void Copy(vtkMRMLNode *node) override;
120 
122  const char* GetNodeTagName() override;
123 
124 // Get/Set methods
125 public:
128  static vtkMRMLSubjectHierarchyNode* GetSubjectHierarchyNode(vtkMRMLScene* scene);
129 
131  vtkIdType GetSceneItemID();
133  vtkMRMLNode* GetItemDataNode(vtkIdType itemID);
135  void SetItemName(vtkIdType itemID, std::string name);
138  std::string GetItemName(vtkIdType itemID);
140  void SetItemLevel(vtkIdType itemID, std::string level);
142  std::string GetItemLevel(vtkIdType itemID);
144  void SetItemOwnerPluginName(vtkIdType itemID, std::string ownerPluginName);
146  std::string GetItemOwnerPluginName(vtkIdType itemID);
148  void SetItemExpanded(vtkIdType itemID, bool expanded);
150  bool GetItemExpanded(vtkIdType itemID);
151 
153  void SetItemUID(vtkIdType itemID, std::string uidName, std::string uidValue);
156  std::string GetItemUID(vtkIdType itemID, std::string uidName);
157 
159  void SetItemAttribute(vtkIdType itemID, std::string attributeName, std::string attributeValue);
162  bool RemoveItemAttribute(vtkIdType itemID, std::string attributeName);
165  std::string GetItemAttribute(vtkIdType itemID, std::string attributeName);
168  std::vector<std::string> GetItemAttributeNames(vtkIdType itemID);
172  bool HasItemAttribute(vtkIdType itemID, std::string attributeName);
173 
176  void ItemModified(vtkIdType itemID);
177 
180  void RequestOwnerPluginSearch(vtkIdType itemID);
184  void RequestOwnerPluginSearch(vtkMRMLNode* dataNode);
185 
187  static vtkIdType GetInvalidItemID() { return INVALID_ITEM_ID; }
188 
194  void SetItemDataNode(vtkIdType itemID, vtkMRMLNode* dataNode);
195 
196 // Hierarchy related methods
197 public:
203  vtkIdType CreateItem(vtkIdType parentItemID, vtkMRMLNode* dataNode, const char* ownerPluginName=nullptr);
210  vtkIdType CreateHierarchyItem(vtkIdType parentItemID, std::string name, std::string level);
215  vtkIdType CreateSubjectItem(vtkIdType parentItemID, std::string name);
220  vtkIdType CreateStudyItem(vtkIdType parentItemID, std::string name);
225  vtkIdType CreateFolderItem(vtkIdType parentItemID, std::string name);
226 
231  bool RemoveItem(vtkIdType itemID, bool removeDataNode=true, bool recursive=true);
236  bool RemoveItemChildren(vtkIdType itemID, bool removeDataNodes=true, bool recursive=true);
241  void RemoveAllItems(bool removeDataNode=false);
242 
245  void SetItemParent(vtkIdType itemID, vtkIdType parentItemID, bool enableCircularCheck=true);
248  vtkIdType GetItemParent(vtkIdType itemID);
251  int GetItemPositionUnderParent(vtkIdType itemID);
254  vtkIdType GetItemByPositionUnderParent(vtkIdType parentItemID, int position);
255 
260  void GetItemChildren(vtkIdType itemID, std::vector<vtkIdType>& childIDs, bool recursive=false);
262  void GetItemChildren(vtkIdType itemID, vtkIdList* childIDs, bool recursive=false);
263 
266  bool ReparentItemByDataNode(vtkIdType itemID, vtkMRMLNode* newParentNode);
270  bool MoveItem(vtkIdType itemID, vtkIdType beforeItemID);
271 
272 // Item finder methods
273 public:
278  vtkIdType GetItemByUID(const char* uidName, const char* uidValue);
279 
285  vtkIdType GetItemByUIDList(const char* uidName, const char* uidValue);
286 
290  vtkIdType GetItemByDataNode(vtkMRMLNode* dataNode);
291 
295  vtkIdType GetItemByName(std::string name);
296 
303  void GetItemsByName(std::string name, vtkIdList* foundItemIds, bool contains=false);
304 
310  vtkIdType GetItemChildWithName(vtkIdType parentItemID, std::string name, bool recursive=false);
311 
316  void GetDataNodesInBranch(vtkIdType itemID, vtkCollection* dataNodeCollection, const char* childClass=nullptr);
317 
322  vtkMRMLNode* GetParentDataNode(vtkMRMLNode* dataNode, bool recursive=false);
323 
324 // Utility functions
325 public:
328  void SetDisplayVisibilityForBranch(vtkIdType itemID, int visible);
332  int GetDisplayVisibilityForBranch(vtkIdType itemID);
333 
337  void SetItemDisplayVisibility(vtkIdType itemID, int visible);
339  int GetItemDisplayVisibility(vtkIdType itemID);
340 
343  vtkMRMLDisplayNode* GetDisplayNodeForItem(vtkIdType itemID);
344 
348  bool IsItemLevel(vtkIdType itemID, std::string level);
349 
353  bool IsItemVirtualBranchParent(vtkIdType itemID);
354 
361  std::string GetAttributeFromItemAncestor(vtkIdType itemID, std::string attributeName, std::string level="");
362 
365  vtkIdType GetItemAncestorAtLevel(vtkIdType itemID, std::string level);
366 
370  bool IsAnyNodeInBranchTransformed(vtkIdType itemID, bool includeParentItem=true, vtkMRMLTransformNode* exceptionNode=nullptr);
371 
373  static void DeserializeUIDList(std::string uidListString, std::vector<std::string>& deserializedUIDList);
374 
379  std::vector<vtkIdType> GetItemsReferencedFromItemByDICOM(vtkIdType itemID);
382  void GetItemsReferencedFromItemByDICOM(vtkIdType itemID, vtkIdList* referencingIdList);
383 
388  std::vector<vtkIdType> GetItemsReferencingItemByDICOM(vtkIdType itemID);
391  void GetItemsReferencingItemByDICOM(vtkIdType itemID, vtkIdList* referencingIdList);
392 
394  std::string GenerateUniqueItemName(std::string name);
395 
397  int GetNumberOfItems();
398 
401  int GetNumberOfItemChildren(vtkIdType itemID, bool recursive=false);
402 
404  void PrintItem(vtkIdType itemID, ostream& os, vtkIndent indent);
405 
407  static vtkMRMLSubjectHierarchyNode* ResolveSubjectHierarchy(vtkMRMLScene* scene);
408 
410  void ShowItemsInView(vtkIdList* itemIDs, vtkMRMLAbstractViewNode* viewNode);
411 
412 protected:
414  static void ItemEventCallback(vtkObject* caller, unsigned long eid, void* clientData, void* callData);
415 
416 protected:
418  ~vtkMRMLSubjectHierarchyNode() override;
421 
422  class vtkInternal;
423  vtkInternal* Internal;
424  friend class vtkInternal;
425 
427  vtkSmartPointer<vtkCallbackCommand> ItemEventCallbackCommand;
428 };
429 
430 #endif
virtual void WriteNodeBodyXML(ostream &of, int indent)
Write this node&#39;s body to a MRML file in XML format.
static const std::string SUBJECTHIERARCHY_VERSION_ATTRIBUTE_NAME
MRML node for representing a transformation between this node space and a parent node space...
vtkSmartPointer< vtkCallbackCommand > ItemEventCallbackCommand
Command handling events from subject hierarchy items.
void operator=(const vtkMRMLNode &)
virtual vtkMRMLNode * CreateNodeInstance()=0
Create instance of the default node. Like New only virtual.
MRML node to represent a complete subject hierarchy tree.
virtual void Copy(vtkMRMLNode *node)
Copy node contents from another node of the same type. Does not copy node ID and Scene. Performs deep copy - an independent copy is created from all data, including bulk data.
Abstract MRML node to represent a view. The class holds the properties common to any view type (3D...
A set of MRML Nodes that supports serialization and undo/redo.
Definition: vtkMRMLScene.h:61
static const std::string SUBJECTHIERARCHY_NAME_VALUE_SEPARATOR
Event invoked when item resolving finished (e.g. after scene import)
virtual void WriteXML(ostream &of, int indent)
static vtkIdType GetInvalidItemID()
Python accessor for the invalid ID.
static const std::string SUBJECTHIERARCHY_SEPARATOR
void PrintSelf(ostream &os, vtkIndent indent) override
Event invoked when item resolving starts (e.g. after scene import)
Abstract class that contains graphical display properties for displayable nodes.
virtual const char * GetNodeTagName()=0
Abstract Superclass for all specific types of MRML nodes.
Definition: vtkMRMLNode.h:167