00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef __GAS_BuildCollisionMask__
00020 #define __GAS_BuildCollisionMask__
00021
00022 #include "GAS_API.h"
00023
00024 #include <UT/UT_ThreadedAlgorithm.h>
00025 #include <GU/GU_Detail.h>
00026
00027 #include "GAS_SubSolver.h"
00028 #include "GAS_Utils.h"
00029
00030 class GU_Detail;
00031 class SIM_VectorField;
00032 class SIM_IndexField;
00033
00034 class GAS_API GAS_BuildCollisionMask : public GAS_SubSolver
00035 {
00036 public:
00037 GET_DATA_FUNC_S(GAS_NAME_FIELD, FieldName);
00038 GET_DATA_FUNC_S(GAS_NAME_COLLISION, CollisionName);
00039 GET_DATA_FUNC_S(GAS_NAME_COLLISIONVELOCITY, CollisionVelocityName);
00040 GET_DATA_FUNC_S(GAS_NAME_INDEX, IndexFieldName);
00041 GETSET_DATA_FUNCS_B("usepointvelocity", UsePointVelocity);
00042 GETSET_DATA_FUNCS_B("usevolumevelocity", UseSDFVelocity);
00043 GETSET_DATA_FUNCS_B("allownonsdf", AllowNonSDF);
00044
00045 GET_DATA_FUNC_B("usebandwidth", UseBandwidth);
00046 GET_DATA_FUNC_F("bandwidth", Bandwidth);
00047 GET_DATA_FUNC_B("clamptobandwidth", ClampToBandwidth);
00048
00049 GET_DATA_FUNC_F("particlebandwidth", ParticleBandwidth);
00050 protected:
00051 explicit GAS_BuildCollisionMask(const SIM_DataFactory *factory);
00052 virtual ~GAS_BuildCollisionMask();
00053
00054
00055 virtual bool solveGasSubclass(SIM_Engine &engine,
00056 SIM_Object *obj,
00057 SIM_Time time,
00058 SIM_Time timestep);
00059
00060 void buildCollisionMask(SIM_Object *obj,
00061 SIM_ScalarField *collisionmask,
00062 SIM_VectorField *collisionvel,
00063 SIM_IndexField *index);
00064
00065 private:
00066 static const SIM_DopDescription *getDopDescription();
00067
00068 DECLARE_STANDARD_GETCASTTOTYPE();
00069 DECLARE_DATAFACTORY(GAS_BuildCollisionMask,
00070 GAS_SubSolver,
00071 "Gas BuildCollisionMask",
00072 getDopDescription());
00073 };
00074
00075 #endif