/** Copyright 2013 BlackBerry Inc. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. Original file from GamePlay3D: http://gameplay3d.org This file was modified to fit the cocos2d-x project */ #ifndef MATHUTIL_H_ #define MATHUTIL_H_ #include "CCMathBase.h" NS_CC_MATH_BEGIN /** * Defines a math utility class. * * This is primarily used for optimized internal math operations. */ class MathUtil { friend class Matrix; friend class Vector3; public: /** * Updates the given scalar towards the given target using a smoothing function. * The given response time determines the amount of smoothing (lag). A longer * response time yields a smoother result and more lag. To force the scalar to * follow the target closely, provide a response time that is very small relative * to the given elapsed time. * * @param x the scalar to update. * @param target target value. * @param elapsedTime elapsed time between calls. * @param responseTime response time (in the same units as elapsedTime). */ static void smooth(float* x, float target, float elapsedTime, float responseTime); /** * Updates the given scalar towards the given target using a smoothing function. * The given rise and fall times determine the amount of smoothing (lag). Longer * rise and fall times yield a smoother result and more lag. To force the scalar to * follow the target closely, provide rise and fall times that are very small relative * to the given elapsed time. * * @param x the scalar to update. * @param target target value. * @param elapsedTime elapsed time between calls. * @param riseTime response time for rising slope (in the same units as elapsedTime). * @param fallTime response time for falling slope (in the same units as elapsedTime). */ static void smooth(float* x, float target, float elapsedTime, float riseTime, float fallTime); private: inline static void addMatrix(const float* m, float scalar, float* dst); inline static void addMatrix(const float* m1, const float* m2, float* dst); inline static void subtractMatrix(const float* m1, const float* m2, float* dst); inline static void multiplyMatrix(const float* m, float scalar, float* dst); inline static void multiplyMatrix(const float* m1, const float* m2, float* dst); inline static void negateMatrix(const float* m, float* dst); inline static void transposeMatrix(const float* m, float* dst); inline static void transformVector4(const float* m, float x, float y, float z, float w, float* dst); inline static void transformVector4(const float* m, const float* v, float* dst); inline static void crossVector3(const float* v1, const float* v2, float* dst); MathUtil(); }; NS_CC_MATH_END #define MATRIX_SIZE ( sizeof(float) * 16) #ifdef USE_NEON #include "MathUtilNeon.inl" #else #include "MathUtil.inl" #endif #endif