| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 |
- #include "BsScriptAnimationUtility.generated.h"
- #include "BsMonoMethod.h"
- #include "BsMonoClass.h"
- #include "BsMonoUtil.h"
- #include "../../../bsf/Source/Foundation/bsfCore/Animation/BsAnimationUtility.h"
- #include "BsScriptTAnimationCurve.generated.h"
- #include "BsScriptTAnimationCurve.generated.h"
- #include "BsScriptTAnimationCurve.generated.h"
- #include "BsScriptTAnimationCurve.generated.h"
- namespace bs
- {
- ScriptAnimationUtility::ScriptAnimationUtility(MonoObject* managedInstance, const SPtr<AnimationUtility>& value)
- :ScriptObject(managedInstance), mInternal(value)
- {
- }
- void ScriptAnimationUtility::initRuntimeData()
- {
- metaData.scriptClass->addInternalCall("Internal_eulerToQuaternionCurve", (void*)&ScriptAnimationUtility::Internal_eulerToQuaternionCurve);
- metaData.scriptClass->addInternalCall("Internal_quaternionToEulerCurve", (void*)&ScriptAnimationUtility::Internal_quaternionToEulerCurve);
- metaData.scriptClass->addInternalCall("Internal_splitCurve3D", (void*)&ScriptAnimationUtility::Internal_splitCurve3D);
- metaData.scriptClass->addInternalCall("Internal_combineCurve3D", (void*)&ScriptAnimationUtility::Internal_combineCurve3D);
- metaData.scriptClass->addInternalCall("Internal_splitCurve2D", (void*)&ScriptAnimationUtility::Internal_splitCurve2D);
- metaData.scriptClass->addInternalCall("Internal_combineCurve2D", (void*)&ScriptAnimationUtility::Internal_combineCurve2D);
- metaData.scriptClass->addInternalCall("Internal_calculateRange", (void*)&ScriptAnimationUtility::Internal_calculateRange);
- }
- MonoObject* ScriptAnimationUtility::create(const SPtr<AnimationUtility>& value)
- {
- if(value == nullptr) return nullptr;
- bool dummy = false;
- void* ctorParams[1] = { &dummy };
- MonoObject* managedInstance = metaData.scriptClass->createInstance("bool", ctorParams);
- new (bs_alloc<ScriptAnimationUtility>()) ScriptAnimationUtility(managedInstance, value);
- return managedInstance;
- }
- MonoObject* ScriptAnimationUtility::Internal_eulerToQuaternionCurve(MonoObject* eulerCurve)
- {
- SPtr<TAnimationCurve<Quaternion>> tmp__output;
- SPtr<TAnimationCurve<Vector3>> tmpeulerCurve;
- ScriptTAnimationCurveVector3* scripteulerCurve;
- scripteulerCurve = ScriptTAnimationCurveVector3::toNative(eulerCurve);
- tmpeulerCurve = scripteulerCurve->getInternal();
- tmp__output = AnimationUtility::eulerToQuaternionCurve(tmpeulerCurve);
- MonoObject* __output;
- __output = ScriptTAnimationCurveQuaternion::create(tmp__output);
- return __output;
- }
- MonoObject* ScriptAnimationUtility::Internal_quaternionToEulerCurve(MonoObject* quatCurve)
- {
- SPtr<TAnimationCurve<Vector3>> tmp__output;
- SPtr<TAnimationCurve<Quaternion>> tmpquatCurve;
- ScriptTAnimationCurveQuaternion* scriptquatCurve;
- scriptquatCurve = ScriptTAnimationCurveQuaternion::toNative(quatCurve);
- tmpquatCurve = scriptquatCurve->getInternal();
- tmp__output = AnimationUtility::quaternionToEulerCurve(tmpquatCurve);
- MonoObject* __output;
- __output = ScriptTAnimationCurveVector3::create(tmp__output);
- return __output;
- }
- MonoArray* ScriptAnimationUtility::Internal_splitCurve3D(MonoObject* compoundCurve)
- {
- Vector<SPtr<TAnimationCurve<float>>> vec__output;
- SPtr<TAnimationCurve<Vector3>> tmpcompoundCurve;
- ScriptTAnimationCurveVector3* scriptcompoundCurve;
- scriptcompoundCurve = ScriptTAnimationCurveVector3::toNative(compoundCurve);
- tmpcompoundCurve = scriptcompoundCurve->getInternal();
- vec__output = AnimationUtility::splitCurve3D(tmpcompoundCurve);
- MonoArray* __output;
- int arraySize__output = (int)vec__output.size();
- ScriptArray array__output = ScriptArray::create<ScriptTAnimationCurvefloat>(arraySize__output);
- for(int i = 0; i < arraySize__output; i++)
- {
- array__output.set(i, ScriptTAnimationCurvefloat::create(vec__output[i]));
- }
- __output = array__output.getInternal();
- return __output;
- }
- MonoObject* ScriptAnimationUtility::Internal_combineCurve3D(MonoArray* curveComponents)
- {
- SPtr<TAnimationCurve<Vector3>> tmp__output;
- Vector<SPtr<TAnimationCurve<float>>> veccurveComponents;
- if(curveComponents != nullptr)
- {
- ScriptArray arraycurveComponents(curveComponents);
- veccurveComponents.resize(arraycurveComponents.size());
- for(int i = 0; i < (int)arraycurveComponents.size(); i++)
- {
- ScriptTAnimationCurvefloat* scriptcurveComponents;
- scriptcurveComponents = ScriptTAnimationCurvefloat::toNative(arraycurveComponents.get<MonoObject*>(i));
- if(scriptcurveComponents != nullptr)
- veccurveComponents[i] = scriptcurveComponents->getInternal();
- }
- }
- tmp__output = AnimationUtility::combineCurve3D(veccurveComponents);
- MonoObject* __output;
- __output = ScriptTAnimationCurveVector3::create(tmp__output);
- return __output;
- }
- MonoArray* ScriptAnimationUtility::Internal_splitCurve2D(MonoObject* compoundCurve)
- {
- Vector<SPtr<TAnimationCurve<float>>> vec__output;
- SPtr<TAnimationCurve<Vector2>> tmpcompoundCurve;
- ScriptTAnimationCurveVector2* scriptcompoundCurve;
- scriptcompoundCurve = ScriptTAnimationCurveVector2::toNative(compoundCurve);
- tmpcompoundCurve = scriptcompoundCurve->getInternal();
- vec__output = AnimationUtility::splitCurve2D(tmpcompoundCurve);
- MonoArray* __output;
- int arraySize__output = (int)vec__output.size();
- ScriptArray array__output = ScriptArray::create<ScriptTAnimationCurvefloat>(arraySize__output);
- for(int i = 0; i < arraySize__output; i++)
- {
- array__output.set(i, ScriptTAnimationCurvefloat::create(vec__output[i]));
- }
- __output = array__output.getInternal();
- return __output;
- }
- MonoObject* ScriptAnimationUtility::Internal_combineCurve2D(MonoArray* curveComponents)
- {
- SPtr<TAnimationCurve<Vector2>> tmp__output;
- Vector<SPtr<TAnimationCurve<float>>> veccurveComponents;
- if(curveComponents != nullptr)
- {
- ScriptArray arraycurveComponents(curveComponents);
- veccurveComponents.resize(arraycurveComponents.size());
- for(int i = 0; i < (int)arraycurveComponents.size(); i++)
- {
- ScriptTAnimationCurvefloat* scriptcurveComponents;
- scriptcurveComponents = ScriptTAnimationCurvefloat::toNative(arraycurveComponents.get<MonoObject*>(i));
- if(scriptcurveComponents != nullptr)
- veccurveComponents[i] = scriptcurveComponents->getInternal();
- }
- }
- tmp__output = AnimationUtility::combineCurve2D(veccurveComponents);
- MonoObject* __output;
- __output = ScriptTAnimationCurveVector2::create(tmp__output);
- return __output;
- }
- void ScriptAnimationUtility::Internal_calculateRange(MonoArray* curves, float* xMin, float* xMax, float* yMin, float* yMax)
- {
- Vector<SPtr<TAnimationCurve<float>>> veccurves;
- if(curves != nullptr)
- {
- ScriptArray arraycurves(curves);
- veccurves.resize(arraycurves.size());
- for(int i = 0; i < (int)arraycurves.size(); i++)
- {
- ScriptTAnimationCurvefloat* scriptcurves;
- scriptcurves = ScriptTAnimationCurvefloat::toNative(arraycurves.get<MonoObject*>(i));
- if(scriptcurves != nullptr)
- veccurves[i] = scriptcurves->getInternal();
- }
- }
- AnimationUtility::calculateRange(veccurves, *xMin, *xMax, *yMin, *yMax);
- }
- }
|