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
|
/*=========================================================================
Program: Visualization Toolkit
Module: vtkImageSliceCollection.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.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.
=========================================================================*/
/**
* @class vtkImageSliceCollection
* @brief a sorted list of image slice objects
*
* vtkImageSliceCollection is a vtkPropCollection that maintains
* a list of vtkImageSlice objects that are sorted by LayerNumber.
* This allows the images to be rendered in the correct order.
* @sa
* vtkImageSlice vtkImageAssembly
*/
#ifndef vtkImageSliceCollection_h
#define vtkImageSliceCollection_h
#include "vtkImageSlice.h" // to allow inline static-cast
#include "vtkPropCollection.h"
#include "vtkRenderingImageModule.h" // For export macro
VTK_ABI_NAMESPACE_BEGIN
class VTKRENDERINGIMAGE_EXPORT vtkImageSliceCollection : public vtkPropCollection
{
public:
static vtkImageSliceCollection* New();
vtkTypeMacro(vtkImageSliceCollection, vtkPropCollection);
void PrintSelf(ostream& os, vtkIndent indent) override;
/**
* Sorts the vtkImageSliceCollection by layer number. Smaller layer
* numbers are first. Layer numbers can be any integer value. Items
* with the same layer number will be kept in the same relative order
* as before the sort.
*/
void Sort();
/**
* Add an image to the list. The new image is inserted in the list
* according to its layer number.
*/
void AddItem(vtkImageSlice* a);
/**
* Standard Collection methods. You must call InitTraversal
* before calling GetNextImage. If possible, you should use the
* GetNextImage method that takes a collection iterator instead.
*/
vtkImageSlice* GetNextImage();
/**
* Reentrant safe way to get an object in a collection.
*/
vtkImageSlice* GetNextImage(vtkCollectionSimpleIterator& cookie);
/**
* Access routine provided for compatibility with previous
* versions of VTK. Please use the GetNextImage() variant
* where possible.
*/
vtkImageSlice* GetNextItem() { return this->GetNextImage(); }
protected:
vtkImageSliceCollection() = default;
~vtkImageSliceCollection() override;
void DeleteElement(vtkCollectionElement*) override;
private:
// hide the standard AddItem from the user and the compiler.
void AddItem(vtkObject* o) { this->vtkCollection::AddItem(o); }
void AddItem(vtkProp* o) { this->vtkPropCollection::AddItem(o); }
private:
vtkImageSliceCollection(const vtkImageSliceCollection&) = delete;
void operator=(const vtkImageSliceCollection&) = delete;
};
inline vtkImageSlice* vtkImageSliceCollection::GetNextImage()
{
return static_cast<vtkImageSlice*>(this->GetNextItemAsObject());
}
inline vtkImageSlice* vtkImageSliceCollection::GetNextImage(vtkCollectionSimpleIterator& cookie)
{
return static_cast<vtkImageSlice*>(this->GetNextItemAsObject(cookie));
}
VTK_ABI_NAMESPACE_END
#endif
|