20 using namespace UT::Literal;
34 myRecompute_normals =
false;
35 mySmoothing_level = 0;
37 myInput_pts_only =
false;
41 myLimit_below =
false;
42 myMin_edge_length = 1e-05;
43 myLimit_above =
false;
44 myMax_edge_length = 10000;
46 myVisualize_lfs =
false;
57 if (myGroup != src.myGroup)
return false;
58 if (myHard_edges != src.myHard_edges)
return false;
59 if (myIterations != src.myIterations)
return false;
60 if (myRecompute_normals != src.myRecompute_normals)
return false;
61 if (mySmoothing_level != src.mySmoothing_level)
return false;
62 if (myTarget_edge != src.myTarget_edge)
return false;
63 if (myInput_pts_only != src.myInput_pts_only)
return false;
64 if (myElement_sizing != src.myElement_sizing)
return false;
65 if (myGradation != src.myGradation)
return false;
66 if (myDensity != src.myDensity)
return false;
67 if (myLimit_below != src.myLimit_below)
return false;
68 if (myMin_edge_length != src.myMin_edge_length)
return false;
69 if (myLimit_above != src.myLimit_above)
return false;
70 if (myMax_edge_length != src.myMax_edge_length)
return false;
71 if (myLfs_only != src.myLfs_only)
return false;
72 if (myVisualize_lfs != src.myVisualize_lfs)
return false;
73 if (myLfs_ramp != src.myLfs_ramp)
return false;
88 graph->
evalOpParm(myGroup, nodeidx,
"group", time, 0);
91 graph->
evalOpParm(myHard_edges, nodeidx,
"hard_edges", time, 0);
94 graph->
evalOpParm(myIterations, nodeidx,
"iterations", time, 0);
95 myRecompute_normals =
false;
97 graph->
evalOpParm(myRecompute_normals, nodeidx,
"recompute_normals", time, 0);
98 mySmoothing_level = 0;
100 graph->
evalOpParm(mySmoothing_level, nodeidx,
"smoothing_level", time, 0);
103 graph->
evalOpParm(myTarget_edge, nodeidx,
"target_edge", time, 0);
104 myInput_pts_only =
false;
106 graph->
evalOpParm(myInput_pts_only, nodeidx,
"input_pts_only", time, 0);
107 myElement_sizing = 0;
109 graph->
evalOpParm(myElement_sizing, nodeidx,
"element_sizing", time, 0);
112 graph->
evalOpParm(myGradation, nodeidx,
"gradation", time, 0);
115 graph->
evalOpParm(myDensity, nodeidx,
"density", time, 0);
116 myLimit_below =
false;
118 graph->
evalOpParm(myLimit_below, nodeidx,
"limit_below", time, 0);
119 myMin_edge_length = 1e-05;
120 if (
true && ( (!(((getLimit_below()==0)))) ) )
121 graph->
evalOpParm(myMin_edge_length, nodeidx,
"min_edge_length", time, 0);
122 myLimit_above =
false;
124 graph->
evalOpParm(myLimit_above, nodeidx,
"limit_above", time, 0);
125 myMax_edge_length = 10000;
126 if (
true && ( (!(((getLimit_above()==0)))) ) )
127 graph->
evalOpParm(myMax_edge_length, nodeidx,
"max_edge_length", time, 0);
130 graph->
evalOpParm(myLfs_only, nodeidx,
"lfs_only", time, 0);
131 myVisualize_lfs =
false;
133 graph->
evalOpParm(myVisualize_lfs, nodeidx,
"visualize_lfs", time, 0);
135 if (
true && ( (!(((getVisualize_lfs()==0)))) ) )
136 graph->
evalOpParm(myLfs_ramp, nodeidx,
"lfs_ramp", time, 0);
152 template <
typename T>
159 if (idx.
size() != instance.
size()+1)
164 coerceValue(value, myGroup);
167 coerceValue(value, myHard_edges);
170 coerceValue(value, myIterations);
173 coerceValue(value, myRecompute_normals);
176 coerceValue(value, mySmoothing_level);
179 coerceValue(value, myTarget_edge);
182 coerceValue(value, myInput_pts_only);
185 coerceValue(value, myElement_sizing);
188 coerceValue(value, myGradation);
191 coerceValue(value, myDensity);
194 coerceValue(value, myLimit_below);
197 coerceValue(value, myMin_edge_length);
200 coerceValue(value, myLimit_above);
203 coerceValue(value, myMax_edge_length);
206 coerceValue(value, myLfs_only);
209 coerceValue(value, myVisualize_lfs);
212 coerceValue(value, myLfs_ramp);
219 { doGetParmValue(idx, instance, value); }
221 { doGetParmValue(idx, instance, value); }
223 { doGetParmValue(idx, instance, value); }
225 { doGetParmValue(idx, instance, value); }
227 { doGetParmValue(idx, instance, value); }
229 { doGetParmValue(idx, instance, value); }
231 { doGetParmValue(idx, instance, value); }
233 { doGetParmValue(idx, instance, value); }
235 { doGetParmValue(idx, instance, value); }
237 { doGetParmValue(idx, instance, value); }
239 { doGetParmValue(idx, instance, value); }
241 template <
typename T>
248 if (idx.
size() != instance.
size()+1)
253 coerceValue(myGroup, value);
256 coerceValue(myHard_edges, value);
259 coerceValue(myIterations, value);
262 coerceValue(myRecompute_normals, value);
265 coerceValue(mySmoothing_level, value);
268 coerceValue(myTarget_edge, value);
271 coerceValue(myInput_pts_only, value);
274 coerceValue(myElement_sizing, value);
277 coerceValue(myGradation, value);
280 coerceValue(myDensity, value);
283 coerceValue(myLimit_below, value);
286 coerceValue(myMin_edge_length, value);
289 coerceValue(myLimit_above, value);
292 coerceValue(myMax_edge_length, value);
295 coerceValue(myLfs_only, value);
298 coerceValue(myVisualize_lfs, value);
301 coerceValue(myLfs_ramp, value);
308 { doSetParmValue(idx, instance, value); }
310 { doSetParmValue(idx, instance, value); }
312 { doSetParmValue(idx, instance, value); }
314 { doSetParmValue(idx, instance, value); }
316 { doSetParmValue(idx, instance, value); }
318 { doSetParmValue(idx, instance, value); }
320 { doSetParmValue(idx, instance, value); }
322 { doSetParmValue(idx, instance, value); }
324 { doSetParmValue(idx, instance, value); }
326 { doSetParmValue(idx, instance, value); }
328 { doSetParmValue(idx, instance, value); }
344 if (fieldnum.
size() < 1)
355 return "recompute_normals";
357 return "smoothing_level";
359 return "target_edge";
361 return "input_pts_only";
363 return "element_sizing";
369 return "limit_below";
371 return "min_edge_length";
373 return "limit_above";
375 return "max_edge_length";
379 return "visualize_lfs";
389 if (fieldnum.
size() < 1)
390 return PARM_UNSUPPORTED;
429 return PARM_UNSUPPORTED;
465 loadData(is, rampdata);
483 int typelen = colon - data.
buffer();
497 {
int64 iv =
v; UTwrite(os, &iv); }
499 { UTwrite<fpreal64>(os, &
v); }
501 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y()); }
503 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y());
504 UTwrite<fpreal64>(os, &v.
z()); }
506 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y());
507 UTwrite<fpreal64>(os, &v.
z()); UTwrite<fpreal64>(os, &v.
w()); }
519 if (s) s->save(ostr);
521 saveData(os, result);
528 ostr << s->getDataTypeToken();
533 saveData(os, result);
537 void save(std::ostream &os)
const
541 saveData(os, myGroup);
542 saveData(os, myHard_edges);
543 saveData(os, myIterations);
544 saveData(os, myRecompute_normals);
545 saveData(os, mySmoothing_level);
546 saveData(os, myTarget_edge);
547 saveData(os, myInput_pts_only);
548 saveData(os, myElement_sizing);
549 saveData(os, myGradation);
550 saveData(os, myDensity);
551 saveData(os, myLimit_below);
552 saveData(os, myMin_edge_length);
553 saveData(os, myLimit_above);
554 saveData(os, myMax_edge_length);
555 saveData(os, myLfs_only);
556 saveData(os, myVisualize_lfs);
557 saveData(os, myLfs_ramp);
570 loadData(is, myGroup);
571 loadData(is, myHard_edges);
572 loadData(is, myIterations);
573 loadData(is, myRecompute_normals);
574 loadData(is, mySmoothing_level);
575 loadData(is, myTarget_edge);
576 loadData(is, myInput_pts_only);
577 loadData(is, myElement_sizing);
578 loadData(is, myGradation);
579 loadData(is, myDensity);
580 loadData(is, myLimit_below);
581 loadData(is, myMin_edge_length);
582 loadData(is, myLimit_above);
583 loadData(is, myMax_edge_length);
584 loadData(is, myLfs_only);
585 loadData(is, myVisualize_lfs);
586 loadData(is, myLfs_ramp);
596 if (!thissop)
return getGroup();
598 OP_Utils::evalOpParm(result, thissop,
"group", cookparms.
getCookTime(), 0);
606 if (!thissop)
return getHard_edges();
608 OP_Utils::evalOpParm(result, thissop,
"hard_edges", cookparms.
getCookTime(), 0);
616 if (!thissop)
return getIterations();
618 OP_Utils::evalOpParm(result, thissop,
"iterations", cookparms.
getCookTime(), 0);
626 if (!thissop)
return getRecompute_normals();
628 OP_Utils::evalOpParm(result, thissop,
"recompute_normals", cookparms.
getCookTime(), 0);
636 if (!thissop)
return getSmoothing_level();
638 OP_Utils::evalOpParm(result, thissop,
"smoothing_level", cookparms.
getCookTime(), 0);
646 if (!thissop)
return getTarget_edge();
648 OP_Utils::evalOpParm(result, thissop,
"target_edge", cookparms.
getCookTime(), 0);
656 if (!thissop)
return getInput_pts_only();
658 OP_Utils::evalOpParm(result, thissop,
"input_pts_only", cookparms.
getCookTime(), 0);
666 if (!thissop)
return getElement_sizing();
668 OP_Utils::evalOpParm(result, thissop,
"element_sizing", cookparms.
getCookTime(), 0);
676 if (!thissop)
return getGradation();
678 OP_Utils::evalOpParm(result, thissop,
"gradation", cookparms.
getCookTime(), 0);
686 if (!thissop)
return getDensity();
688 OP_Utils::evalOpParm(result, thissop,
"density", cookparms.
getCookTime(), 0);
696 if (!thissop)
return getLimit_below();
698 OP_Utils::evalOpParm(result, thissop,
"limit_below", cookparms.
getCookTime(), 0);
706 if (!thissop)
return getMin_edge_length();
708 OP_Utils::evalOpParm(result, thissop,
"min_edge_length", cookparms.
getCookTime(), 0);
716 if (!thissop)
return getLimit_above();
718 OP_Utils::evalOpParm(result, thissop,
"limit_above", cookparms.
getCookTime(), 0);
726 if (!thissop)
return getMax_edge_length();
728 OP_Utils::evalOpParm(result, thissop,
"max_edge_length", cookparms.
getCookTime(), 0);
736 if (!thissop)
return getLfs_only();
738 OP_Utils::evalOpParm(result, thissop,
"lfs_only", cookparms.
getCookTime(), 0);
746 if (!thissop)
return getVisualize_lfs();
748 OP_Utils::evalOpParm(result, thissop,
"visualize_lfs", cookparms.
getCookTime(), 0);
756 if (!thissop)
return getLfs_ramp();
758 OP_Utils::evalOpParm(result, thissop,
"lfs_ramp", cookparms.
getCookTime(), 0);
766 bool myRecompute_normals;
769 bool myInput_pts_only;
770 int64 myElement_sizing;
778 bool myVisualize_lfs;
void setRecompute_normals(bool val)
static void loadData(UT_IStream &is, UT_StringHolder &v)
ParmType getNestParmType(TempIndex fieldnum) const override
static void saveData(std::ostream &os, UT_SharedPtr< UT_Ramp > s)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector3D &value) const override
void getNestParmValue(TempIndex idx, TempIndex instance, PRM_DataItemHandle &value) const override
bool getRecompute_normals() const
fpreal64 opSmoothing_level(const SOP_NodeVerb::CookParms &cookparms) const
SOP_Node * getNode() const
void setNestParmValue(TempIndex idx, TempIndex instance, const exint &value) override
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix3D &value) const override
void doSetParmValue(TempIndex idx, TempIndex instance, const T &value)
void setLimit_above(bool val)
int64 getIterations() const
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix4D &value) override
bool opVisualize_lfs(const SOP_NodeVerb::CookParms &cookparms) const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector4D &value) const override
exint bread(int32 *buffer, exint asize=1)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector2D &value) override
GT_API const UT_StringHolder time
static void loadData(UT_IStream &is, UT_Vector3I &v)
GLuint const GLfloat * val
void setElement_sizing(int64 val)
fpreal64 getGradation() const
void getNestParmValue(TempIndex idx, TempIndex instance, exint &value) const override
void setLimit_below(bool val)
static void saveData(std::ostream &os, UT_Vector4D v)
static void loadData(UT_IStream &is, UT_Vector4I &v)
SYS_FORCE_INLINE const char * buffer() const
const SOP_GraphProxy * graph() const
bool operator==(const SOP_RemeshParms &src) const
An output stream object that owns its own string buffer storage.
void setVisualize_lfs(bool val)
int64 getElement_sizing() const
static PRM_DataItemHandle parseBinary(const char *type, UT_IStream &is)
void save(std::ostream &os) const
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
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix2D &value) const override
static void saveData(std::ostream &os, bool v)
void getNestParmValue(TempIndex idx, TempIndex instance, fpreal &value) const override
bool opLimit_above(const SOP_NodeVerb::CookParms &cookparms) const
UT_StringHolder opHard_edges(const SOP_NodeVerb::CookParms &cookparms) const
void setMax_edge_length(fpreal64 val)
bool operator==(const BaseDimensions< T > &a, const BaseDimensions< Y > &b)
void setHard_edges(const UT_StringHolder &val)
bool load(UT_IStream &is)
static void loadData(UT_IStream &is, int64 &v)
void setSmoothing_level(fpreal64 val)
static void loadData(UT_IStream &is, UT_SharedPtr< UT_Ramp > &v)
void doGetParmValue(TempIndex idx, TempIndex instance, T &value) const
fpreal64 getTarget_edge() const
void setGradation(fpreal64 val)
void setNestParmValue(TempIndex idx, TempIndex instance, const PRM_DataItemHandle &value) override
SYS_FORCE_INLINE const char * buffer() const
std::shared_ptr< T > UT_SharedPtr
Wrapper around std::shared_ptr.
bool getLimit_above() const
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_StringHolder &value) override
GLint GLenum GLsizei GLint GLsizei const void * data
void setIterations(int64 val)
fpreal64 getDensity() const
fpreal64 getMin_edge_length() const
void setGroup(const UT_StringHolder &val)
UT_SharedPtr< UT_Ramp > getLfs_ramp() const
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector4D &value) override
void setLfs_only(bool val)
const char * getNestParmName(TempIndex fieldnum) const override
static void saveData(std::ostream &os, UT_StringHolder s)
const UT_StringHolder & getGroup() const
static void saveData(std::ostream &os, fpreal64 v)
int64 opElement_sizing(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Matrix3D &v)
void setLfs_ramp(UT_SharedPtr< UT_Ramp > val)
static void loadData(UT_IStream &is, fpreal64 &v)
static void saveData(std::ostream &os, int64 v)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector2D &value) const override
static void loadData(UT_IStream &is, UT_Vector3D &v)
fpreal64 opMin_edge_length(const SOP_NodeVerb::CookParms &cookparms) const
void setNestParmValue(TempIndex idx, TempIndex instance, const fpreal &value) override
fpreal64 getMax_edge_length() const
void saveBinary(std::ostream &os) const
Save string to binary stream.
fpreal64 opGradation(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Matrix2D &v)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix2D &value) override
GT_API const UT_StringHolder version
DEP_MicroNode * depnode() const
static void saveData(std::ostream &os, PRM_DataItemHandle s)
bool opLimit_below(const SOP_NodeVerb::CookParms &cookparms) const
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector3D &value) override
UT_StringHolder opGroup(const SOP_NodeVerb::CookParms &cookparms) const
void copyFrom(const SOP_NodeParms *src) override
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix3D &value) override
bool opLfs_only(const SOP_NodeVerb::CookParms &cookparms) const
void setTarget_edge(fpreal64 val)
fpreal64 opDensity(const SOP_NodeVerb::CookParms &cookparms) const
bool getInput_pts_only() const
static void saveData(std::ostream &os, UT_Vector2D v)
void setDensity(fpreal64 val)
fpreal64 opMax_edge_length(const SOP_NodeVerb::CookParms &cookparms) const
void setMin_edge_length(fpreal64 val)
int64 opIterations(const SOP_NodeVerb::CookParms &cookparms) const
Utility class for containing a color ramp.
static void saveData(std::ostream &os, UT_Matrix2D v)
fpreal64 opTarget_edge(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, PRM_DataItemHandle &v)
void setInput_pts_only(bool val)
GLdouble GLdouble GLdouble r
static void saveData(std::ostream &os, UT_Matrix4D v)
void buildFromOp(const SOP_GraphProxy *graph, exint nodeidx, fpreal time, DEP_MicroNode *depnode)
virtual void evalOpParm(int64 &v, NodeIdx node, const char *parmname, fpreal time, DEP_MicroNode *depnode) const =0
bool getVisualize_lfs() const
fpreal getCookTime() const
bool operator!=(const SOP_RemeshParms &src) const
static void saveData(std::ostream &os, UT_Vector3D v)
UT_SharedPtr< UT_Ramp > opLfs_ramp(const SOP_NodeVerb::CookParms &cookparms) const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_SharedPtr< UT_Ramp > &value) const override
static void loadData(UT_IStream &is, bool &v)
const char * findChar(int c) const
const UT_StringHolder & getHard_edges() const
static void loadData(UT_IStream &is, UT_Vector2I &v)
static void saveData(std::ostream &os, UT_Matrix3D v)
~SOP_RemeshParms() override
void getNestParmValue(TempIndex idx, TempIndex instance, UT_StringHolder &value) const override
bool getLimit_below() const
static void loadData(UT_IStream &is, UT_Matrix4D &v)
GLsizei const GLfloat * value
static void loadData(UT_IStream &is, UT_Vector4D &v)
void loadFromOpSubclass(const LoadParms &loadparms) override
exint getNestNumParms(TempIndex idx) const override
const OP_Context & context() const
UT_SharedPtr< const PRM_DataItem > PRM_DataItemHandle
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix4D &value) const override
SYS_FORCE_INLINE bool isstring() const
bool opInput_pts_only(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Vector2D &v)
SYS_FORCE_INLINE void strncpy(const char *src, exint maxlen)
bool opRecompute_normals(const SOP_NodeVerb::CookParms &cookparms) const
fpreal64 getSmoothing_level() const