quaternion.h

来自「3D游戏展示程序」· C头文件 代码 · 共 59 行

H
59
字号
//--------------------------------------------------
//  Desc: quaternion
//  Date: 2007.4.2 /update
//  Author: artsylee
//
//  Copyright (C) 2007 artsylee
//
//--------------------------------------------------

#ifndef _QUATERNION_
#define _QUATERNION_

#include "Vector3D.h"

class Vector4D
{
public:
	float	x;
	float	y;
	float	z;
	float	w;

	Vector4D();	
	Vector4D(float fx, float fy, float fz, float fw);							
	Vector4D(const Vector4D &v);
	Vector4D(const Vector3D &v, const float fw);

	Vector4D	operator-(const Vector4D &v) const;
	Vector4D	operator+(const Vector4D &v) const;
	Vector4D	operator*(float scale) const;
	float		operator*(const Vector4D &v) const;

	Vector4D&   operator=(const Vector4D &v);
	Vector4D&	operator+=(const Vector4D &v);
	Vector4D&	operator-=(const Vector4D &v);
	Vector4D&	operator*=(float scale);

	float		LengthSquared() const;
	float		Length() const;
	Vector4D&	Normalize();
	operator	float*()	{	return (float*)this;	}
};

__forceinline Vector4D operator*(float d, const Vector4D& v)	{ v*d;	}
//__forceinline Vector4D operator*(const Vector4D& v, float d)	{ v*d;	}

class Quaternion : public Vector4D
{
public:
	Quaternion():Vector4D()	{}	
	Quaternion(float fx, float fy, float fz, float fw):Vector4D(fx, fy, fz, fw)	{}						
	Quaternion(const Vector4D &v):Vector4D(v)	{}
	Quaternion(const Vector3D &v, const float fw):Vector4D(v, fw)	{}
};

Quaternion Slerp(const float r, const Quaternion &v1, const Quaternion &v2);
Quaternion Lerp(const float r, const Quaternion &v1, const Quaternion &v2);

#endif // _QUATERNION_

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?