37 myOverrideOutput =
false;
40 myOverrideBounds =
false;
54 myFileName =
"./sdf$F4.simdata"_UTsh;
56 myBuildPolySoup =
false;
69 if (myOutput != src.myOutput)
return false;
70 if (myMode != src.myMode)
return false;
71 if (myUniformSamples != src.myUniformSamples)
return false;
72 if (myDivs != src.myDivs)
return false;
73 if (mySampleDiv != src.mySampleDiv)
return false;
74 if (myDivSize != src.myDivSize)
return false;
75 if (myOverrideOutput != src.myOverrideOutput)
return false;
76 if (myIsoDiv != src.myIsoDiv)
return false;
77 if (myPadBounds != src.myPadBounds)
return false;
78 if (myOverrideBounds != src.myOverrideBounds)
return false;
79 if (myMin != src.myMin)
return false;
80 if (myMax != src.myMax)
return false;
81 if (myTol != src.myTol)
return false;
82 if (myOffset != src.myOffset)
return false;
83 if (myLaserScan != src.myLaserScan)
return false;
84 if (myFixSigns != src.myFixSigns)
return false;
85 if (myForceBounds != src.myForceBounds)
return false;
86 if (myInvert != src.myInvert)
return false;
87 if (myNumNeighbour != src.myNumNeighbour)
return false;
88 if (mySweepCount != src.mySweepCount)
return false;
89 if (mySweepThreshold != src.mySweepThreshold)
return false;
90 if (myTetraType != src.myTetraType)
return false;
91 if (myFileMode != src.myFileMode)
return false;
92 if (myFileName != src.myFileName)
return false;
93 if (myName != src.myName)
return false;
94 if (myBuildPolySoup != src.myBuildPolySoup)
return false;
112 graph->
evalOpParm(myOutput, nodeidx,
"output", time, graph->
isDirect()?
nullptr:depnode);
116 myUniformSamples = 4;
118 graph->
evalOpParm(myUniformSamples, nodeidx,
"uniformsamples", time, graph->
isDirect()?
nullptr:depnode);
124 graph->
evalOpParm(mySampleDiv, nodeidx,
"samplediv", time, graph->
isDirect()?
nullptr:depnode);
127 graph->
evalOpParm(myDivSize, nodeidx,
"divsize", time, graph->
isDirect()?
nullptr:depnode);
128 myOverrideOutput =
false;
130 graph->
evalOpParm(myOverrideOutput, nodeidx,
"overrideoutput", time, graph->
isDirect()?
nullptr:depnode);
133 graph->
evalOpParm(myIsoDiv, nodeidx,
"isodiv", time, graph->
isDirect()?
nullptr:depnode);
136 graph->
evalOpParm(myPadBounds, nodeidx,
"padbounds", time, graph->
isDirect()?
nullptr:depnode);
137 myOverrideBounds =
false;
139 graph->
evalOpParm(myOverrideBounds, nodeidx,
"overridebounds", time, graph->
isDirect()?
nullptr:depnode);
151 graph->
evalOpParm(myOffset, nodeidx,
"offset", time, graph->
isDirect()?
nullptr:depnode);
154 graph->
evalOpParm(myLaserScan, nodeidx,
"laserscan", time, graph->
isDirect()?
nullptr:depnode);
157 graph->
evalOpParm(myFixSigns, nodeidx,
"fixsigns", time, graph->
isDirect()?
nullptr:depnode);
158 myForceBounds =
true;
160 graph->
evalOpParm(myForceBounds, nodeidx,
"forcebounds", time, graph->
isDirect()?
nullptr:depnode);
163 graph->
evalOpParm(myInvert, nodeidx,
"invert", time, graph->
isDirect()?
nullptr:depnode);
166 graph->
evalOpParm(myNumNeighbour, nodeidx,
"numneighbour", time, graph->
isDirect()?
nullptr:depnode);
169 graph->
evalOpParm(mySweepCount, nodeidx,
"sweepcount", time, graph->
isDirect()?
nullptr:depnode);
170 mySweepThreshold = 2;
172 graph->
evalOpParm(mySweepThreshold, nodeidx,
"sweepalpha", time, graph->
isDirect()?
nullptr:depnode);
175 graph->
evalOpParm(myTetraType, nodeidx,
"tetratype", time, graph->
isDirect()?
nullptr:depnode);
178 graph->
evalOpParm(myFileMode, nodeidx,
"filemode", time, graph->
isDirect()?
nullptr:depnode);
179 myFileName =
"./sdf$F4.simdata"_UTsh;
180 if (
true && ( (getFileMode()!=3) ) )
181 graph->
evalOpParm(myFileName, nodeidx,
"filename", time, graph->
isDirect()?
nullptr:depnode);
185 myBuildPolySoup =
false;
187 graph->
evalOpParm(myBuildPolySoup, nodeidx,
"buildpolysoup", time, graph->
isDirect()?
nullptr:depnode);
203 template <
typename T>
210 if (idx.
size() != instance.
size()+1)
306 { doGetParmValue(idx, instance, value); }
308 { doGetParmValue(idx, instance, value); }
310 { doGetParmValue(idx, instance, value); }
312 { doGetParmValue(idx, instance, value); }
314 { doGetParmValue(idx, instance, value); }
316 { doGetParmValue(idx, instance, value); }
318 { doGetParmValue(idx, instance, value); }
320 { doGetParmValue(idx, instance, value); }
322 { doGetParmValue(idx, instance, value); }
324 { doGetParmValue(idx, instance, value); }
326 { doGetParmValue(idx, instance, value); }
328 template <
typename T>
335 if (idx.
size() != instance.
size()+1)
422 { doSetParmValue(idx, instance, value); }
424 { doSetParmValue(idx, instance, value); }
426 { doSetParmValue(idx, instance, value); }
428 { doSetParmValue(idx, instance, value); }
430 { doSetParmValue(idx, instance, value); }
432 { doSetParmValue(idx, instance, value); }
434 { doSetParmValue(idx, instance, value); }
436 { doSetParmValue(idx, instance, value); }
438 { doSetParmValue(idx, instance, value); }
440 { doSetParmValue(idx, instance, value); }
442 { doSetParmValue(idx, instance, value); }
458 if (fieldnum.
size() < 1)
467 return "uniformsamples";
475 return "overrideoutput";
481 return "overridebounds";
495 return "forcebounds";
499 return "numneighbour";
513 return "buildpolysoup";
521 if (fieldnum.
size() < 1)
522 return PARM_UNSUPPORTED;
615 loadData(is, rampdata);
633 int typelen = colon - data.
buffer();
647 {
int64 iv =
v; UTwrite(os, &iv); }
649 { UTwrite<fpreal64>(os, &
v); }
651 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y()); }
653 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y());
654 UTwrite<fpreal64>(os, &v.
z()); }
656 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y());
657 UTwrite<fpreal64>(os, &v.
z()); UTwrite<fpreal64>(os, &v.
w()); }
669 if (s) s->save(ostr);
671 saveData(os, result);
678 ostr << s->getDataTypeToken();
683 saveData(os, result);
687 void save(std::ostream &os)
const
691 saveData(os, myOutput);
692 saveData(os, myMode);
693 saveData(os, myUniformSamples);
694 saveData(os, myDivs);
695 saveData(os, mySampleDiv);
696 saveData(os, myDivSize);
697 saveData(os, myOverrideOutput);
698 saveData(os, myIsoDiv);
699 saveData(os, myPadBounds);
700 saveData(os, myOverrideBounds);
704 saveData(os, myOffset);
705 saveData(os, myLaserScan);
706 saveData(os, myFixSigns);
707 saveData(os, myForceBounds);
708 saveData(os, myInvert);
709 saveData(os, myNumNeighbour);
710 saveData(os, mySweepCount);
711 saveData(os, mySweepThreshold);
712 saveData(os, myTetraType);
713 saveData(os, myFileMode);
714 saveData(os, myFileName);
715 saveData(os, myName);
716 saveData(os, myBuildPolySoup);
729 loadData(is, myOutput);
730 loadData(is, myMode);
731 loadData(is, myUniformSamples);
732 loadData(is, myDivs);
733 loadData(is, mySampleDiv);
734 loadData(is, myDivSize);
735 loadData(is, myOverrideOutput);
736 loadData(is, myIsoDiv);
737 loadData(is, myPadBounds);
738 loadData(is, myOverrideBounds);
742 loadData(is, myOffset);
743 loadData(is, myLaserScan);
744 loadData(is, myFixSigns);
745 loadData(is, myForceBounds);
746 loadData(is, myInvert);
747 loadData(is, myNumNeighbour);
748 loadData(is, mySweepCount);
749 loadData(is, mySweepThreshold);
750 loadData(is, myTetraType);
751 loadData(is, myFileMode);
752 loadData(is, myFileName);
753 loadData(is, myName);
754 loadData(is, myBuildPolySoup);
764 if (!thissop)
return getOutput();
766 OP_Utils::evalOpParm(result, thissop,
"output", cookparms.
getCookTime(), 0);
774 if (!thissop)
return getMode();
776 OP_Utils::evalOpParm(result, thissop,
"mode", cookparms.
getCookTime(), 0);
784 if (!thissop)
return getUniformSamples();
786 OP_Utils::evalOpParm(result, thissop,
"uniformsamples", cookparms.
getCookTime(), 0);
794 if (!thissop)
return getDivs();
796 OP_Utils::evalOpParm(result, thissop,
"divs", cookparms.
getCookTime(), 0);
804 if (!thissop)
return getSampleDiv();
806 OP_Utils::evalOpParm(result, thissop,
"samplediv", cookparms.
getCookTime(), 0);
814 if (!thissop)
return getDivSize();
816 OP_Utils::evalOpParm(result, thissop,
"divsize", cookparms.
getCookTime(), 0);
824 if (!thissop)
return getOverrideOutput();
826 OP_Utils::evalOpParm(result, thissop,
"overrideoutput", cookparms.
getCookTime(), 0);
834 if (!thissop)
return getIsoDiv();
836 OP_Utils::evalOpParm(result, thissop,
"isodiv", cookparms.
getCookTime(), 0);
844 if (!thissop)
return getPadBounds();
846 OP_Utils::evalOpParm(result, thissop,
"padbounds", cookparms.
getCookTime(), 0);
854 if (!thissop)
return getOverrideBounds();
856 OP_Utils::evalOpParm(result, thissop,
"overridebounds", cookparms.
getCookTime(), 0);
864 if (!thissop)
return getMin();
866 OP_Utils::evalOpParm(result, thissop,
"min", cookparms.
getCookTime(), 0);
874 if (!thissop)
return getMax();
876 OP_Utils::evalOpParm(result, thissop,
"max", cookparms.
getCookTime(), 0);
884 if (!thissop)
return getTol();
886 OP_Utils::evalOpParm(result, thissop,
"tol", cookparms.
getCookTime(), 0);
894 if (!thissop)
return getOffset();
896 OP_Utils::evalOpParm(result, thissop,
"offset", cookparms.
getCookTime(), 0);
904 if (!thissop)
return getLaserScan();
906 OP_Utils::evalOpParm(result, thissop,
"laserscan", cookparms.
getCookTime(), 0);
914 if (!thissop)
return getFixSigns();
916 OP_Utils::evalOpParm(result, thissop,
"fixsigns", cookparms.
getCookTime(), 0);
924 if (!thissop)
return getForceBounds();
926 OP_Utils::evalOpParm(result, thissop,
"forcebounds", cookparms.
getCookTime(), 0);
934 if (!thissop)
return getInvert();
936 OP_Utils::evalOpParm(result, thissop,
"invert", cookparms.
getCookTime(), 0);
944 if (!thissop)
return getNumNeighbour();
946 OP_Utils::evalOpParm(result, thissop,
"numneighbour", cookparms.
getCookTime(), 0);
954 if (!thissop)
return getSweepCount();
956 OP_Utils::evalOpParm(result, thissop,
"sweepcount", cookparms.
getCookTime(), 0);
964 if (!thissop)
return getSweepThreshold();
966 OP_Utils::evalOpParm(result, thissop,
"sweepalpha", cookparms.
getCookTime(), 0);
974 if (!thissop)
return getTetraType();
976 OP_Utils::evalOpParm(result, thissop,
"tetratype", cookparms.
getCookTime(), 0);
984 if (!thissop)
return getFileMode();
986 OP_Utils::evalOpParm(result, thissop,
"filemode", cookparms.
getCookTime(), 0);
994 if (!thissop)
return getFileName();
996 OP_Utils::evalOpParm(result, thissop,
"filename", cookparms.
getCookTime(), 0);
1004 if (!thissop)
return getName();
1006 OP_Utils::evalOpParm(result, thissop,
"name", cookparms.
getCookTime(), 0);
1014 if (!thissop)
return getBuildPolySoup();
1016 OP_Utils::evalOpParm(result, thissop,
"buildpolysoup", cookparms.
getCookTime(), 0);
1023 int64 myUniformSamples;
1027 bool myOverrideOutput;
1030 bool myOverrideBounds;
1039 int64 myNumNeighbour;
1041 int64 mySweepThreshold;
1046 bool myBuildPolySoup;
int64 opUniformSamples(const SOP_NodeVerb::CookParms &cookparms) const
bool opForceBounds(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Vector3I &v)
static void saveData(std::ostream &os, UT_Vector4D v)
void setOffset(fpreal64 val)
bool getLaserScan() const
void setForceBounds(bool val)
void setLaserScan(bool val)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_StringHolder &value) const override
void setOutput(int64 val)
bool opOverrideOutput(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, fpreal64 &v)
void setOverrideOutput(bool val)
SOP_Node * getNode() const
bool operator!=(const SOP_IsoOffsetParms &src) const
bool opInvert(const SOP_NodeVerb::CookParms &cookparms) const
exint getNestNumParms(TempIndex idx) const override
void setTetraType(int64 val)
const UT_StringHolder & getName() const
void setIsoDiv(UT_Vector3I val)
int64 getTetraType() const
exint bread(int32 *buffer, exint asize=1)
GT_API const UT_StringHolder time
constexpr SYS_FORCE_INLINE T & y() noexcept
static void loadData(UT_IStream &is, UT_Vector3D &v)
void setMin(UT_Vector3D val)
GLsizei const GLfloat * value
void setNestParmValue(TempIndex idx, TempIndex instance, const PRM_DataItemHandle &value) override
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector2D &value) override
bool getForceBounds() const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector3D &value) const override
void loadFromOpSubclass(const LoadParms &loadparms) override
const OP_Context & context() const
void setNumNeighbour(int64 val)
constexpr SYS_FORCE_INLINE T & z() noexcept
fpreal64 getOffset() const
SYS_FORCE_INLINE const char * buffer() const
int64 opFileMode(const SOP_NodeVerb::CookParms &cookparms) const
void buildFromOp(const OP_GraphProxy *graph, exint nodeidx, fpreal time, DEP_MicroNode *depnode)
static void loadData(UT_IStream &is, PRM_DataItemHandle &v)
fpreal64 opDivSize(const SOP_NodeVerb::CookParms &cookparms) const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix2D &value) const override
bool load(UT_IStream &is)
int64 opMode(const SOP_NodeVerb::CookParms &cookparms) const
An output stream object that owns its own string buffer storage.
UT_Vector3I opIsoDiv(const SOP_NodeVerb::CookParms &cookparms) const
bool getPadBounds() const
**But if you need a result
static void saveData(std::ostream &os, UT_Matrix2D v)
int64 getUniformSamples() const
static PRM_DataItemHandle parseBinary(const char *type, UT_IStream &is)
static void saveData(std::ostream &os, UT_Vector2D v)
int64 opNumNeighbour(const SOP_NodeVerb::CookParms &cookparms) const
const UT_WorkBuffer & str()
Returns a read-only reference to the underlying UT_WorkBuffer.
UT_Vector3D getMax() const
void doGetParmValue(TempIndex idx, TempIndex instance, T &value) const
constexpr SYS_FORCE_INLINE T & x() noexcept
bool getBuildPolySoup() const
UT_Vector3I getDivs() const
UT_StringHolder opFileName(const SOP_NodeVerb::CookParms &cookparms) const
bool opOverrideBounds(const SOP_NodeVerb::CookParms &cookparms) const
bool operator==(const SOP_IsoOffsetParms &src) const
int64 getSweepCount() const
UT_SharedPtr< const PRM_DataItem > PRM_DataItemHandle
constexpr SYS_FORCE_INLINE T & x() noexcept
static void loadData(UT_IStream &is, bool &v)
bool operator==(const BaseDimensions< T > &a, const BaseDimensions< Y > &b)
ParmType getNestParmType(TempIndex fieldnum) const override
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix2D &value) override
UT_Vector3D opMin(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Vector2D &v)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_SharedPtr< UT_Ramp > &value) const override
void setDivs(UT_Vector3I val)
fpreal64 getDivSize() const
const UT_StringHolder & getFileName() const
static void saveData(std::ostream &os, UT_Matrix3D v)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector2D &value) const override
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix3D &value) const override
void setDivSize(fpreal64 val)
SYS_FORCE_INLINE const char * buffer() const
std::shared_ptr< T > UT_SharedPtr
Wrapper around std::shared_ptr.
constexpr SYS_FORCE_INLINE T & z() noexcept
static void saveData(std::ostream &os, PRM_DataItemHandle s)
PXL_API const char * getName(const ColorSpace *space)
Return the name of the color space.
static void saveData(std::ostream &os, UT_SharedPtr< UT_Ramp > s)
int64 opOutput(const SOP_NodeVerb::CookParms &cookparms) const
__hostdev__ bool getMax() const
bool isParmColorRamp(exint idx) const override
const OP_GraphProxy * graph() const
void setName(const UT_StringHolder &val)
int64 getNumNeighbour() const
void setNestParmValue(TempIndex idx, TempIndex instance, const fpreal &value) override
UT_Vector3D getMin() const
static void saveData(std::ostream &os, UT_StringHolder s)
static void loadData(UT_IStream &is, UT_Vector4D &v)
int64 getSampleDiv() const
void setTol(fpreal64 val)
void setBuildPolySoup(bool val)
UT_Vector3D opMax(const SOP_NodeVerb::CookParms &cookparms) const
UT_Vector3I getIsoDiv() const
bool getOverrideOutput() const
void getNestParmValue(TempIndex idx, TempIndex instance, PRM_DataItemHandle &value) const override
virtual void evalOpParm(int64 &v, NodeIdx node, const char *parmname, fpreal time, DEP_MicroNode *depnode) const =0
void setFileName(const UT_StringHolder &val)
void copyFrom(const OP_NodeParms *src) override
void setUniformSamples(int64 val)
static void saveData(std::ostream &os, UT_Vector3D v)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix3D &value) override
void saveBinary(std::ostream &os) const
Save string to binary stream.
bool getOverrideBounds() const
int64 opSweepThreshold(const SOP_NodeVerb::CookParms &cookparms) const
GT_API const UT_StringHolder version
static void saveData(std::ostream &os, bool v)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector4D &value) const override
static void loadData(UT_IStream &is, int64 &v)
void setSweepCount(int64 val)
static void loadData(UT_IStream &is, UT_Vector2I &v)
void setMax(UT_Vector3D val)
const char * getNestParmName(TempIndex fieldnum) const override
static void loadData(UT_IStream &is, UT_Matrix2D &v)
void coerceValue(T &result, const S &src) const
fpreal64 opOffset(const SOP_NodeVerb::CookParms &cookparms) const
UT_StringHolder opName(const SOP_NodeVerb::CookParms &cookparms) const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix4D &value) const override
void setFixSigns(bool val)
bool opBuildPolySoup(const SOP_NodeVerb::CookParms &cookparms) const
bool opPadBounds(const SOP_NodeVerb::CookParms &cookparms) const
void setSweepThreshold(int64 val)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_StringHolder &value) override
DEP_MicroNode * depnode() const
__hostdev__ bool getMin() const
Utility class for containing a color ramp.
void setPadBounds(bool val)
static void loadData(UT_IStream &is, UT_Matrix4D &v)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix4D &value) override
constexpr SYS_FORCE_INLINE T & w() noexcept
virtual UT_StringHolder baseGetSignature() const
int64 getSweepThreshold() const
int64 opTetraType(const SOP_NodeVerb::CookParms &cookparms) const
void setNestParmValue(TempIndex idx, TempIndex instance, const exint &value) override
bool opFixSigns(const SOP_NodeVerb::CookParms &cookparms) const
void setOverrideBounds(bool val)
int64 getFileMode() const
fpreal getCookTime() const
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector3D &value) override
void setFileMode(int64 val)
const char * findChar(int c) const
void save(std::ostream &os) const
UT_Vector3I opDivs(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_StringHolder &v)
static void saveData(std::ostream &os, UT_Matrix4D v)
void setSampleDiv(int64 val)
constexpr SYS_FORCE_INLINE T & y() noexcept
bool opLaserScan(const SOP_NodeVerb::CookParms &cookparms) const
int64 opSampleDiv(const SOP_NodeVerb::CookParms &cookparms) const
void getNestParmValue(TempIndex idx, TempIndex instance, exint &value) const override
static void loadData(UT_IStream &is, UT_Vector4I &v)
virtual bool isDirect() const =0
Direct proxies mirror actual nodes:
static void loadData(UT_IStream &is, UT_Matrix3D &v)
void doSetParmValue(TempIndex idx, TempIndex instance, const T &value)
fpreal64 opTol(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, int64 v)
constexpr SYS_FORCE_INLINE T & y() noexcept
void getNestParmValue(TempIndex idx, TempIndex instance, fpreal &value) const override
SYS_FORCE_INLINE bool isstring() const
static void loadData(UT_IStream &is, UT_SharedPtr< UT_Ramp > &v)
static void saveData(std::ostream &os, fpreal64 v)
OP_NodeParms & operator=(const OP_NodeParms &)=default
SYS_FORCE_INLINE void strncpy(const char *src, exint maxlen)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector4D &value) override
int64 opSweepCount(const SOP_NodeVerb::CookParms &cookparms) const
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_SharedPtr< UT_Ramp > &value) override
constexpr SYS_FORCE_INLINE T & x() noexcept