BsScriptAnimationUtility.generated.cpp 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  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. namespace bs
  10. {
  11. ScriptAnimationUtility::ScriptAnimationUtility(MonoObject* managedInstance, const SPtr<AnimationUtility>& value)
  12. :ScriptObject(managedInstance), mInternal(value)
  13. {
  14. }
  15. void ScriptAnimationUtility::initRuntimeData()
  16. {
  17. metaData.scriptClass->addInternalCall("Internal_eulerToQuaternionCurve", (void*)&ScriptAnimationUtility::Internal_eulerToQuaternionCurve);
  18. metaData.scriptClass->addInternalCall("Internal_quaternionToEulerCurve", (void*)&ScriptAnimationUtility::Internal_quaternionToEulerCurve);
  19. metaData.scriptClass->addInternalCall("Internal_splitCurve", (void*)&ScriptAnimationUtility::Internal_splitCurve);
  20. metaData.scriptClass->addInternalCall("Internal_combineCurve", (void*)&ScriptAnimationUtility::Internal_combineCurve);
  21. metaData.scriptClass->addInternalCall("Internal_calculateRange", (void*)&ScriptAnimationUtility::Internal_calculateRange);
  22. }
  23. MonoObject* ScriptAnimationUtility::create(const SPtr<AnimationUtility>& value)
  24. {
  25. if(value == nullptr) return nullptr;
  26. bool dummy = false;
  27. void* ctorParams[1] = { &dummy };
  28. MonoObject* managedInstance = metaData.scriptClass->createInstance("bool", ctorParams);
  29. new (bs_alloc<ScriptAnimationUtility>()) ScriptAnimationUtility(managedInstance, value);
  30. return managedInstance;
  31. }
  32. MonoObject* ScriptAnimationUtility::Internal_eulerToQuaternionCurve(MonoObject* eulerCurve)
  33. {
  34. SPtr<TAnimationCurve<Quaternion>> tmp__output;
  35. SPtr<TAnimationCurve<Vector3>> tmpeulerCurve;
  36. ScriptTAnimationCurveVector3* scripteulerCurve;
  37. scripteulerCurve = ScriptTAnimationCurveVector3::toNative(eulerCurve);
  38. tmpeulerCurve = scripteulerCurve->getInternal();
  39. tmp__output = AnimationUtility::eulerToQuaternionCurve(tmpeulerCurve);
  40. MonoObject* __output;
  41. __output = ScriptTAnimationCurveQuaternion::create(tmp__output);
  42. return __output;
  43. }
  44. MonoObject* ScriptAnimationUtility::Internal_quaternionToEulerCurve(MonoObject* quatCurve)
  45. {
  46. SPtr<TAnimationCurve<Vector3>> tmp__output;
  47. SPtr<TAnimationCurve<Quaternion>> tmpquatCurve;
  48. ScriptTAnimationCurveQuaternion* scriptquatCurve;
  49. scriptquatCurve = ScriptTAnimationCurveQuaternion::toNative(quatCurve);
  50. tmpquatCurve = scriptquatCurve->getInternal();
  51. tmp__output = AnimationUtility::quaternionToEulerCurve(tmpquatCurve);
  52. MonoObject* __output;
  53. __output = ScriptTAnimationCurveVector3::create(tmp__output);
  54. return __output;
  55. }
  56. MonoArray* ScriptAnimationUtility::Internal_splitCurve(MonoObject* compoundCurve)
  57. {
  58. Vector<SPtr<TAnimationCurve<float>>> vec__output;
  59. SPtr<TAnimationCurve<Vector3>> tmpcompoundCurve;
  60. ScriptTAnimationCurveVector3* scriptcompoundCurve;
  61. scriptcompoundCurve = ScriptTAnimationCurveVector3::toNative(compoundCurve);
  62. tmpcompoundCurve = scriptcompoundCurve->getInternal();
  63. vec__output = AnimationUtility::splitCurve(tmpcompoundCurve);
  64. MonoArray* __output;
  65. int arraySize__output = (int)vec__output.size();
  66. ScriptArray array__output = ScriptArray::create<ScriptTAnimationCurvefloat>(arraySize__output);
  67. for(int i = 0; i < arraySize__output; i++)
  68. {
  69. array__output.set(i, ScriptTAnimationCurvefloat::create(vec__output[i]));
  70. }
  71. __output = array__output.getInternal();
  72. return __output;
  73. }
  74. MonoObject* ScriptAnimationUtility::Internal_combineCurve(MonoArray* curveComponents)
  75. {
  76. SPtr<TAnimationCurve<Vector3>> tmp__output;
  77. Vector<SPtr<TAnimationCurve<float>>> veccurveComponents;
  78. if(curveComponents != nullptr)
  79. {
  80. ScriptArray arraycurveComponents(curveComponents);
  81. veccurveComponents.resize(arraycurveComponents.size());
  82. for(int i = 0; i < (int)arraycurveComponents.size(); i++)
  83. {
  84. ScriptTAnimationCurvefloat* scriptcurveComponents;
  85. scriptcurveComponents = ScriptTAnimationCurvefloat::toNative(arraycurveComponents.get<MonoObject*>(i));
  86. if(scriptcurveComponents != nullptr)
  87. veccurveComponents[i] = scriptcurveComponents->getInternal();
  88. }
  89. }
  90. tmp__output = AnimationUtility::combineCurve(veccurveComponents);
  91. MonoObject* __output;
  92. __output = ScriptTAnimationCurveVector3::create(tmp__output);
  93. return __output;
  94. }
  95. void ScriptAnimationUtility::Internal_calculateRange(MonoArray* curves, float* xMin, float* xMax, float* yMin, float* yMax)
  96. {
  97. Vector<SPtr<TAnimationCurve<float>>> veccurves;
  98. if(curves != nullptr)
  99. {
  100. ScriptArray arraycurves(curves);
  101. veccurves.resize(arraycurves.size());
  102. for(int i = 0; i < (int)arraycurves.size(); i++)
  103. {
  104. ScriptTAnimationCurvefloat* scriptcurves;
  105. scriptcurves = ScriptTAnimationCurvefloat::toNative(arraycurves.get<MonoObject*>(i));
  106. if(scriptcurves != nullptr)
  107. veccurves[i] = scriptcurves->getInternal();
  108. }
  109. }
  110. AnimationUtility::calculateRange(veccurves, *xMin, *xMax, *yMin, *yMax);
  111. }
  112. }