📄 _matrix44.h
字号:
{
float mi0 = m[i][0];
float mi1 = m[i][1];
float mi2 = m[i][2];
m[i][0] = mi0*m1.m[0][0] + mi1*m1.m[1][0] + mi2*m1.m[2][0];
m[i][1] = mi0*m1.m[0][1] + mi1*m1.m[1][1] + mi2*m1.m[2][1];
m[i][2] = mi0*m1.m[0][2] + mi1*m1.m[1][2] + mi2*m1.m[2][2];
}
m[3][0] += m1.m[3][0];
m[3][1] += m1.m[3][1];
m[3][2] += m1.m[3][2];
m[0][3] = 0.0f;
m[1][3] = 0.0f;
m[2][3] = 0.0f;
m[3][3] = 1.0f;
}
//------------------------------------------------------------------------------
/**
Transforms a vector by the matrix, projecting the result back into w=1.
*/
inline
_vector3
_matrix44::transform_coord(const _vector3& v) const
{
float d = 1.0f / (M14*v.x + M24*v.y + M34*v.z + M44);
return _vector3(
(M11*v.x + M21*v.y + M31*v.z + M41) * d,
(M12*v.x + M22*v.y + M32*v.z + M42) * d,
(M13*v.x + M23*v.y + M33*v.z + M43) * d);
}
//------------------------------------------------------------------------------
/**
*/
inline
_vector3
_matrix44::x_component() const
{
_vector3 v(M11,M12,M13);
return v;
}
//------------------------------------------------------------------------------
/**
*/
inline
_vector3
_matrix44::y_component() const
{
_vector3 v(M21,M22,M23);
return v;
}
//------------------------------------------------------------------------------
/**
*/
inline
_vector3
_matrix44::z_component() const
{
_vector3 v(M31,M32,M33);
return v;
}
//------------------------------------------------------------------------------
/**
*/
inline
_vector3
_matrix44::pos_component() const
{
_vector3 v(M41,M42,M43);
return v;
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::rotate_x(const float a)
{
float c = n_cos(a);
float s = n_sin(a);
int i;
for (i=0; i<4; i++) {
float mi1 = m[i][1];
float mi2 = m[i][2];
m[i][1] = mi1*c + mi2*-s;
m[i][2] = mi1*s + mi2*c;
}
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::rotate_y(const float a)
{
float c = n_cos(a);
float s = n_sin(a);
int i;
for (i=0; i<4; i++) {
float mi0 = m[i][0];
float mi2 = m[i][2];
m[i][0] = mi0*c + mi2*s;
m[i][2] = mi0*-s + mi2*c;
}
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::rotate_z(const float a)
{
float c = n_cos(a);
float s = n_sin(a);
int i;
for (i=0; i<4; i++) {
float mi0 = m[i][0];
float mi1 = m[i][1];
m[i][0] = mi0*c + mi1*-s;
m[i][1] = mi0*s + mi1*c;
}
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::translate(const _vector3& t)
{
M41 += t.x;
M42 += t.y;
M43 += t.z;
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::set_translation(const _vector3& t)
{
M41 = t.x;
M42 = t.y;
M43 = t.z;
};
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::scale(const _vector3& s)
{
int i;
for (i=0; i<4; i++)
{
m[i][0] *= s.x;
m[i][1] *= s.y;
m[i][2] *= s.z;
}
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::lookatRh(const _vector3& at, const _vector3& up)
{
_vector3 eye(M41, M42, M43);
_vector3 zaxis = eye - at;
zaxis.norm();
_vector3 xaxis = up * zaxis;
xaxis.norm();
_vector3 yaxis = zaxis * xaxis;
M11 = xaxis.x; M12 = xaxis.y; M13 = xaxis.z; M14 = 0.0f;
M21 = yaxis.x; M22 = yaxis.y; M23 = yaxis.z; M24 = 0.0f;
M31 = zaxis.x; M32 = zaxis.y; M33 = zaxis.z; M34 = 0.0f;
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::lookatLh(const _vector3& at, const _vector3& up)
{
_vector3 eye(M41, M42, M43);
_vector3 zaxis = at - eye;
zaxis.norm();
_vector3 xaxis = up * zaxis;
xaxis.norm();
_vector3 yaxis = zaxis * xaxis;
M11 = xaxis.x; M12 = yaxis.x; M13 = zaxis.x; M14 = 0.0f;
M21 = xaxis.y; M22 = yaxis.y; M23 = zaxis.y; M24 = 0.0f;
M31 = xaxis.z; M32 = yaxis.z; M33 = zaxis.z; M34 = 0.0f;
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::perspFovLh(float fovY, float aspect, float zn, float zf)
{
float h = float(1.0 / tan(fovY * 0.5f));
float w = h / aspect;
M11 = w; M12 = 0.0f; M13 = 0.0f; M14 = 0.0f;
M21 = 0.0f; M22 = h; M23 = 0.0f; M24 = 0.0f;
M31 = 0.0f; M32 = 0.0f; M33 = zf / (zf - zn); M34 = 1.0f;
M41 = 0.0f; M42 = 0.0f; M43 = -zn * (zf / (zf - zn)); M44 = 0.0f;
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::perspFovRh(float fovY, float aspect, float zn, float zf)
{
float h = float(1.0 / tan(fovY * 0.5f));
float w = h / aspect;
M11 = w; M12 = 0.0f; M13 = 0.0f; M14 = 0.0f;
M21 = 0.0f; M22 = h; M23 = 0.0f; M24 = 0.0f;
M31 = 0.0f; M32 = 0.0f; M33 = zf / (zn - zf); M34 = -1.0f;
M41 = 0.0f; M42 = 0.0f; M43 = zn * (zf / (zn - zf)); M44 = 0.0f;
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::orthoLh(float w, float h, float zn, float zf)
{
M11 = 2.0f / w; M12 = 0.0f; M13 = 0.0f; M14 = 0.0f;
M21 = 0.0f; M22 = 2.0f / h; M23 = 0.0f; M24 = 0.0f;
M31 = 0.0f; M32 = 0.0f; M33 = 1.0f / (zf - zn); M34 = 0.0f;
M41 = 0.0f; M42 = 0.0f; M43 = zn / (zn - zf); M44 = 1.0f;
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::orthoRh(float w, float h, float zn, float zf)
{
M11 = 2.0f / w; M12 = 0.0f; M13 = 0.0f; M14 = 0.0f;
M21 = 0.0f; M22 = 2.0f / h; M23 = 0.0f; M24 = 0.0f;
M31 = 0.0f; M32 = 0.0f; M33 = 1.0f / (zn - zf); M34 = 0.0f;
M41 = 0.0f; M42 = 0.0f; M43 = zn / (zn - zf); M44 = 1.0f;
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::billboard(const _vector3& to, const _vector3& up)
{
_vector3 from(M41, M42, M43);
_vector3 z(from - to);
z.norm();
_vector3 y(up);
y.norm();
_vector3 x(y * z);
z = x * y;
M11=x.x; M12=x.y; M13=x.z; M14=0.0f;
M21=y.x; M22=y.y; M23=y.z; M24=0.0f;
M31=z.x; M32=z.y; M33=z.z; M34=0.0f;
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::operator *= (const _matrix44& m1)
{
int i;
for (i=0; i<4; i++)
{
float mi0 = m[i][0];
float mi1 = m[i][1];
float mi2 = m[i][2];
float mi3 = m[i][3];
m[i][0] = mi0*m1.m[0][0] + mi1*m1.m[1][0] + mi2*m1.m[2][0] + mi3*m1.m[3][0];
m[i][1] = mi0*m1.m[0][1] + mi1*m1.m[1][1] + mi2*m1.m[2][1] + mi3*m1.m[3][1];
m[i][2] = mi0*m1.m[0][2] + mi1*m1.m[1][2] + mi2*m1.m[2][2] + mi3*m1.m[3][2];
m[i][3] = mi0*m1.m[0][3] + mi1*m1.m[1][3] + mi2*m1.m[2][3] + mi3*m1.m[3][3];
}
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::rotate(const _vector3& vec, float a)
{
_vector3 v(vec);
v.norm();
float sa = (float) n_sin(a);
float ca = (float) n_cos(a);
_matrix44 rotM;
rotM.M11 = ca + (1.0f - ca) * v.x * v.x;
rotM.M12 = (1.0f - ca) * v.x * v.y - sa * v.z;
rotM.M13 = (1.0f - ca) * v.z * v.x + sa * v.y;
rotM.M21 = (1.0f - ca) * v.x * v.y + sa * v.z;
rotM.M22 = ca + (1.0f - ca) * v.y * v.y;
rotM.M23 = (1.0f - ca) * v.y * v.z - sa * v.x;
rotM.M31 = (1.0f - ca) * v.z * v.x - sa * v.y;
rotM.M32 = (1.0f - ca) * v.y * v.z + sa * v.x;
rotM.M33 = ca + (1.0f - ca) * v.z * v.z;
(*this) *= rotM;
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::mult(const _vector4& src, _vector4& dst) const
{
dst.x = M11*src.x + M21*src.y + M31*src.z + M41*src.w;
dst.y = M12*src.x + M22*src.y + M32*src.z + M42*src.w;
dst.z = M13*src.x + M23*src.y + M33*src.z + M43*src.w;
dst.w = M14*src.x + M24*src.y + M34*src.z + M44*src.w;
}
//------------------------------------------------------------------------------
/**
*/
inline
void
_matrix44::mult(const _vector3& src, _vector3& dst) const
{
dst.x = M11*src.x + M21*src.y + M31*src.z + M41;
dst.y = M12*src.x + M22*src.y + M32*src.z + M42;
dst.z = M13*src.x + M23*src.y + M33*src.z + M43;
}
//------------------------------------------------------------------------------
/**
*/
static
inline
_matrix44 operator * (const _matrix44& m0, const _matrix44& m1)
{
_matrix44 m2(
m0.m[0][0]*m1.m[0][0] + m0.m[0][1]*m1.m[1][0] + m0.m[0][2]*m1.m[2][0] + m0.m[0][3]*m1.m[3][0],
m0.m[0][0]*m1.m[0][1] + m0.m[0][1]*m1.m[1][1] + m0.m[0][2]*m1.m[2][1] + m0.m[0][3]*m1.m[3][1],
m0.m[0][0]*m1.m[0][2] + m0.m[0][1]*m1.m[1][2] + m0.m[0][2]*m1.m[2][2] + m0.m[0][3]*m1.m[3][2],
m0.m[0][0]*m1.m[0][3] + m0.m[0][1]*m1.m[1][3] + m0.m[0][2]*m1.m[2][3] + m0.m[0][3]*m1.m[3][3],
m0.m[1][0]*m1.m[0][0] + m0.m[1][1]*m1.m[1][0] + m0.m[1][2]*m1.m[2][0] + m0.m[1][3]*m1.m[3][0],
m0.m[1][0]*m1.m[0][1] + m0.m[1][1]*m1.m[1][1] + m0.m[1][2]*m1.m[2][1] + m0.m[1][3]*m1.m[3][1],
m0.m[1][0]*m1.m[0][2] + m0.m[1][1]*m1.m[1][2] + m0.m[1][2]*m1.m[2][2] + m0.m[1][3]*m1.m[3][2],
m0.m[1][0]*m1.m[0][3] + m0.m[1][1]*m1.m[1][3] + m0.m[1][2]*m1.m[2][3] + m0.m[1][3]*m1.m[3][3],
m0.m[2][0]*m1.m[0][0] + m0.m[2][1]*m1.m[1][0] + m0.m[2][2]*m1.m[2][0] + m0.m[2][3]*m1.m[3][0],
m0.m[2][0]*m1.m[0][1] + m0.m[2][1]*m1.m[1][1] + m0.m[2][2]*m1.m[2][1] + m0.m[2][3]*m1.m[3][1],
m0.m[2][0]*m1.m[0][2] + m0.m[2][1]*m1.m[1][2] + m0.m[2][2]*m1.m[2][2] + m0.m[2][3]*m1.m[3][2],
m0.m[2][0]*m1.m[0][3] + m0.m[2][1]*m1.m[1][3] + m0.m[2][2]*m1.m[2][3] + m0.m[2][3]*m1.m[3][3],
m0.m[3][0]*m1.m[0][0] + m0.m[3][1]*m1.m[1][0] + m0.m[3][2]*m1.m[2][0] + m0.m[3][3]*m1.m[3][0],
m0.m[3][0]*m1.m[0][1] + m0.m[3][1]*m1.m[1][1] + m0.m[3][2]*m1.m[2][1] + m0.m[3][3]*m1.m[3][1],
m0.m[3][0]*m1.m[0][2] + m0.m[3][1]*m1.m[1][2] + m0.m[3][2]*m1.m[2][2] + m0.m[3][3]*m1.m[3][2],
m0.m[3][0]*m1.m[0][3] + m0.m[3][1]*m1.m[1][3] + m0.m[3][2]*m1.m[2][3] + m0.m[3][3]*m1.m[3][3]);
return m2;
}
//------------------------------------------------------------------------------
/**
*/
static
inline
_vector3 operator * (const _matrix44& m, const _vector3& v)
{
return _vector3(
m.M11*v.x + m.M21*v.y + m.M31*v.z + m.M41,
m.M12*v.x + m.M22*v.y + m.M32*v.z + m.M42,
m.M13*v.x + m.M23*v.y + m.M33*v.z + m.M43);
}
//------------------------------------------------------------------------------
/**
*/
static
inline
_vector4 operator * (const _matrix44& m, const _vector4& v)
{
return _vector4(
m.M11*v.x + m.M21*v.y + m.M31*v.z + m.M41*v.w,
m.M12*v.x + m.M22*v.y + m.M32*v.z + m.M42*v.w,
m.M13*v.x + m.M23*v.y + m.M33*v.z + m.M43*v.w,
m.M14*v.x + m.M24*v.y + m.M34*v.z + m.M44*v.w);
};
//------------------------------------------------------------------------------
#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -