36 #ifndef PROFILESURFACE_OBJECT_H
37 #define PROFILESURFACE_OBJECT_H
63 class GeoTessMetaData;
112 virtual int class_size()
const
121 {
return ProfileType::SURFACE; };
126 virtual bool operator == (
const Profile& p)
const
127 {
return (Profile::operator==(p) &&
139 virtual double getValue(
int attributeIndex,
int nodeIndex)
const
141 return nodeIndex == 0 ? data->getDouble(attributeIndex) : NaN_DOUBLE;
150 virtual double getValueTop(
int attributeIndex)
const
151 {
return data->getDouble(attributeIndex); }
163 virtual bool isNaN(
int nodeIndex,
int attributeIndex)
165 return nodeIndex != 0 || data->isNaN(attributeIndex);
173 int attributeIndex,
double radius,
174 bool allowRadiusOutOfRange)
const
176 return getData(0).getDouble(attributeIndex);
183 virtual float getRadius(
int i)
const
184 {
return NaN_FLOAT; };
191 {
Data** da =
new Data* [1]; da[0] = data;
return da; };
206 virtual void setData(
const vector<Data*>& inData)
207 {
delete data; data = inData[0]; }
212 virtual void setData(
int index,
Data* inData)
213 {
delete data; data = inData; }
219 virtual void setRadii(
const vector<float>& newRadii)
225 virtual float getRadiusTop()
const
226 {
return NaN_FLOAT; };
241 virtual float getRadiusBottom()
const
242 {
return NaN_FLOAT; };
275 data(NULL), pointIndex(-1)
276 { data = Data::getData(ifs, gtmd); };
281 ProfileSurface(IFStreamAscii& ifs, GeoTessMetaData& gtmd) : Profile(),
282 data(NULL), pointIndex(-1)
283 { data = Data::getData(ifs, gtmd); };
289 virtual ~ProfileSurface() {
if (data != NULL)
delete data; };
294 virtual void write(IFStreamBinary& ofs)
295 { ofs.writeByte((
byte) ProfileType::SURFACE.ordinal());
301 virtual void write(IFStreamAscii& ofs)
302 { ofs.writeInt(ProfileType::SURFACE.ordinal());
315 virtual int findClosestRadiusIndex(
double radius)
const
326 virtual void setPointIndex(
int nodeIndex,
int pntIndex)
327 { pointIndex = pntIndex; }
337 virtual void resetPointIndices() { pointIndex = -1; }
347 virtual int getPointIndex(
int nodeIndex)
const
348 {
return pointIndex; }
354 virtual Profile* copy()
356 return new ProfileSurface(data->copy());
365 #endif // PROFILESURFACE_OBJECT_H