HDK
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
HOM_ParmTuple.h
Go to the documentation of this file.
1 /*
2  * PROPRIETARY INFORMATION. This software is proprietary to
3  * Side Effects Software Inc., and is not to be reproduced,
4  * transmitted, or disclosed in any way without written permission.
5  *
6  * COMMENTS:
7  */
8 
9 #ifndef __HOM_ParmTuple_h__
10 #define __HOM_ParmTuple_h__
11 
12 #include "HOM_API.h"
13 #include "HOM_Defines.h"
14 #include "HOM_Errors.h"
15 #include "HOM_BaseKeyframe.h"
16 #include "HOM_PtrOrNull.h"
17 #include <string>
18 #include <vector>
19 #include <stdexcept>
20 class HOM_ParmTemplate;
21 class HOM_Parm;
22 class HOM_Ramp;
23 
24 SWIGOUT(%rename(ParmTuple) HOM_ParmTuple;)
25 
27 {
28 public:
30  { HOM_CONSTRUCT_OBJECT(this) }
31  HOM_ParmTuple(const HOM_ParmTuple &parm_tuple)
32  { HOM_CONSTRUCT_OBJECT(this) }
33  virtual ~HOM_ParmTuple()
34  { HOM_DESTRUCT_OBJECT(this) }
35 
36  virtual bool operator==(HOM_PtrOrNull<HOM_ParmTuple> parm_tuple) = 0;
37  virtual bool operator!=(HOM_PtrOrNull<HOM_ParmTuple> parm_tuple) = 0;
38 
39  virtual int __hash__() = 0;
40  virtual std::string __repr__() = 0;
41 
42  SWIGOUT(%newobject node;)
43  virtual HOM_Node *node() = 0;
44 
45  SWIGOUT(%newobject parmTemplate;)
46  virtual HOM_ParmTemplate *parmTemplate() = 0;
47 
48  virtual std::string name() = 0;
49  virtual std::string description() = 0;
50 
51  // Wrapping a version of set() that takes a vector of doubles will
52  // let you pass a vector of doubles or a vector of ints to it. So,
53  // we don't bother to provide a version that takes a vector of ints.
54  virtual void _set(const std::vector<double> &float_values) = 0;
55  virtual void setPending(const std::vector<double> &float_values) = 0;
56  virtual void _set(const std::vector<std::string> &string_values) = 0;
57  virtual void setPending(const std::vector<std::string> &string_values) = 0;
58  virtual void _set(const std::vector<HOM_Ramp *> &ramp_values) = 0;
59  virtual void setPending(const std::vector<HOM_Ramp *> &ramp_values) = 0;
60 
61  virtual void revertToDefaults() = 0;
62  virtual void revertToAndRestorePermanentDefaults() = 0;
63 
64  SWIGOUT(%kwargs isAtDefault;)
65  virtual bool isAtDefault(bool compare_temporary_defaults=true,
66  bool compare_expressions=true) = 0;
67  virtual bool isAtRampDefault() = 0;
68 
69  virtual std::vector<double> evalAsFloats() = 0;
70 
71  virtual std::vector<double> evalAsFloatsAtFrame(double frame) = 0;
72 
73  virtual std::vector<int> evalAsInts() = 0;
74 
75  virtual std::vector<int> evalAsIntsAtFrame(double frame) = 0;
76 
77  virtual std::vector<std::string> evalAsStrings() = 0;
78 
79  virtual std::vector<std::string> evalAsStringsAtFrame(double frame) = 0;
80 
81  virtual std::vector<HOM_ElemPtr<HOM_Ramp> > evalAsRamps() = 0;
82 
83  SWIGOUT(%newobject evalAsRampAtFrame;)
84  virtual std::vector<HOM_ElemPtr<HOM_Ramp> > evalAsRampsAtFrame(double frame) = 0;
85 
86  SWIGOUT(%newobject evalAsGeometries;)
87  virtual std::vector<HOM_ElemPtr<HOM_Geometry> > evalAsGeometries() = 0;
88 
89  SWIGOUT(%newobject evalAsGeometryAtFrame;)
90  virtual std::vector<HOM_ElemPtr<HOM_Geometry> > evalAsGeometriesAtFrame(double frame) = 0;
91 
92  virtual std::vector<std::map<std::string, std::string> >
93  evalAsJSONMaps() = 0;
94  virtual std::vector<std::map<std::string, std::string> >
95  evalAsJSONMapsAtFrame(double frame) = 0;
96 
97 
98  virtual void lock(bool on) = 0;
99  virtual void lock(const std::vector<bool> &bool_values) = 0;
100  virtual void setAutoscope(const std::vector<bool> &bool_values) = 0;
101 
102  virtual bool isSpare() = 0;
103 
104  virtual bool isTimeDependent() = 0;
105 
106  virtual bool isMultiParmInstance() = 0;
107  virtual bool isMultiParmParent() = 0;
108  SWIGOUT(%newobject parentMultiParm;)
109  virtual HOM_Parm *parentMultiParm() = 0;
110  virtual std::vector<int> multiParmInstanceIndices() = 0;
111 
112  virtual int multiParmInstancesPerItem() = 0;
113  virtual int multiParmInstancesCount() = 0;
114  virtual int multiParmStartOffset() = 0;
115 
116  virtual std::vector<HOM_ElemPtr<HOM_ParmTuple> > multiParmInstances() = 0;
117 
118  virtual std::vector<std::string> containingFolders() = 0;
119  virtual std::vector<int> containingFolderIndices() = 0;
120  virtual std::vector<HOM_ElemPtr<HOM_ParmTuple> >
121  containingFolderSetParmTuples() = 0;
122 
123  virtual void setKeyframe(const std::vector<HOM_BaseKeyframe *> &keyframes) = 0;
124  virtual void deleteKeyframeAtFrame(double frame) = 0;
125  virtual void deleteAllKeyframes() = 0;
126 
127  SWIGOUT(%newobject __getitem__;)
128  virtual HOM_Parm *__getitem__(int index) = 0;
129  virtual int __len__() = 0;
130  virtual bool __bool__() = 0;
131 
132  SWIGOUT(%newobject createClip;)
133  virtual HOM_Node *createClip(HOM_Node &parent_node,
134  const char *name,
135  bool create_new,
136  bool apply_immediately,
137  bool current_value_only=false,
138  bool create_locked=false,
139  bool set_value_to_default=false) = 0;
140 
141  virtual void appendClip(HOM_Node &chop_node,
142  bool apply_immediately,
143  bool current_value_only=false,
144  bool create_locked=false,
145  bool set_value_to_default=false) = 0;
146 
147  virtual HOM_BinaryString _clipData(double start,
148  double end,
149  bool binary = true,
150  bool use_blosc_compression = true,
151  double sample_rate = 0) = 0;
152 
153  SWIGOUT(%kwargs _setClipData;)
154  virtual void _setClipData(HOM_BinaryString data,
155  bool binary = true,
156  bool blosc_compressed = true,
157  double sample_rate = 0,
158  double start = HOM_MIN_NEGATIVE_DOUBLE) = 0;
159 
160  virtual void _saveClip(std::string file_name,
161  double start,
162  double end,
163  double sample_rate = 0) = 0;
164 
165  SWIGOUT(%kwargs _loadClip;)
166  virtual void _loadClip(std::string file_name,
167  double sample_rate = 0,
168  double start = HOM_MIN_NEGATIVE_DOUBLE) = 0;
169 
170  virtual void copyToParmClipboard() = 0;
171 
172  virtual void *_asVoidPointer() = 0;
173 
174  SWIGOUT(%kwargs asCode;)
175  virtual std::string asCode(bool brief=false, bool save_values=true,
176  bool save_keyframes=true,
177  bool save_keys_in_frames=false,
178  bool save_flag_values=true,
179  bool save_aliases=true,
180  const char *function_name=NULL) = 0;
181 
182  // You can get the parm data type with parmTemplate().dataType().
183  // However, we need a way to get the parm data type's enum value
184  // from C++ code without creating a temporary ParmTemplate object,
185  // so that's why parmDataTypeEnumId() exists.
186  SWIGOUT(%ignore parmDataTypeEnumId;)
187  virtual int parmDataTypeEnumId() = 0;
188 
189  // For data parameters only.
190  // You can get the data parm type with parmTemplate().dataParmType().
191  // However, we need a way to get the data parm type's enum value
192  // from C++ code without creating a temporary ParmTemplate object,
193  // so that's why dataParmTypeEnumId() exists.
194  SWIGOUT(%ignore dataParmTypeEnumId;)
195  virtual int dataParmTypeEnumId() = 0;
196 
197  virtual std::string help() = 0;
198  virtual std::string helpUrl() = 0;
199 
200  virtual bool isDisabled() = 0;
201 
202  virtual void disable(bool on) = 0;
203 
204  virtual bool isHidden() = 0;
205 
206  virtual void hide(bool on) = 0;
207 
208  virtual bool isConstrained() = 0;
209 
210  virtual bool isShowingExpression() = 0;
211  virtual void showExpression(bool value) = 0;
212 
213 #ifdef SWIG
214 %extend
215 {
216  %warnfilter(321) eval;
217  InterpreterObject eval()
218  {
219  return HOMevalParmTuple(*self);
220  }
221 
222  InterpreterObject evalAtFrame(double frame)
223  {
224  return HOMevalParmTupleAtFrame(*self, frame);
225  }
226 
227  InterpreterObject evalAtTime(double time)
228  {
229  return HOMevalParmTupleAtFrame(*self, HOM().timeToFrame(time));
230  }
231 }
232 #endif
233 };
234 
235 #endif
#define HOM_DESTRUCT_OBJECT(pointer)
Definition: HOM_Module.h:1291
GT_API const UT_StringHolder time
GLuint start
Definition: glcorearb.h:475
GLsizei const GLchar *const * string
Definition: glcorearb.h:814
const GLuint GLenum const void * binary
Definition: glcorearb.h:1924
#define SWIGOUT(x)
Definition: HOM_Defines.h:24
string __repr__(VtArray< T > const &self)
Definition: wrapArray.h:352
std::string help(const App *app, const Error &e)
Printout the full help string on error (if this fn is set, the old default for CLI11) ...
Definition: CLI11.h:8978
#define HOM_API
Definition: HOM_API.h:13
void ignore(T const &) VULKAN_HPP_NOEXCEPT
Definition: vulkan.hpp:6508
GLuint GLuint end
Definition: glcorearb.h:475
#define HOM_CONSTRUCT_OBJECT(pointer)
Definition: HOM_Module.h:1290
bool operator!=(const Mat3< T0 > &m0, const Mat3< T1 > &m1)
Inequality operator, does exact floating point comparisons.
Definition: Mat3.h:556
#define HOM_MIN_NEGATIVE_DOUBLE
Definition: HOM_Defines.h:50
HUSD_API bool eval(VtValue &val, T &ret_val)
GLuint const GLchar * name
Definition: glcorearb.h:786
void * _asVoidPointer()
Definition: HOM_Ramp.h:62
OIIO_UTIL_API bool rename(string_view from, string_view to, std::string &err)
GLuint index
Definition: glcorearb.h:786
virtual ~HOM_ParmTuple()
Definition: HOM_ParmTuple.h:33
Definition: core.h:1131
HOM_API HOM_Module & HOM()
bool operator==(const Mat3< T0 > &m0, const Mat3< T1 > &m1)
Equality operator, does exact floating point comparisons.
Definition: Mat3.h:542
Definition: format.h:895
HOM_ParmTuple(const HOM_ParmTuple &parm_tuple)
Definition: HOM_ParmTuple.h:31