File: vtkVVDataItemVolumeContourCollection.h

package info (click to toggle)
volview 3.4-3
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 25,204 kB
  • sloc: cpp: 132,585; ansic: 11,612; tcl: 236; sh: 64; makefile: 25; xml: 8
file content (104 lines) | stat: -rw-r--r-- 3,413 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
/*=========================================================================

  Copyright (c) Kitware, Inc.
  All rights reserved.
  See Copyright.txt or http://www.kitware.com/VolViewCopyright.htm for details.

     This software is distributed WITHOUT ANY WARRANTY; without even
     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
     PURPOSE.  See the above copyright notice for more information.

=========================================================================*/
// .NAME vtkVVDataItemVolumeContourCollection - maintain a list of contours
// .SECTION Description
// .SECTION See Also
// vtkCollection

#ifndef __vtkVVDataItemVolumeContourCollection_h
#define __vtkVVDataItemVolumeContourCollection_h

#include "vtkKWObject.h"

class vtkVVDataItemVolumeContour;
class vtkVVDataItemVolume;
class vtkCollection;

class VTK_EXPORT vtkVVDataItemVolumeContourCollection : public vtkKWObject
{
public:
  vtkTypeRevisionMacro(vtkVVDataItemVolumeContourCollection, vtkKWObject);
  static vtkVVDataItemVolumeContourCollection *New();
  void PrintSelf(ostream& os, vtkIndent indent);

  // Description:
  // Set/Get the data on which all contours in this collection reside. 
  // Not ref counted, since the data item volume will reference count us.
  virtual void SetDataItemVolume( vtkVVDataItemVolume * );
  vtkGetObjectMacro( DataItemVolume, vtkVVDataItemVolume );
  
  // Description:
  // Add a contour to the list. Returns the added item.
  vtkVVDataItemVolumeContour *AddNewItem();

  // Description:
  // Add an item to the list.
  virtual void AddItem( vtkVVDataItemVolumeContour *a );
  
  // Description:
  // Get the number of contours.
  int GetNumberOfItems();
  
  // Description:
  // Get the nth contour in the list.
  vtkVVDataItemVolumeContour *GetNthItem( int i );

  // Description:
  // Remove the i'th item in the list.
  void RemoveItem(int i);

  // Description:
  // Remove an object from the list. 
  void RemoveItem(vtkVVDataItemVolumeContour *);

  // Description:
  // Remove all objects from the list.
  void RemoveAllItems();

  // Description:
  // Search for an object and return location in list. If the return value is
  // 0, the object was not found. If the object was found, the location is
  // the return value-1.
  int IsItemPresent(vtkVVDataItemVolumeContour *a);

  // Description:
  // Search by the description string identifier of the contours.
  int GetNumberOfContoursWithDescription( const char *description );
  vtkVVDataItemVolumeContour *GetNthContourWithDescription( int i, const char *description );

  // Description:
  // Check all the items in the collection for their MTTime.
  virtual unsigned long GetMTime();  

  // Description:
  // Enable garbage collection. There are ref counting cycles with 
  // vtkVVDataItemVolume
  virtual void Register(vtkObjectBase* o);
  virtual void UnRegister(vtkObjectBase* o);

protected:
  vtkVVDataItemVolumeContourCollection(); 
  ~vtkVVDataItemVolumeContourCollection();
  
  vtkCollection       * Collection;
  vtkVVDataItemVolume * DataItemVolume;

  // Report reference count loops. The dataitem refcounts us
  virtual void ReportReferences(vtkGarbageCollector* collector);

private:
  vtkVVDataItemVolumeContourCollection(const vtkVVDataItemVolumeContourCollection&);  // Not implemented.
  void operator=(const vtkVVDataItemVolumeContourCollection&);  // Not implemented.
};

#endif