BsScriptAnimationUtility.generated.cpp 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  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. tmpeulerCurve = scripteulerCurve->getInternal();
  42. tmp__output = AnimationUtility::eulerToQuaternionCurve(tmpeulerCurve);
  43. MonoObject* __output;
  44. __output = ScriptTAnimationCurveQuaternion::create(tmp__output);
  45. return __output;
  46. }
  47. MonoObject* ScriptAnimationUtility::Internal_quaternionToEulerCurve(MonoObject* quatCurve)
  48. {
  49. SPtr<TAnimationCurve<Vector3>> tmp__output;
  50. SPtr<TAnimationCurve<Quaternion>> tmpquatCurve;
  51. ScriptTAnimationCurveQuaternion* scriptquatCurve;
  52. scriptquatCurve = ScriptTAnimationCurveQuaternion::toNative(quatCurve);
  53. tmpquatCurve = scriptquatCurve->getInternal();
  54. tmp__output = AnimationUtility::quaternionToEulerCurve(tmpquatCurve);
  55. MonoObject* __output;
  56. __output = ScriptTAnimationCurveVector3::create(tmp__output);
  57. return __output;
  58. }
  59. MonoArray* ScriptAnimationUtility::Internal_splitCurve3D(MonoObject* compoundCurve)
  60. {
  61. Vector<SPtr<TAnimationCurve<float>>> vec__output;
  62. SPtr<TAnimationCurve<Vector3>> tmpcompoundCurve;
  63. ScriptTAnimationCurveVector3* scriptcompoundCurve;
  64. scriptcompoundCurve = ScriptTAnimationCurveVector3::toNative(compoundCurve);
  65. tmpcompoundCurve = scriptcompoundCurve->getInternal();
  66. vec__output = AnimationUtility::splitCurve3D(tmpcompoundCurve);
  67. MonoArray* __output;
  68. int arraySize__output = (int)vec__output.size();
  69. ScriptArray array__output = ScriptArray::create<ScriptTAnimationCurvefloat>(arraySize__output);
  70. for(int i = 0; i < arraySize__output; i++)
  71. {
  72. array__output.set(i, ScriptTAnimationCurvefloat::create(vec__output[i]));
  73. }
  74. __output = array__output.getInternal();
  75. return __output;
  76. }
  77. MonoObject* ScriptAnimationUtility::Internal_combineCurve3D(MonoArray* curveComponents)
  78. {
  79. SPtr<TAnimationCurve<Vector3>> tmp__output;
  80. Vector<SPtr<TAnimationCurve<float>>> veccurveComponents;
  81. if(curveComponents != nullptr)
  82. {
  83. ScriptArray arraycurveComponents(curveComponents);
  84. veccurveComponents.resize(arraycurveComponents.size());
  85. for(int i = 0; i < (int)arraycurveComponents.size(); i++)
  86. {
  87. ScriptTAnimationCurvefloat* scriptcurveComponents;
  88. scriptcurveComponents = ScriptTAnimationCurvefloat::toNative(arraycurveComponents.get<MonoObject*>(i));
  89. if(scriptcurveComponents != nullptr)
  90. veccurveComponents[i] = scriptcurveComponents->getInternal();
  91. }
  92. }
  93. tmp__output = AnimationUtility::combineCurve3D(veccurveComponents);
  94. MonoObject* __output;
  95. __output = ScriptTAnimationCurveVector3::create(tmp__output);
  96. return __output;
  97. }
  98. MonoArray* ScriptAnimationUtility::Internal_splitCurve2D(MonoObject* compoundCurve)
  99. {
  100. Vector<SPtr<TAnimationCurve<float>>> vec__output;
  101. SPtr<TAnimationCurve<Vector2>> tmpcompoundCurve;
  102. ScriptTAnimationCurveVector2* scriptcompoundCurve;
  103. scriptcompoundCurve = ScriptTAnimationCurveVector2::toNative(compoundCurve);
  104. tmpcompoundCurve = scriptcompoundCurve->getInternal();
  105. vec__output = AnimationUtility::splitCurve2D(tmpcompoundCurve);
  106. MonoArray* __output;
  107. int arraySize__output = (int)vec__output.size();
  108. ScriptArray array__output = ScriptArray::create<ScriptTAnimationCurvefloat>(arraySize__output);
  109. for(int i = 0; i < arraySize__output; i++)
  110. {
  111. array__output.set(i, ScriptTAnimationCurvefloat::create(vec__output[i]));
  112. }
  113. __output = array__output.getInternal();
  114. return __output;
  115. }
  116. MonoObject* ScriptAnimationUtility::Internal_combineCurve2D(MonoArray* curveComponents)
  117. {
  118. SPtr<TAnimationCurve<Vector2>> tmp__output;
  119. Vector<SPtr<TAnimationCurve<float>>> veccurveComponents;
  120. if(curveComponents != nullptr)
  121. {
  122. ScriptArray arraycurveComponents(curveComponents);
  123. veccurveComponents.resize(arraycurveComponents.size());
  124. for(int i = 0; i < (int)arraycurveComponents.size(); i++)
  125. {
  126. ScriptTAnimationCurvefloat* scriptcurveComponents;
  127. scriptcurveComponents = ScriptTAnimationCurvefloat::toNative(arraycurveComponents.get<MonoObject*>(i));
  128. if(scriptcurveComponents != nullptr)
  129. veccurveComponents[i] = scriptcurveComponents->getInternal();
  130. }
  131. }
  132. tmp__output = AnimationUtility::combineCurve2D(veccurveComponents);
  133. MonoObject* __output;
  134. __output = ScriptTAnimationCurveVector2::create(tmp__output);
  135. return __output;
  136. }
  137. void ScriptAnimationUtility::Internal_calculateRange(MonoArray* curves, float* xMin, float* xMax, float* yMin, float* yMax)
  138. {
  139. Vector<SPtr<TAnimationCurve<float>>> veccurves;
  140. if(curves != nullptr)
  141. {
  142. ScriptArray arraycurves(curves);
  143. veccurves.resize(arraycurves.size());
  144. for(int i = 0; i < (int)arraycurves.size(); i++)
  145. {
  146. ScriptTAnimationCurvefloat* scriptcurves;
  147. scriptcurves = ScriptTAnimationCurvefloat::toNative(arraycurves.get<MonoObject*>(i));
  148. if(scriptcurves != nullptr)
  149. veccurves[i] = scriptcurves->getInternal();
  150. }
  151. }
  152. AnimationUtility::calculateRange(veccurves, *xMin, *xMax, *yMin, *yMax);
  153. }
  154. }