1
/////////////////////////////////////////////////////////////
3
// Copyright (c) 2007-2011 by The University of Queensland //
4
// Earth Systems Science Computational Centre (ESSCC) //
5
// http://www.uq.edu.au/esscc //
7
// Primary Business: Brisbane, Queensland, Australia //
8
// Licensed under the Open Software License version 3.0 //
9
// http://www.opensource.org/licenses/osl-3.0.php //
11
/////////////////////////////////////////////////////////////
13
#ifndef __CLIPPED_SPHERE_VOL_H
14
#define __CLIPPED_SPHERE_VOL_H
16
// --- Project includes ---
17
#include "SphereVol.h"
20
// --- STL includes ---
27
class ClippedSphereVol : public SphereVol
30
vector<pair<Plane,bool> > m_planes;
34
ClippedSphereVol(const Vector3&,double);
35
virtual ~ClippedSphereVol(){};
37
void addPlane(const Plane&,bool);
38
virtual Vector3 getAPoint(int) const;
39
virtual const map<double,const AGeometricObject*> getClosestObjects(const Vector3&,int) const;
40
virtual bool isIn(const Vector3&) const;
41
virtual bool isIn(const Sphere&);
43
//friend ostream& operator << (ostream&,const ClippedSphereVol&);
46
#endif // __CLIPPED_SPHERE_VOL_H