added DoRayFuntion that return interpolated normal
This commit is contained in:
parent
43facb8954
commit
fc770bdd96
|
@ -24,6 +24,10 @@
|
||||||
History
|
History
|
||||||
|
|
||||||
$Log: not supported by cvs2svn $
|
$Log: not supported by cvs2svn $
|
||||||
|
Revision 1.22 2006/09/20 17:18:26 ponchio
|
||||||
|
VDistFunct() at line 292 was passed as a temporary.
|
||||||
|
Invalid under g++. Fixed.
|
||||||
|
|
||||||
Revision 1.21 2006/02/09 08:38:04 pietroni
|
Revision 1.21 2006/02/09 08:38:04 pietroni
|
||||||
sintax error corrected
|
sintax error corrected
|
||||||
|
|
||||||
|
@ -331,6 +335,32 @@ namespace vcg {
|
||||||
return(gr.DoRay(FintFunct(),mf,_ray,_maxDist,_t));
|
return(gr.DoRay(FintFunct(),mf,_ray,_maxDist,_t));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <class MESH, class GRID>
|
||||||
|
typename GRID::ObjPtr DoRay(MESH & mesh,GRID & gr, const Ray3<typename GRID::ScalarType> & _ray,
|
||||||
|
const typename GRID::ScalarType & _maxDist,
|
||||||
|
typename GRID::ScalarType & _t,
|
||||||
|
typename GRID::CoordType & _normf)
|
||||||
|
{
|
||||||
|
typedef typename MESH::FaceType FaceType;
|
||||||
|
typedef typename MESH::ScalarType ScalarType;
|
||||||
|
typedef FaceTmark<MESH> MarkerFace;
|
||||||
|
MarkerFace mf;
|
||||||
|
mf.SetMesh(&mesh);
|
||||||
|
typedef vcg::RayTriangleIntersectionFunctor<true> FintFunct;
|
||||||
|
FaceType *f=gr.DoRay(FintFunct(),mf,_ray,_maxDist,_t);
|
||||||
|
GRID::CoordType dir=_ray.Direction();
|
||||||
|
dir.Normalize();
|
||||||
|
GRID::CoordType int_point=_ray.Origin()+_ray.Direction()*_t;
|
||||||
|
GRID::ScalarType alfa,beta,gamma;
|
||||||
|
if (f!=NULL)
|
||||||
|
{
|
||||||
|
f->InterpolationParameters(int_point, alfa, beta, gamma);
|
||||||
|
_normf = (f->V(0)->cN())*alfa+
|
||||||
|
(f->V(1)->cN())*beta+
|
||||||
|
(f->V(2)->cN())*gamma ;
|
||||||
|
}
|
||||||
|
return f;
|
||||||
|
}
|
||||||
|
|
||||||
//**ITERATORS DEFINITION**//
|
//**ITERATORS DEFINITION**//
|
||||||
|
|
||||||
|
@ -351,8 +381,8 @@ namespace vcg {
|
||||||
ClosestFaceIterator(GridType &_Si):ClosestBaseType(_Si,PDistFunct()){}
|
ClosestFaceIterator(GridType &_Si):ClosestBaseType(_Si,PDistFunct()){}
|
||||||
|
|
||||||
// Commented out: it seems unuseful and make gcc complain. p.
|
// Commented out: it seems unuseful and make gcc complain. p.
|
||||||
// void SetMesh(MeshType *m)
|
void SetMesh(MeshType *m)
|
||||||
// {this->tm.SetMesh(m);}
|
{this->tm.SetMesh(m);}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class GRID,class MESH>
|
template <class GRID,class MESH>
|
||||||
|
@ -367,9 +397,9 @@ namespace vcg {
|
||||||
|
|
||||||
ClosestVertexIterator(GridType &_Si):ClosestBaseType(_Si,VDistFunct()){}
|
ClosestVertexIterator(GridType &_Si):ClosestBaseType(_Si,VDistFunct()){}
|
||||||
|
|
||||||
//// Commented out: it seems unuseful and make gcc complain. p.
|
// Commented out: it seems unuseful and make gcc complain. p.
|
||||||
// void SetMesh(MeshType *m)
|
void SetMesh(MeshType *m)
|
||||||
// {this->tm.SetMesh(m);}
|
{this->tm.SetMesh(m);}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class GRID,class MESH>
|
template <class GRID,class MESH>
|
||||||
|
@ -386,9 +416,9 @@ namespace vcg {
|
||||||
|
|
||||||
TriRayIterator(GridType &_Si):RayBaseType(_Si,FintFunct()){}
|
TriRayIterator(GridType &_Si):RayBaseType(_Si,FintFunct()){}
|
||||||
|
|
||||||
//// Commented out: it seems unuseful and make gcc complain. p.
|
// Commented out: it seems unuseful and make gcc complain. p.
|
||||||
// void SetMesh(MeshType *m)
|
void SetMesh(MeshType *m)
|
||||||
// {this->tm.SetMesh(m);}
|
{this->tm.SetMesh(m);}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue