PolyEvaluator.h

Go to the documentation of this file.
00001 // Copyright (C) 2005 Dave Griffiths
00002 //
00003 // This program is free software; you can redistribute it and/or modify
00004 // it under the terms of the GNU General Public License as published by
00005 // the Free Software Foundation; either version 2 of the License, or
00006 // (at your option) any later version.
00007 //
00008 // This program is distributed in the hope that it will be useful,
00009 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00010 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00011 // GNU General Public License for more details.
00012 //
00013 // You should have received a copy of the GNU General Public License
00014 // along with this program; if not, write to the Free Software
00015 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
00016 
00017 #include <string>
00018 #include <map>
00019 #include <assert.h>
00020 #include "Evaluator.h"
00021 
00022 #ifndef N_POLYEVALUATOR
00023 #define N_POLYEVALUATOR
00024 
00025 namespace Fluxus
00026 {
00027 
00028 class PolyPrimitive;
00029 
00033 class PolyEvaluator : public Evaluator
00034 {
00035 public:
00036     PolyEvaluator(const PolyPrimitive *prim);
00037     virtual ~PolyEvaluator();
00038     
00039     virtual bool IntersectLine(const dVector &start, const dVector &end, vector<Point> &points);
00040     virtual Point ClosestPoint(const dVector &position);
00041     
00042 private:
00043     const PolyPrimitive *m_Prim;
00044 
00045     bool IntersectTriStrip(const dVector &start, const dVector &end, vector<Point> &points);
00046     bool IntersectQuads(const dVector &start, const dVector &end, vector<Point> &points);
00047     bool IntersectTriList(const dVector &start, const dVector &end, vector<Point> &points);
00048     bool IntersectTriFan(const dVector &start, const dVector &end, vector<Point> &points);
00049     bool IntersectPolygon(const dVector &start, const dVector &end, vector<Point> &points);
00050 
00051     Point InterpolatePData(dVector bary, unsigned int i1, unsigned int i2, unsigned int i3);
00052 
00053 };
00054 
00055 }
00056 
00057 #endif

Generated on Wed Sep 17 21:16:30 2008 for The Fluxus Renderer (libfluxus) by  doxygen 1.5.1