added Grid to return all the cells sharing a specified edge

This commit is contained in:
ganovelli 2004-06-25 18:34:23 +00:00
parent 39028e633e
commit 260665c528
1 changed files with 6 additions and 5 deletions

View File

@ -24,6 +24,9 @@
History History
$Log: not supported by cvs2svn $ $Log: not supported by cvs2svn $
Revision 1.4 2004/06/23 15:49:03 ponchio
Added some help and inndentation
Revision 1.3 2004/05/12 18:50:58 ganovelli Revision 1.3 2004/05/12 18:50:58 ganovelli
changed calls to Dist changed calls to Dist
@ -167,11 +170,10 @@ class GridStaticPtr
} }
/// Date le coordinate di un grid point ritorna le celle che condividono /// Date le coordinate di un grid point (corner minx,miy,minz) ritorna le celle che condividono
/// l'edge cell che parte dal grid point in direzione axis /// l'edge cell che parte dal grid point in direzione axis
inline void Grid( Point3i p, const int axis, inline void Grid( Point3i p, const int axis,
std::vector<Cell*> & cl, std::vector<Cell*> & cl)
std::vector<Point3i> &o)
{ {
#ifndef NDEBUG #ifndef NDEBUG
if ( p[0]<0 || p[0]>siz[0] || if ( p[0]<0 || p[0]>siz[0] ||
@ -192,8 +194,7 @@ class GridStaticPtr
for(j = max(y-1,0); j <= min( y,siz[axis1]-1);++j){ for(j = max(y-1,0); j <= min( y,siz[axis1]-1);++j){
p[axis0]=i; p[axis0]=i;
p[axis1]=j; p[axis1]=j;
cl.push_back(Grid(p[0]+siz[0]*(p[1]+siz[1]*p[2]))); ; cl.push_back(Grid(p[0]+siz[0]*(p[1]+siz[1]*p[2])));
o.push_back(p);
} }
} }