ESyS-Particle  4.0.1
PaddedBlock3D.h
00001 
00002 //                                                         //
00003 // Copyright (c) 2003-2011 by The University of Queensland //
00004 // Earth Systems Science Computational Centre (ESSCC)      //
00005 // http://www.uq.edu.au/esscc                              //
00006 //                                                         //
00007 // Primary Business: Brisbane, Queensland, Australia       //
00008 // Licensed under the Open Software License version 3.0    //
00009 // http://www.opensource.org/licenses/osl-3.0.php          //
00010 //                                                         //
00012 
00013 #ifndef __PADDEDBLOCK3D_H
00014 #define __PADDEDBLOCK3D_H
00015 
00016 //-- project includes --
00017 #include "Geometry/SplitBlock3D.h"
00018 
00019 using std::vector;
00020 
00030 class CPaddedBlock3D : public CSplitBlock3D
00031 {
00032  protected:
00033   double m_pad_size;
00034 
00035   virtual Vec3 getAPoint();
00036   void generate_regular_padding();
00037 
00038  public:
00039   CPaddedBlock3D(double,double,double,double,double,double,double,double,double,double,int,bool circ_x=false);
00040   virtual ~CPaddedBlock3D(){};
00041 
00042   virtual void generate(int,unsigned int);  
00043 };
00044 #endif //__PADDEDBLOCK3D_H