2014-04-30 08:50:12 +08:00
|
|
|
/**
|
|
|
|
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
|
|
|
|
*/
|
|
|
|
|
2014-05-17 05:36:00 +08:00
|
|
|
#include "math/Vec3.h"
|
|
|
|
#include "math/Mat4.h"
|
2014-04-02 10:33:07 +08:00
|
|
|
|
2014-04-02 12:09:51 +08:00
|
|
|
NS_CC_MATH_BEGIN
|
2014-04-02 10:33:07 +08:00
|
|
|
|
Optimize Vec3
small function Vec3 move to Vec3.inl
Added:
add(float xx, float yy, float zz);
setZero();
Change all code:
_vec3 = Vec3(x, y, z); -> _vec3.set(x, y, z);
Vec3 vec3 = Vec3(x, y, z); -> Vec3 vec3(x, y, z);
_vec3 += Vec3(x, y, z); -> _vec3.add(x, y, z);
_vec3 = Vec3::ZERO; -> _vec3.setZero();
2015-04-05 18:09:50 +08:00
|
|
|
|
|
|
|
inline bool Vec3::isZero() const
|
|
|
|
{
|
|
|
|
return x == 0.0f && y == 0.0f && z == 0.0f;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline bool Vec3::isOne() const
|
|
|
|
{
|
|
|
|
return x == 1.0f && y == 1.0f && z == 1.0f;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Vec3::add(const Vec3& v)
|
|
|
|
{
|
|
|
|
x += v.x;
|
|
|
|
y += v.y;
|
|
|
|
z += v.z;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Vec3::add(float xx, float yy, float zz)
|
|
|
|
{
|
|
|
|
x += xx;
|
|
|
|
y += yy;
|
|
|
|
z += zz;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline float Vec3::length() const
|
|
|
|
{
|
|
|
|
return sqrt(x * x + y * y + z * z);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline float Vec3::lengthSquared() const
|
|
|
|
{
|
|
|
|
return (x * x + y * y + z * z);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Vec3::negate()
|
|
|
|
{
|
|
|
|
x = -x;
|
|
|
|
y = -y;
|
|
|
|
z = -z;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Vec3::scale(float scalar)
|
|
|
|
{
|
|
|
|
x *= scalar;
|
|
|
|
y *= scalar;
|
|
|
|
z *= scalar;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Vec3::set(float xx, float yy, float zz)
|
|
|
|
{
|
|
|
|
this->x = xx;
|
|
|
|
this->y = yy;
|
|
|
|
this->z = zz;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Vec3::set(const float* array)
|
|
|
|
{
|
|
|
|
GP_ASSERT(array);
|
|
|
|
|
|
|
|
x = array[0];
|
|
|
|
y = array[1];
|
|
|
|
z = array[2];
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Vec3::set(const Vec3& v)
|
|
|
|
{
|
|
|
|
this->x = v.x;
|
|
|
|
this->y = v.y;
|
|
|
|
this->z = v.z;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Vec3::set(const Vec3& p1, const Vec3& p2)
|
|
|
|
{
|
|
|
|
x = p2.x - p1.x;
|
|
|
|
y = p2.y - p1.y;
|
|
|
|
z = p2.z - p1.z;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Vec3::setZero()
|
|
|
|
{
|
|
|
|
x = y = z = 0.0f;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Vec3::subtract(const Vec3& v)
|
|
|
|
{
|
|
|
|
x -= v.x;
|
|
|
|
y -= v.y;
|
|
|
|
z -= v.z;
|
|
|
|
}
|
|
|
|
|
2014-05-15 01:07:09 +08:00
|
|
|
inline const Vec3 Vec3::operator+(const Vec3& v) const
|
2014-04-02 10:33:07 +08:00
|
|
|
{
|
2014-05-15 01:07:09 +08:00
|
|
|
Vec3 result(*this);
|
2014-04-02 10:33:07 +08:00
|
|
|
result.add(v);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2014-05-15 01:07:09 +08:00
|
|
|
inline Vec3& Vec3::operator+=(const Vec3& v)
|
2014-04-02 10:33:07 +08:00
|
|
|
{
|
|
|
|
add(v);
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2014-05-15 01:07:09 +08:00
|
|
|
inline const Vec3 Vec3::operator-(const Vec3& v) const
|
2014-04-02 10:33:07 +08:00
|
|
|
{
|
2014-05-15 01:07:09 +08:00
|
|
|
Vec3 result(*this);
|
2014-04-02 10:33:07 +08:00
|
|
|
result.subtract(v);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2014-05-15 01:07:09 +08:00
|
|
|
inline Vec3& Vec3::operator-=(const Vec3& v)
|
2014-04-02 10:33:07 +08:00
|
|
|
{
|
|
|
|
subtract(v);
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2014-05-15 01:07:09 +08:00
|
|
|
inline const Vec3 Vec3::operator-() const
|
2014-04-02 10:33:07 +08:00
|
|
|
{
|
2014-05-15 01:07:09 +08:00
|
|
|
Vec3 result(*this);
|
2014-04-02 10:33:07 +08:00
|
|
|
result.negate();
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2014-05-15 01:07:09 +08:00
|
|
|
inline const Vec3 Vec3::operator*(float s) const
|
2014-04-02 10:33:07 +08:00
|
|
|
{
|
2014-05-15 01:07:09 +08:00
|
|
|
Vec3 result(*this);
|
2014-04-16 10:42:39 +08:00
|
|
|
result.scale(s);
|
2014-04-02 10:33:07 +08:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2014-05-15 01:07:09 +08:00
|
|
|
inline Vec3& Vec3::operator*=(float s)
|
2014-04-02 10:33:07 +08:00
|
|
|
{
|
2014-04-16 10:42:39 +08:00
|
|
|
scale(s);
|
2014-04-02 10:33:07 +08:00
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2014-05-15 01:07:09 +08:00
|
|
|
inline const Vec3 Vec3::operator/(const float s) const
|
2014-04-02 10:33:07 +08:00
|
|
|
{
|
2014-05-15 01:07:09 +08:00
|
|
|
return Vec3(this->x / s, this->y / s, this->z / s);
|
2014-04-02 10:33:07 +08:00
|
|
|
}
|
|
|
|
|
2014-05-15 01:07:09 +08:00
|
|
|
inline bool Vec3::operator==(const Vec3& v) const
|
2014-04-02 10:33:07 +08:00
|
|
|
{
|
|
|
|
return x==v.x && y==v.y && z==v.z;
|
|
|
|
}
|
|
|
|
|
2014-05-15 01:07:09 +08:00
|
|
|
inline bool Vec3::operator!=(const Vec3& v) const
|
2014-04-02 10:33:07 +08:00
|
|
|
{
|
|
|
|
return x!=v.x || y!=v.y || z!=v.z;
|
|
|
|
}
|
|
|
|
|
2014-05-15 01:07:09 +08:00
|
|
|
inline const Vec3 operator*(float x, const Vec3& v)
|
2014-04-02 10:33:07 +08:00
|
|
|
{
|
2014-05-15 01:07:09 +08:00
|
|
|
Vec3 result(v);
|
2014-04-02 10:33:07 +08:00
|
|
|
result.scale(x);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2014-04-02 12:09:51 +08:00
|
|
|
NS_CC_MATH_END
|