00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef __GAS_GeometryToSDF__
00020 #define __GAS_GeometryToSDF__
00021
00022 #include "GAS_API.h"
00023
00024 #include "GAS_SubSolver.h"
00025 #include "GAS_Utils.h"
00026
00027 class SIM_RawField;
00028
00029 class GAS_API GAS_GeometryToSDF : public GAS_SubSolver
00030 {
00031 public:
00032 GET_DATA_FUNC_S(GAS_NAME_SURFACE, SurfaceName);
00033 GET_DATA_FUNC_S(GAS_NAME_GEOMETRY, GeometryName);
00034
00035 GETSET_DATA_FUNCS_I(SIM_NAME_MODE, Mode);
00036 GETSET_DATA_FUNCS_B(SIM_NAME_LASERSCAN, LaserScan);
00037 GETSET_DATA_FUNCS_B(SIM_NAME_FIXSIGNS, FixSigns);
00038 GETSET_DATA_FUNCS_B(SIM_NAME_FORCEBOUNDS, ForceBounds);
00039 GETSET_DATA_FUNCS_F(SIM_NAME_OFFSET, Offset);
00040 GETSET_DATA_FUNCS_F(SIM_NAME_TOLERANCE, Tolerance);
00041 GETSET_DATA_FUNCS_B(SIM_NAME_INVERT, Invert);
00042 GETSET_DATA_FUNCS_I("numneighbour", NumNeighbour);
00043 GETSET_DATA_FUNCS_I("sweepcount", SweepCount);
00044 GETSET_DATA_FUNCS_F("sweepalpha", SweepThreshold);
00045
00046 protected:
00047 explicit GAS_GeometryToSDF(const SIM_DataFactory *factory);
00048 virtual ~GAS_GeometryToSDF();
00049
00050
00051
00052 virtual bool solveGasSubclass(SIM_Engine &engine,
00053 SIM_Object *obj,
00054 SIM_Time time,
00055 SIM_Time timestep);
00056
00057 void geometryToSDF(SIM_Object *obj,
00058 SIM_RawField *destfield,
00059 const GU_Detail *geo,
00060 const UT_DMatrix4 &xform);
00061
00062 private:
00063 static const SIM_DopDescription *getDopDescription();
00064
00065 DECLARE_STANDARD_GETCASTTOTYPE();
00066 DECLARE_DATAFACTORY(GAS_GeometryToSDF,
00067 GAS_SubSolver,
00068 "Gas Geometry To SDF",
00069 getDopDescription());
00070 };
00071
00072 #endif
00073