BsScriptAnimationUtility.generated.cpp 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. #include "BsScriptAnimationUtility.generated.h"
  2. #include "BsMonoMethod.h"
  3. #include "BsMonoClass.h"
  4. #include "BsMonoUtil.h"
  5. #include "../../../bsf/Source/Foundation/bsfCore/Animation/BsAnimationUtility.h"
  6. #include "BsScriptTAnimationCurve.generated.h"
  7. #include "BsScriptTAnimationCurve.generated.h"
  8. #include "BsScriptTAnimationCurve.generated.h"
  9. #include "BsScriptTAnimationCurve.generated.h"
  10. namespace bs
  11. {
  12. ScriptAnimationUtility::ScriptAnimationUtility(MonoObject* managedInstance, const SPtr<AnimationUtility>& value)
  13. :ScriptObject(managedInstance), mInternal(value)
  14. {
  15. }
  16. void ScriptAnimationUtility::initRuntimeData()
  17. {
  18. metaData.scriptClass->addInternalCall("Internal_eulerToQuaternionCurve", (void*)&ScriptAnimationUtility::Internal_eulerToQuaternionCurve);
  19. metaData.scriptClass->addInternalCall("Internal_quaternionToEulerCurve", (void*)&ScriptAnimationUtility::Internal_quaternionToEulerCurve);
  20. metaData.scriptClass->addInternalCall("Internal_splitCurve3D", (void*)&ScriptAnimationUtility::Internal_splitCurve3D);
  21. metaData.scriptClass->addInternalCall("Internal_combineCurve3D", (void*)&ScriptAnimationUtility::Internal_combineCurve3D);
  22. metaData.scriptClass->addInternalCall("Internal_splitCurve2D", (void*)&ScriptAnimationUtility::Internal_splitCurve2D);
  23. metaData.scriptClass->addInternalCall("Internal_combineCurve2D", (void*)&ScriptAnimationUtility::Internal_combineCurve2D);
  24. metaData.scriptClass->addInternalCall("Internal_calculateRange", (void*)&ScriptAnimationUtility::Internal_calculateRange);
  25. }
  26. MonoObject* ScriptAnimationUtility::create(const SPtr<AnimationUtility>& value)
  27. {
  28. if(value == nullptr) return nullptr;
  29. bool dummy = false;
  30. void* ctorParams[1] = { &dummy };
  31. MonoObject* managedInstance = metaData.scriptClass->createInstance("bool", ctorParams);
  32. new (bs_alloc<ScriptAnimationUtility>()) ScriptAnimationUtility(managedInstance, value);
  33. return managedInstance;
  34. }
  35. MonoObject* ScriptAnimationUtility::Internal_eulerToQuaternionCurve(MonoObject* eulerCurve)
  36. {
  37. SPtr<TAnimationCurve<Quaternion>> tmp__output;
  38. SPtr<TAnimationCurve<Vector3>> tmpeulerCurve;
  39. ScriptTAnimationCurveVector3* scripteulerCurve;
  40. scripteulerCurve = ScriptTAnimationCurveVector3::toNative(eulerCurve);
  41. if(scripteulerCurve != nullptr)
  42. tmpeulerCurve = scripteulerCurve->getInternal();
  43. tmp__output = AnimationUtility::eulerToQuaternionCurve(tmpeulerCurve);
  44. MonoObject* __output;
  45. __output = ScriptTAnimationCurveQuaternion::create(tmp__output);
  46. return __output;
  47. }
  48. MonoObject* ScriptAnimationUtility::Internal_quaternionToEulerCurve(MonoObject* quatCurve)
  49. {
  50. SPtr<TAnimationCurve<Vector3>> tmp__output;
  51. SPtr<TAnimationCurve<Quaternion>> tmpquatCurve;
  52. ScriptTAnimationCurveQuaternion* scriptquatCurve;
  53. scriptquatCurve = ScriptTAnimationCurveQuaternion::toNative(quatCurve);
  54. if(scriptquatCurve != nullptr)
  55. tmpquatCurve = scriptquatCurve->getInternal();
  56. tmp__output = AnimationUtility::quaternionToEulerCurve(tmpquatCurve);
  57. MonoObject* __output;
  58. __output = ScriptTAnimationCurveVector3::create(tmp__output);
  59. return __output;
  60. }
  61. MonoArray* ScriptAnimationUtility::Internal_splitCurve3D(MonoObject* compoundCurve)
  62. {
  63. Vector<SPtr<TAnimationCurve<float>>> vec__output;
  64. SPtr<TAnimationCurve<Vector3>> tmpcompoundCurve;
  65. ScriptTAnimationCurveVector3* scriptcompoundCurve;
  66. scriptcompoundCurve = ScriptTAnimationCurveVector3::toNative(compoundCurve);
  67. if(scriptcompoundCurve != nullptr)
  68. tmpcompoundCurve = scriptcompoundCurve->getInternal();
  69. vec__output = AnimationUtility::splitCurve3D(tmpcompoundCurve);
  70. MonoArray* __output;
  71. int arraySize__output = (int)vec__output.size();
  72. ScriptArray array__output = ScriptArray::create<ScriptTAnimationCurvefloat>(arraySize__output);
  73. for(int i = 0; i < arraySize__output; i++)
  74. {
  75. array__output.set(i, ScriptTAnimationCurvefloat::create(vec__output[i]));
  76. }
  77. __output = array__output.getInternal();
  78. return __output;
  79. }
  80. MonoObject* ScriptAnimationUtility::Internal_combineCurve3D(MonoArray* curveComponents)
  81. {
  82. SPtr<TAnimationCurve<Vector3>> tmp__output;
  83. Vector<SPtr<TAnimationCurve<float>>> veccurveComponents;
  84. if(curveComponents != nullptr)
  85. {
  86. ScriptArray arraycurveComponents(curveComponents);
  87. veccurveComponents.resize(arraycurveComponents.size());
  88. for(int i = 0; i < (int)arraycurveComponents.size(); i++)
  89. {
  90. ScriptTAnimationCurvefloat* scriptcurveComponents;
  91. scriptcurveComponents = ScriptTAnimationCurvefloat::toNative(arraycurveComponents.get<MonoObject*>(i));
  92. if(scriptcurveComponents != nullptr)
  93. veccurveComponents[i] = scriptcurveComponents->getInternal();
  94. }
  95. }
  96. tmp__output = AnimationUtility::combineCurve3D(veccurveComponents);
  97. MonoObject* __output;
  98. __output = ScriptTAnimationCurveVector3::create(tmp__output);
  99. return __output;
  100. }
  101. MonoArray* ScriptAnimationUtility::Internal_splitCurve2D(MonoObject* compoundCurve)
  102. {
  103. Vector<SPtr<TAnimationCurve<float>>> vec__output;
  104. SPtr<TAnimationCurve<Vector2>> tmpcompoundCurve;
  105. ScriptTAnimationCurveVector2* scriptcompoundCurve;
  106. scriptcompoundCurve = ScriptTAnimationCurveVector2::toNative(compoundCurve);
  107. if(scriptcompoundCurve != nullptr)
  108. tmpcompoundCurve = scriptcompoundCurve->getInternal();
  109. vec__output = AnimationUtility::splitCurve2D(tmpcompoundCurve);
  110. MonoArray* __output;
  111. int arraySize__output = (int)vec__output.size();
  112. ScriptArray array__output = ScriptArray::create<ScriptTAnimationCurvefloat>(arraySize__output);
  113. for(int i = 0; i < arraySize__output; i++)
  114. {
  115. array__output.set(i, ScriptTAnimationCurvefloat::create(vec__output[i]));
  116. }
  117. __output = array__output.getInternal();
  118. return __output;
  119. }
  120. MonoObject* ScriptAnimationUtility::Internal_combineCurve2D(MonoArray* curveComponents)
  121. {
  122. SPtr<TAnimationCurve<Vector2>> tmp__output;
  123. Vector<SPtr<TAnimationCurve<float>>> veccurveComponents;
  124. if(curveComponents != nullptr)
  125. {
  126. ScriptArray arraycurveComponents(curveComponents);
  127. veccurveComponents.resize(arraycurveComponents.size());
  128. for(int i = 0; i < (int)arraycurveComponents.size(); i++)
  129. {
  130. ScriptTAnimationCurvefloat* scriptcurveComponents;
  131. scriptcurveComponents = ScriptTAnimationCurvefloat::toNative(arraycurveComponents.get<MonoObject*>(i));
  132. if(scriptcurveComponents != nullptr)
  133. veccurveComponents[i] = scriptcurveComponents->getInternal();
  134. }
  135. }
  136. tmp__output = AnimationUtility::combineCurve2D(veccurveComponents);
  137. MonoObject* __output;
  138. __output = ScriptTAnimationCurveVector2::create(tmp__output);
  139. return __output;
  140. }
  141. void ScriptAnimationUtility::Internal_calculateRange(MonoArray* curves, float* xMin, float* xMax, float* yMin, float* yMax)
  142. {
  143. Vector<SPtr<TAnimationCurve<float>>> veccurves;
  144. if(curves != nullptr)
  145. {
  146. ScriptArray arraycurves(curves);
  147. veccurves.resize(arraycurves.size());
  148. for(int i = 0; i < (int)arraycurves.size(); i++)
  149. {
  150. ScriptTAnimationCurvefloat* scriptcurves;
  151. scriptcurves = ScriptTAnimationCurvefloat::toNative(arraycurves.get<MonoObject*>(i));
  152. if(scriptcurves != nullptr)
  153. veccurves[i] = scriptcurves->getInternal();
  154. }
  155. }
  156. AnimationUtility::calculateRange(veccurves, *xMin, *xMax, *yMin, *yMax);
  157. }
  158. }