1 /*=========================================================================
2
3 Program: Visualization Toolkit
4 Module: vtkArrayCoordinates.cxx
5
6 -------------------------------------------------------------------------
7 Copyright 2008 Sandia Corporation.
8 Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
9 the U.S. Government retains certain rights in this software.
10 -------------------------------------------------------------------------
11
12 Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
13 All rights reserved.
14 See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
15
16 This software is distributed WITHOUT ANY WARRANTY; without even
17 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
18 PURPOSE. See the above copyright notice for more information.
19
20 =========================================================================*/
21
22 #include "vtkArrayCoordinates.h"
23
24 vtkArrayCoordinates::vtkArrayCoordinates() = default;
25
vtkArrayCoordinates(CoordinateT i)26 vtkArrayCoordinates::vtkArrayCoordinates(CoordinateT i) :
27 Storage(1)
28 {
29 this->Storage[0] = i;
30 }
31
vtkArrayCoordinates(CoordinateT i,CoordinateT j)32 vtkArrayCoordinates::vtkArrayCoordinates(CoordinateT i, CoordinateT j) :
33 Storage(2)
34 {
35 this->Storage[0] = i;
36 this->Storage[1] = j;
37 }
38
vtkArrayCoordinates(CoordinateT i,CoordinateT j,CoordinateT k)39 vtkArrayCoordinates::vtkArrayCoordinates(CoordinateT i, CoordinateT j, CoordinateT k) :
40 Storage(3)
41 {
42 this->Storage[0] = i;
43 this->Storage[1] = j;
44 this->Storage[2] = k;
45 }
46
GetDimensions() const47 vtkArrayCoordinates::DimensionT vtkArrayCoordinates::GetDimensions() const
48 {
49 return static_cast<vtkArrayCoordinates::DimensionT>(this->Storage.size());
50 }
51
SetDimensions(DimensionT dimensions)52 void vtkArrayCoordinates::SetDimensions(DimensionT dimensions)
53 {
54 this->Storage.assign(dimensions, 0);
55 }
56
operator [](DimensionT i)57 vtkArrayCoordinates::CoordinateT& vtkArrayCoordinates::operator[](DimensionT i)
58 {
59 return this->Storage[i];
60 }
61
operator [](DimensionT i) const62 const vtkArrayCoordinates::CoordinateT& vtkArrayCoordinates::operator[](DimensionT i) const
63 {
64 return this->Storage[i];
65 }
66
GetCoordinate(DimensionT i) const67 vtkArrayCoordinates::CoordinateT vtkArrayCoordinates::GetCoordinate(DimensionT i) const
68 {
69 return this->Storage[i];
70 }
71
SetCoordinate(DimensionT i,const CoordinateT & coordinate)72 void vtkArrayCoordinates::SetCoordinate(DimensionT i, const CoordinateT& coordinate)
73 {
74 this->Storage[i] = coordinate;
75 }
76
operator ==(const vtkArrayCoordinates & rhs) const77 bool vtkArrayCoordinates::operator==(const vtkArrayCoordinates& rhs) const
78 {
79 return this->Storage == rhs.Storage;
80 }
81
operator !=(const vtkArrayCoordinates & rhs) const82 bool vtkArrayCoordinates::operator!=(const vtkArrayCoordinates& rhs) const
83 {
84 return !(*this == rhs);
85 }
86
operator <<(ostream & stream,const vtkArrayCoordinates & rhs)87 ostream& operator<<(ostream& stream, const vtkArrayCoordinates& rhs)
88 {
89 for(vtkArrayCoordinates::DimensionT i = 0; i != rhs.GetDimensions(); ++i)
90 {
91 if(i)
92 stream << ",";
93 stream << rhs[i];
94 }
95
96 return stream;
97 }
98
99