Added ValidCell check to manage invalid cell in the trivial_walker.

Corrected compiling error due to the derivation from a templated base class (a few "this->" required)
This commit is contained in:
Paolo Cignoni 2014-08-23 01:35:15 +00:00
parent 305ac24a23
commit 9b519cb2b8
1 changed files with 18 additions and 11 deletions
vcg/complex/algorithms/create

View File

@ -34,8 +34,9 @@ class SimpleVolume : public BasicGrid<typename VOX_TYPE::ScalarType>
public: public:
typedef VOX_TYPE VoxelType; typedef VOX_TYPE VoxelType;
typedef typename VoxelType::ScalarType ScalarType; typedef typename VoxelType::ScalarType ScalarType;
typedef typename BasicGrid<typename VOX_TYPE::ScalarType>::Box3x Box3x;
const Point3i &ISize() {return siz;} /// Dimensioni griglia come numero di celle per lato const Point3i &ISize() {return this->siz;} /// Dimensioni griglia come numero di celle per lato
ScalarType Val(const int &x,const int &y,const int &z) const { ScalarType Val(const int &x,const int &y,const int &z) const {
return cV(x,y,z).V(); return cV(x,y,z).V();
@ -48,17 +49,18 @@ public:
} }
VOX_TYPE &V(const int &x,const int &y,const int &z) { VOX_TYPE &V(const int &x,const int &y,const int &z) {
return Vol[x+y*siz[0]+z*siz[0]*siz[1]]; return Vol[x+y*this->siz[0]+z*this->siz[0]*this->siz[1]];
} }
VOX_TYPE &V(const Point3i &pi) { VOX_TYPE &V(const Point3i &pi) {
return Vol[ pi[0] + pi[1]*siz[0] + pi[2]*siz[0]*siz[1] ]; return Vol[ pi[0] + pi[1]*this->siz[0] + pi[2]*this->siz[0]*this->siz[1] ];
} }
const VOX_TYPE &cV(const int &x,const int &y,const int &z) const { const VOX_TYPE &cV(const int &x,const int &y,const int &z) const {
return Vol[x+y*siz[0]+z*siz[0]*siz[1]]; return Vol[x+y*this->siz[0]+z*this->siz[0]*this->siz[1]];
} }
bool ValidCell(const Point3i & /*p0*/, const Point3i & /*p1*/) const { return true;}
template < class VertexPointerType > template < class VertexPointerType >
void GetXIntercept(const vcg::Point3i &p1, const vcg::Point3i &p2, VertexPointerType &v, const float thr) void GetXIntercept(const vcg::Point3i &p1, const vcg::Point3i &p2, VertexPointerType &v, const float thr)
@ -99,9 +101,9 @@ public:
void Init(Point3i _sz, Box3x bb) void Init(Point3i _sz, Box3x bb)
{ {
siz=_sz; this->siz=_sz;
this->bbox = bb; this->bbox = bb;
Vol.resize(siz[0]*siz[1]*siz[2]); Vol.resize(this->siz[0]*this->siz[1]*this->siz[2]);
this->ComputeDimAndVoxel(); this->ComputeDimAndVoxel();
} }
@ -157,14 +159,18 @@ private:
typedef typename MeshType::VertexPointer VertexPointer; typedef typename MeshType::VertexPointer VertexPointer;
public: public:
// bbox is the portion of the volume to be computed // subbox is the portion of the volume to be computed
// resolution determine the sampling step: // resolution determine the sampling step:
// should be a divisor of bbox size (e.g. if bbox size is 256^3 resolution could be 128,64, etc) // should be a divisor of bbox size (e.g. if bbox size is 256^3 resolution could be 128,64, etc)
void Init(VolumeType &volume) void Init(VolumeType &volume)
{
Init(volume,Box3i(Point3i(0,0,0),volume.ISize()));
}
void Init(VolumeType &volume, Box3i subbox)
{ {
_bbox = Box3i(Point3i(0,0,0),volume.ISize()); _bbox = subbox;
_slice_dimension = _bbox.DimX()*_bbox.DimZ(); _slice_dimension = _bbox.DimX()*_bbox.DimZ();
_x_cs = new VertexIndex[ _slice_dimension ]; _x_cs = new VertexIndex[ _slice_dimension ];
@ -173,7 +179,7 @@ private:
_x_ns = new VertexIndex[ _slice_dimension ]; _x_ns = new VertexIndex[ _slice_dimension ];
_z_ns = new VertexIndex[ _slice_dimension ]; _z_ns = new VertexIndex[ _slice_dimension ];
}; }
~TrivialWalker() ~TrivialWalker()
{_thr=0;} {_thr=0;}
@ -201,7 +207,8 @@ private:
{ {
p1.X()=i; p1.Y()=j; p1.Z()=k; p1.X()=i; p1.Y()=j; p1.Z()=k;
p2.X()=i+1; p2.Y()=j+1; p2.Z()=k+1; p2.X()=i+1; p2.Y()=j+1; p2.Z()=k+1;
extractor.ProcessCell(p1, p2); if(volume.ValidCell(p1,p2))
extractor.ProcessCell(p1, p2);
} }
} }
NextSlice(); NextSlice();