23 namespace SOP_CollisionDetectCLEnums
35 using namespace UT::Literal;
54 myGroup =
"surface_triangles"_UTsh;
55 myTetGroup =
"!surface_triangles"_UTsh;
62 myIgnorepiece =
false;
63 myHittypesattr =
"hittypes"_UTsh;
64 myHitptsattr =
"hitpts"_UTsh;
65 myHituvsattr =
"hituvs"_UTsh;
66 myHitnmlsattr =
"hitnmls"_UTsh;
67 myHitidxattr =
"hitidx"_UTsh;
68 myHitvtxattr =
"hitvtx"_UTsh;
83 if (myGroup != src.myGroup)
return false;
84 if (myTetGroup != src.myTetGroup)
return false;
85 if (myRadiusscale != src.myRadiusscale)
return false;
86 if (myDotets != src.myDotets)
return false;
87 if (myColdetect != src.myColdetect)
return false;
88 if (myDopttri != src.myDopttri)
return false;
89 if (myDoedgeedge != src.myDoedgeedge)
return false;
90 if (myCcdaccuracy != src.myCcdaccuracy)
return false;
91 if (myIgnorepiece != src.myIgnorepiece)
return false;
92 if (myHittypesattr != src.myHittypesattr)
return false;
93 if (myHitptsattr != src.myHitptsattr)
return false;
94 if (myHituvsattr != src.myHituvsattr)
return false;
95 if (myHitnmlsattr != src.myHitnmlsattr)
return false;
96 if (myHitidxattr != src.myHitidxattr)
return false;
97 if (myHitvtxattr != src.myHitvtxattr)
return false;
98 if (myResetKey != src.myResetKey)
return false;
99 if (myLeaveongpu != src.myLeaveongpu)
return false;
116 myGroup =
"surface_triangles"_UTsh;
118 graph->
evalOpParm(myGroup, nodeidx,
"group", time, graph->
isDirect()?
nullptr:depnode);
119 myTetGroup =
"!surface_triangles"_UTsh;
121 graph->
evalOpParm(myTetGroup, nodeidx,
"tetgroup", time, graph->
isDirect()?
nullptr:depnode);
124 graph->
evalOpParm(myRadiusscale, nodeidx,
"radiusscale", time, graph->
isDirect()?
nullptr:depnode);
127 graph->
evalOpParm(myDotets, nodeidx,
"dotets", time, graph->
isDirect()?
nullptr:depnode);
130 graph->
evalOpParm(myColdetect, nodeidx,
"coldetect", time, graph->
isDirect()?
nullptr:depnode);
133 graph->
evalOpParm(myDopttri, nodeidx,
"dopttri", time, graph->
isDirect()?
nullptr:depnode);
136 graph->
evalOpParm(myDoedgeedge, nodeidx,
"doedgeedge", time, graph->
isDirect()?
nullptr:depnode);
138 if (
true && ( (
true&&!(((
int64(getColdetect())!=2)))) ) )
139 graph->
evalOpParm(myCcdaccuracy, nodeidx,
"ccdaccuracy", time, graph->
isDirect()?
nullptr:depnode);
140 myIgnorepiece =
false;
142 graph->
evalOpParm(myIgnorepiece, nodeidx,
"ignorepiece", time, graph->
isDirect()?
nullptr:depnode);
143 myHittypesattr =
"hittypes"_UTsh;
145 graph->
evalOpParm(myHittypesattr, nodeidx,
"hittypesattr", time, graph->
isDirect()?
nullptr:depnode);
146 myHitptsattr =
"hitpts"_UTsh;
148 graph->
evalOpParm(myHitptsattr, nodeidx,
"hitptsattr", time, graph->
isDirect()?
nullptr:depnode);
149 myHituvsattr =
"hituvs"_UTsh;
151 graph->
evalOpParm(myHituvsattr, nodeidx,
"hituvsattr", time, graph->
isDirect()?
nullptr:depnode);
152 myHitnmlsattr =
"hitnmls"_UTsh;
154 graph->
evalOpParm(myHitnmlsattr, nodeidx,
"hitnmlsattr", time, graph->
isDirect()?
nullptr:depnode);
155 myHitidxattr =
"hitidx"_UTsh;
157 graph->
evalOpParm(myHitidxattr, nodeidx,
"hitidxattr", time, graph->
isDirect()?
nullptr:depnode);
158 myHitvtxattr =
"hitvtx"_UTsh;
160 graph->
evalOpParm(myHitvtxattr, nodeidx,
"hitvtxattr", time, graph->
isDirect()?
nullptr:depnode);
163 graph->
evalOpParm(myResetKey, nodeidx,
"resetkey", time, graph->
isDirect()?
nullptr:depnode);
164 myLeaveongpu =
false;
166 graph->
evalOpParm(myLeaveongpu, nodeidx,
"leaveongpu", time, graph->
isDirect()?
nullptr:depnode);
182 template <
typename T>
189 if (idx.
size() != instance.
size()+1)
194 coerceValue(value, myGroup);
197 coerceValue(value, myTetGroup);
200 coerceValue(value, myRadiusscale);
203 coerceValue(value, myDotets);
206 coerceValue(value, myColdetect);
209 coerceValue(value, myDopttri);
212 coerceValue(value, myDoedgeedge);
215 coerceValue(value, myCcdaccuracy);
218 coerceValue(value, myIgnorepiece);
221 coerceValue(value, myHittypesattr);
224 coerceValue(value, myHitptsattr);
227 coerceValue(value, myHituvsattr);
230 coerceValue(value, myHitnmlsattr);
233 coerceValue(value, myHitidxattr);
236 coerceValue(value, myHitvtxattr);
239 coerceValue(value, myResetKey);
242 coerceValue(value, myLeaveongpu);
258 { doGetParmValue(idx, instance, value); }
260 { doGetParmValue(idx, instance, value); }
262 { doGetParmValue(idx, instance, value); }
264 { doGetParmValue(idx, instance, value); }
266 { doGetParmValue(idx, instance, value); }
268 { doGetParmValue(idx, instance, value); }
270 { doGetParmValue(idx, instance, value); }
272 { doGetParmValue(idx, instance, value); }
274 { doGetParmValue(idx, instance, value); }
276 { doGetParmValue(idx, instance, value); }
278 { doGetParmValue(idx, instance, value); }
280 template <
typename T>
287 if (idx.
size() != instance.
size()+1)
292 coerceValue(myGroup, ( ( value ) ));
295 coerceValue(myTetGroup, ( ( value ) ));
298 coerceValue(myRadiusscale, ( ( value ) ));
301 coerceValue(myDotets, ( ( value ) ));
304 coerceValue(myColdetect, clampMinValue(0, clampMaxValue(2, value ) ));
307 coerceValue(myDopttri, ( ( value ) ));
310 coerceValue(myDoedgeedge, ( ( value ) ));
313 coerceValue(myCcdaccuracy, ( ( value ) ));
316 coerceValue(myIgnorepiece, ( ( value ) ));
319 coerceValue(myHittypesattr, ( ( value ) ));
322 coerceValue(myHitptsattr, ( ( value ) ));
325 coerceValue(myHituvsattr, ( ( value ) ));
328 coerceValue(myHitnmlsattr, ( ( value ) ));
331 coerceValue(myHitidxattr, ( ( value ) ));
334 coerceValue(myHitvtxattr, ( ( value ) ));
337 coerceValue(myResetKey, ( ( value ) ));
340 coerceValue(myLeaveongpu, ( ( value ) ));
347 { doSetParmValue(idx, instance, value); }
349 { doSetParmValue(idx, instance, value); }
351 { doSetParmValue(idx, instance, value); }
353 { doSetParmValue(idx, instance, value); }
355 { doSetParmValue(idx, instance, value); }
357 { doSetParmValue(idx, instance, value); }
359 { doSetParmValue(idx, instance, value); }
361 { doSetParmValue(idx, instance, value); }
363 { doSetParmValue(idx, instance, value); }
365 { doSetParmValue(idx, instance, value); }
367 { doSetParmValue(idx, instance, value); }
383 if (fieldnum.
size() < 1)
392 return "radiusscale";
402 return "ccdaccuracy";
404 return "ignorepiece";
406 return "hittypesattr";
412 return "hitnmlsattr";
428 if (fieldnum.
size() < 1)
429 return PARM_UNSUPPORTED;
468 return PARM_UNSUPPORTED;
504 loadData(is, rampdata);
522 int typelen = colon - data.
buffer();
536 {
int64 iv =
v; UTwrite(os, &iv); }
538 { UTwrite<fpreal64>(os, &
v); }
540 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y()); }
542 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y());
543 UTwrite<fpreal64>(os, &v.
z()); }
545 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y());
546 UTwrite<fpreal64>(os, &v.
z()); UTwrite<fpreal64>(os, &v.
w()); }
558 if (s) s->save(ostr);
560 saveData(os, result);
567 ostr << s->getDataTypeToken();
572 saveData(os, result);
576 void save(std::ostream &os)
const
580 saveData(os, myGroup);
581 saveData(os, myTetGroup);
582 saveData(os, myRadiusscale);
583 saveData(os, myDotets);
584 saveData(os, myColdetect);
585 saveData(os, myDopttri);
586 saveData(os, myDoedgeedge);
587 saveData(os, myCcdaccuracy);
588 saveData(os, myIgnorepiece);
589 saveData(os, myHittypesattr);
590 saveData(os, myHitptsattr);
591 saveData(os, myHituvsattr);
592 saveData(os, myHitnmlsattr);
593 saveData(os, myHitidxattr);
594 saveData(os, myHitvtxattr);
595 saveData(os, myResetKey);
596 saveData(os, myLeaveongpu);
609 loadData(is, myGroup);
610 loadData(is, myTetGroup);
611 loadData(is, myRadiusscale);
612 loadData(is, myDotets);
613 loadData(is, myColdetect);
614 loadData(is, myDopttri);
615 loadData(is, myDoedgeedge);
616 loadData(is, myCcdaccuracy);
617 loadData(is, myIgnorepiece);
618 loadData(is, myHittypesattr);
619 loadData(is, myHitptsattr);
620 loadData(is, myHituvsattr);
621 loadData(is, myHitnmlsattr);
622 loadData(is, myHitidxattr);
623 loadData(is, myHitvtxattr);
624 loadData(is, myResetKey);
625 loadData(is, myLeaveongpu);
635 if (!thissop)
return getGroup();
637 OP_Utils::evalOpParm(result, thissop,
"group", cookparms.
getCookTime(), 0);
645 if (!thissop)
return getTetGroup();
647 OP_Utils::evalOpParm(result, thissop,
"tetgroup", cookparms.
getCookTime(), 0);
655 if (!thissop)
return getRadiusscale();
657 OP_Utils::evalOpParm(result, thissop,
"radiusscale", cookparms.
getCookTime(), 0);
665 if (!thissop)
return getDotets();
667 OP_Utils::evalOpParm(result, thissop,
"dotets", cookparms.
getCookTime(), 0);
675 if (!thissop)
return getColdetect();
677 OP_Utils::evalOpParm(result, thissop,
"coldetect", cookparms.
getCookTime(), 0);
685 if (!thissop)
return getDopttri();
687 OP_Utils::evalOpParm(result, thissop,
"dopttri", cookparms.
getCookTime(), 0);
695 if (!thissop)
return getDoedgeedge();
697 OP_Utils::evalOpParm(result, thissop,
"doedgeedge", cookparms.
getCookTime(), 0);
705 if (!thissop)
return getCcdaccuracy();
707 OP_Utils::evalOpParm(result, thissop,
"ccdaccuracy", cookparms.
getCookTime(), 0);
715 if (!thissop)
return getIgnorepiece();
717 OP_Utils::evalOpParm(result, thissop,
"ignorepiece", cookparms.
getCookTime(), 0);
725 if (!thissop)
return getHittypesattr();
727 OP_Utils::evalOpParm(result, thissop,
"hittypesattr", cookparms.
getCookTime(), 0);
735 if (!thissop)
return getHitptsattr();
737 OP_Utils::evalOpParm(result, thissop,
"hitptsattr", cookparms.
getCookTime(), 0);
745 if (!thissop)
return getHituvsattr();
747 OP_Utils::evalOpParm(result, thissop,
"hituvsattr", cookparms.
getCookTime(), 0);
755 if (!thissop)
return getHitnmlsattr();
757 OP_Utils::evalOpParm(result, thissop,
"hitnmlsattr", cookparms.
getCookTime(), 0);
765 if (!thissop)
return getHitidxattr();
767 OP_Utils::evalOpParm(result, thissop,
"hitidxattr", cookparms.
getCookTime(), 0);
775 if (!thissop)
return getHitvtxattr();
777 OP_Utils::evalOpParm(result, thissop,
"hitvtxattr", cookparms.
getCookTime(), 0);
785 if (!thissop)
return getResetKey();
787 OP_Utils::evalOpParm(result, thissop,
"resetkey", cookparms.
getCookTime(), 0);
795 if (!thissop)
return getLeaveongpu();
797 OP_Utils::evalOpParm(result, thissop,
"leaveongpu", cookparms.
getCookTime(), 0);
void getNestParmValue(TempIndex idx, TempIndex instance, UT_SharedPtr< UT_Ramp > &value) const override
void doGetParmValue(TempIndex idx, TempIndex instance, T &value) const
void setNestParmValue(TempIndex idx, TempIndex instance, const exint &value) override
static void loadData(UT_IStream &is, PRM_DataItemHandle &v)
static void saveData(std::ostream &os, UT_SharedPtr< UT_Ramp > s)
void getNestParmValue(TempIndex idx, TempIndex instance, exint &value) const override
static void saveData(std::ostream &os, UT_Vector3D v)
void setHitidxattr(const UT_StringHolder &val)
UT_StringHolder opHitptsattr(const SOP_NodeVerb::CookParms &cookparms) const
bool load(UT_IStream &is)
UT_StringHolder opHituvsattr(const SOP_NodeVerb::CookParms &cookparms) const
bool operator==(const SOP_CollisionDetectCLParms &src) const
SOP_Node * getNode() const
void setHitvtxattr(const UT_StringHolder &val)
const UT_StringHolder & getHituvsattr() const
void setGroup(const UT_StringHolder &val)
bool operator!=(const SOP_CollisionDetectCLParms &src) const
exint bread(int32 *buffer, exint asize=1)
static void loadData(UT_IStream &is, UT_Vector2I &v)
GT_API const UT_StringHolder time
constexpr SYS_FORCE_INLINE T & y() noexcept
fpreal64 getCcdaccuracy() const
fpreal64 opResetKey(const SOP_NodeVerb::CookParms &cookparms) const
void setNestParmValue(TempIndex idx, TempIndex instance, const PRM_DataItemHandle &value) override
GLsizei const GLfloat * value
static void loadData(UT_IStream &is, fpreal64 &v)
UT_StringHolder opHitvtxattr(const SOP_NodeVerb::CookParms &cookparms) const
void setDopttri(bool val)
void setRadiusscale(fpreal64 val)
const OP_Context & context() const
const UT_StringHolder & getHitvtxattr() const
constexpr SYS_FORCE_INLINE T & z() noexcept
SOP_CollisionDetectCLParms()
SYS_FORCE_INLINE const char * buffer() const
const UT_StringHolder & getHitnmlsattr() const
bool getIgnorepiece() const
An output stream object that owns its own string buffer storage.
void getNestParmValue(TempIndex idx, TempIndex instance, fpreal &value) const override
**But if you need a result
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix4D &value) override
bool getDoedgeedge() const
static PRM_DataItemHandle parseBinary(const char *type, UT_IStream &is)
const UT_WorkBuffer & str()
Returns a read-only reference to the underlying UT_WorkBuffer.
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_SharedPtr< UT_Ramp > &value) override
static void saveData(std::ostream &os, UT_Matrix2D v)
constexpr SYS_FORCE_INLINE T & x() noexcept
static void saveData(std::ostream &os, fpreal64 v)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_StringHolder &value) override
UT_SharedPtr< const PRM_DataItem > PRM_DataItemHandle
constexpr SYS_FORCE_INLINE T & x() noexcept
void copyFrom(const OP_NodeParms *src) override
void setResetKey(fpreal64 val)
bool operator==(const BaseDimensions< T > &a, const BaseDimensions< Y > &b)
static void loadData(UT_IStream &is, UT_StringHolder &v)
bool opLeaveongpu(const SOP_NodeVerb::CookParms &cookparms) const
const UT_StringHolder & getHitptsattr() const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector4D &value) const override
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector3D &value) const override
void getNestParmValue(TempIndex idx, TempIndex instance, UT_StringHolder &value) const override
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix2D &value) const override
static void loadData(UT_IStream &is, UT_Vector3D &v)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector2D &value) override
UT_StringHolder opTetGroup(const SOP_NodeVerb::CookParms &cookparms) const
SYS_FORCE_INLINE const char * buffer() const
std::shared_ptr< T > UT_SharedPtr
Wrapper around std::shared_ptr.
void loadFromOpSubclass(const LoadParms &loadparms) override
constexpr SYS_FORCE_INLINE T & z() noexcept
static void saveData(std::ostream &os, int64 v)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix3D &value) const override
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector2D &value) const override
const OP_GraphProxy * graph() const
const char * getNestParmName(TempIndex fieldnum) const override
static void saveData(std::ostream &os, UT_Vector4D v)
static void saveData(std::ostream &os, UT_StringHolder s)
void setCcdaccuracy(fpreal64 val)
UT_StringHolder opHitnmlsattr(const SOP_NodeVerb::CookParms &cookparms) const
SYS_FORCE_INLINE UT_StringHolder getToken(Coldetect enum_value)
void buildFromOp(const OP_GraphProxy *graph, exint nodeidx, fpreal time, DEP_MicroNode *depnode)
bool opDopttri(const SOP_NodeVerb::CookParms &cookparms) const
const UT_StringHolder & getHitidxattr() const
bool opIgnorepiece(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, UT_Matrix4D v)
void save(std::ostream &os) const
bool isParmColorRamp(exint idx) const override
bool getLeaveongpu() const
virtual void evalOpParm(int64 &v, NodeIdx node, const char *parmname, fpreal time, DEP_MicroNode *depnode) const =0
UT_StringHolder opHittypesattr(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, bool v)
void setLeaveongpu(bool val)
bool opDotets(const SOP_NodeVerb::CookParms &cookparms) const
void saveBinary(std::ostream &os) const
Save string to binary stream.
exint getNestNumParms(TempIndex idx) const override
GT_API const UT_StringHolder version
void setTetGroup(const UT_StringHolder &val)
fpreal64 getResetKey() const
const UT_StringHolder & getHittypesattr() const
void setHittypesattr(const UT_StringHolder &val)
void doSetParmValue(TempIndex idx, TempIndex instance, const T &value)
static void loadData(UT_IStream &is, int64 &v)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector4D &value) override
bool opDoedgeedge(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Matrix4D &v)
DEP_MicroNode * depnode() const
const UT_StringHolder & getTetGroup() const
LeafData & operator=(const LeafData &)=delete
Utility class for containing a color ramp.
fpreal64 opRadiusscale(const SOP_NodeVerb::CookParms &cookparms) const
constexpr SYS_FORCE_INLINE T & w() noexcept
UT_StringHolder opGroup(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Vector4D &v)
virtual UT_StringHolder baseGetSignature() const
fpreal64 opCcdaccuracy(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Vector3I &v)
void setColdetect(Coldetect val)
fpreal getCookTime() const
static void loadData(UT_IStream &is, UT_Matrix3D &v)
static void loadData(UT_IStream &is, bool &v)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector3D &value) override
ParmType getNestParmType(TempIndex fieldnum) const override
const char * findChar(int c) const
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix2D &value) override
static void loadData(UT_IStream &is, UT_Vector2D &v)
const UT_StringHolder & getGroup() const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix4D &value) const override
void setHitnmlsattr(const UT_StringHolder &val)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix3D &value) override
constexpr SYS_FORCE_INLINE T & y() noexcept
void setNestParmValue(TempIndex idx, TempIndex instance, const fpreal &value) override
void setIgnorepiece(bool val)
Coldetect opColdetect(const SOP_NodeVerb::CookParms &cookparms) const
virtual bool isDirect() const =0
Direct proxies mirror actual nodes:
void getNestParmValue(TempIndex idx, TempIndex instance, PRM_DataItemHandle &value) const override
static void saveData(std::ostream &os, UT_Vector2D v)
void setHitptsattr(const UT_StringHolder &val)
Coldetect getColdetect() const
static void saveData(std::ostream &os, UT_Matrix3D v)
constexpr SYS_FORCE_INLINE T & y() noexcept
UT_StringHolder opHitidxattr(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Vector4I &v)
fpreal64 getRadiusscale() const
SYS_FORCE_INLINE bool isstring() const
void setHituvsattr(const UT_StringHolder &val)
static void loadData(UT_IStream &is, UT_SharedPtr< UT_Ramp > &v)
SYS_FORCE_INLINE void strncpy(const char *src, exint maxlen)
static void loadData(UT_IStream &is, UT_Matrix2D &v)
static void saveData(std::ostream &os, PRM_DataItemHandle s)
constexpr SYS_FORCE_INLINE T & x() noexcept
void setDoedgeedge(bool val)