亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? vector3d.h

?? it is a visual c++ file
?? H
字號(hào):
//////////////////////////////////////////////////////////////////////////////////////////
//	VECTOR3D.h
//	Class declaration for a 3d vector
//	Downloaded from: www.paulsprojects.net
//	Created:	20th July 2002
//	Modified:	8th November 2002	-	Changed Constructor layout
//									-	Some speed Improvements
//									-	Corrected Lerp
//				7th January 2003	-	Added QuadraticInterpolate
//
//	Copyright (c) 2006, Paul Baker
//	Distributed under the New BSD Licence. (See accompanying file License.txt or copy at
//	http://www.paulsprojects.net/NewBSDLicense.txt)
//////////////////////////////////////////////////////////////////////////////////////////	

#ifndef VECTOR3D_H
#define VECTOR3D_H

class VECTOR3D
{
public:
	//constructors
	VECTOR3D(void)	:	x(0.0f), y(0.0f), z(0.0f)
	{}

	VECTOR3D(float newX, float newY, float newZ)	:	x(newX), y(newY), z(newZ)
	{}

	VECTOR3D(const float * rhs)	:	x(*rhs), y(*(rhs+1)), z(*(rhs+2))
	{}

	VECTOR3D(const VECTOR3D & rhs)	:	x(rhs.x), y(rhs.y), z(rhs.z)
	{}

	~VECTOR3D() {}	//empty

	void Set(float newX, float newY, float newZ)
	{	x=newX;	y=newY;	z=newZ;	}
	
	//Accessors kept for compatibility
	void SetX(float newX) {x = newX;}
	void SetY(float newY) {y = newY;}
	void SetZ(float newZ) {z = newZ;}

	float GetX() const {return x;}	//public accessor functions
	float GetY() const {return y;}	//inline, const
	float GetZ() const {return z;}

	void LoadZero(void)
	{	x=y=z=0.0f;	}
	void LoadOne(void)
	{	x=y=z=1.0f;	}
	
	//vector algebra
	VECTOR3D CrossProduct(const VECTOR3D & rhs) const
	{	return VECTOR3D(y*rhs.z - z*rhs.y, z*rhs.x - x*rhs.z, x*rhs.y - y*rhs.x);	}

	float DotProduct(const VECTOR3D & rhs) const
	{	return x*rhs.x + y*rhs.y + z*rhs.z;	}
	
	void Normalize();
	VECTOR3D GetNormalized() const;
	
	float GetLength() const
	{	return (float)sqrt((x*x)+(y*y)+(z*z));	}
	
	float GetSquaredLength() const
	{	return (x*x)+(y*y)+(z*z);	}

	//rotations
	void RotateX(double angle);
	VECTOR3D GetRotatedX(double angle) const;
	void RotateY(double angle);
	VECTOR3D GetRotatedY(double angle) const;
	void RotateZ(double angle);
	VECTOR3D GetRotatedZ(double angle) const;
	void RotateAxis(double angle, const VECTOR3D & axis);
	VECTOR3D GetRotatedAxis(double angle, const VECTOR3D & axis) const;

	//pack to [0,1] for color
	void PackTo01();
	VECTOR3D GetPackedTo01() const;

	//linear interpolate
	VECTOR3D lerp(const VECTOR3D & v2, float factor) const
	{	return (*this)*(1.0f-factor) + v2*factor;	}

	VECTOR3D QuadraticInterpolate(const VECTOR3D & v2, const VECTOR3D & v3, float factor) const
	{	return (*this)*(1.0f-factor)*(1.0f-factor) + 2*v2*factor*(1.0f-factor) + v3*factor*factor;}


	//overloaded operators
	//binary operators
	VECTOR3D operator+(const VECTOR3D & rhs) const
	{	return VECTOR3D(x + rhs.x, y + rhs.y, z + rhs.z);	}
	
	VECTOR3D operator-(const VECTOR3D & rhs) const
	{	return VECTOR3D(x - rhs.x, y - rhs.y, z - rhs.z);	}

	VECTOR3D operator*(const float rhs) const
	{	return VECTOR3D(x*rhs, y*rhs, z*rhs);	}
	
	VECTOR3D operator/(const float rhs) const
	{	return (rhs==0.0f) ? VECTOR3D(0.0f, 0.0f, 0.0f) : VECTOR3D(x / rhs, y / rhs, z / rhs);	}

	//multiply by a float, eg 3*v
	friend VECTOR3D operator*(float scaleFactor, const VECTOR3D & rhs);

	//Add, subtract etc, saving the construction of a temporary
	void Add(const VECTOR3D & v2, VECTOR3D & result)
	{
		result.x=x+v2.x;
		result.y=y+v2.y;
		result.z=z+v2.z;
	}

	void Subtract(const VECTOR3D & v2, VECTOR3D & result)
	{
		result.x=x-v2.x;
		result.y=y-v2.y;
		result.z=z-v2.z;
	}

	bool operator==(const VECTOR3D & rhs) const;
	bool operator!=(const VECTOR3D & rhs) const
	{	return !((*this)==rhs);	}

	//self-add etc
	void operator+=(const VECTOR3D & rhs)
	{	x+=rhs.x;	y+=rhs.y;	z+=rhs.z;	}

	void operator-=(const VECTOR3D & rhs)
	{	x-=rhs.x;	y-=rhs.y;	z-=rhs.z;	}

	void operator*=(const float rhs)
	{	x*=rhs;	y*=rhs;	z*=rhs;	}
	
	void operator/=(const float rhs)
	{	if(rhs==0.0f)
			return;
		else
		{	x/=rhs; y/=rhs; z/=rhs;	}
	}


	//unary operators
	VECTOR3D operator-(void) const {return VECTOR3D(-x, -y, -z);}
	VECTOR3D operator+(void) const {return *this;}

	//cast to pointer to a (float *) for glVertex3fv etc
	operator float* () const {return (float*) this;}
	operator const float* () const {return (const float*) this;}

	//member variables
	float x;
	float y;
	float z;
};

#endif	//VECTOR3D_H

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧洲日韩在线| 亚洲三级免费观看| 色综合色狠狠综合色| 日韩vs国产vs欧美| 18涩涩午夜精品.www| 日韩欧美资源站| 色国产综合视频| 国产成人免费视频网站 | 97精品国产露脸对白| 免费观看日韩av| 亚洲综合无码一区二区| 亚洲欧洲日韩av| 91在线你懂得| 国产麻豆精品一区二区| 亚洲成人免费影院| 成人欧美一区二区三区黑人麻豆 | 欧美色偷偷大香| 久久色.com| 91麻豆精品久久久久蜜臀| 91日韩在线专区| 国产ts人妖一区二区| 蜜桃av一区二区在线观看| 亚洲国产综合人成综合网站| 中文字幕一区二区三区不卡在线 | 国产精品福利一区二区三区| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 国产日韩欧美在线一区| 日韩视频免费观看高清完整版在线观看 | av午夜一区麻豆| 国产乱对白刺激视频不卡| 美女久久久精品| 日韩av电影免费观看高清完整版在线观看 | 日韩精品一区在线观看| 91精品蜜臀在线一区尤物| 欧美日韩一区高清| 欧美日韩精品系列| 精品视频免费在线| 欧美日韩在线综合| 欧美日韩免费一区二区三区| 日本道免费精品一区二区三区| 99精品国产91久久久久久| 成人性生交大片免费看中文网站| 国产精品亚洲人在线观看| 精品一区二区三区视频在线观看| 欧美aⅴ一区二区三区视频| 免费精品视频最新在线| 麻豆专区一区二区三区四区五区| 久久精品国产网站| 国内精品久久久久影院色| 精品一区二区三区免费视频| 国产伦精品一区二区三区在线观看| 久久99精品国产.久久久久久 | 91亚洲永久精品| 色婷婷综合久久久| 欧美日韩国产一级二级| 欧美精品aⅴ在线视频| 欧美一区二区免费视频| 日韩欧美的一区| 国产丝袜欧美中文另类| 国产精品久久久久永久免费观看| 日韩码欧中文字| 午夜久久久久久久久| 人禽交欧美网站| 国产精品综合二区| 91碰在线视频| 91麻豆精品国产| 久久九九久精品国产免费直播| 国产精品另类一区| 亚洲成人精品影院| 狠狠色综合播放一区二区| 波多野结衣中文字幕一区二区三区 | 精品国产91乱码一区二区三区| 国产午夜亚洲精品理论片色戒| 日韩理论片一区二区| 五月天一区二区三区| 国产精品一级黄| 欧美亚洲国产一卡| 欧美xxxxx牲另类人与| 国产精品久久久久久久久动漫| 亚洲国产日韩a在线播放| 韩国午夜理伦三级不卡影院| av成人免费在线| 日韩欧美区一区二| 亚洲免费在线播放| 久久成人精品无人区| 色悠久久久久综合欧美99| 日韩欧美国产小视频| 亚洲欧美日韩一区二区三区在线观看| 日本中文字幕一区二区视频 | 日韩精品一区二区三区中文精品 | 一区二区三区影院| 久久99精品久久久久婷婷| 色综合天天做天天爱| 精品国产乱码久久久久久免费 | 国产精品一二三在| 欧美天堂亚洲电影院在线播放| 欧美tk丨vk视频| 亚洲一区二区三区四区中文字幕 | 日韩一卡二卡三卡国产欧美| 国产欧美日韩视频在线观看| 天天亚洲美女在线视频| 成人免费毛片a| 欧美mv日韩mv国产网站| 一级特黄大欧美久久久| 东方欧美亚洲色图在线| 精品久久一区二区三区| 亚洲福利一区二区| 91在线观看高清| 久久久久久9999| 蜜臀国产一区二区三区在线播放| 一本色道久久综合亚洲aⅴ蜜桃 | 日韩亚洲欧美成人一区| 亚洲激情五月婷婷| voyeur盗摄精品| 久久噜噜亚洲综合| 捆绑调教一区二区三区| 欧美日韩在线三区| 一区2区3区在线看| 91毛片在线观看| 国产精品欧美综合在线| 国产一区在线精品| 日韩一区二区电影在线| 视频一区欧美日韩| 欧美日韩mp4| 婷婷六月综合亚洲| 欧美日韩国产小视频在线观看| 伊人色综合久久天天| 91女厕偷拍女厕偷拍高清| 国产精品麻豆一区二区| 成人免费视频caoporn| 国产日韩欧美不卡在线| 国产精品资源站在线| 亚洲精品一区二区三区蜜桃下载| 久久超碰97中文字幕| 欧美成人猛片aaaaaaa| 精品中文字幕一区二区小辣椒| 日韩精品最新网址| 激情综合五月天| 久久久亚洲综合| 成人免费av网站| 日韩理论片在线| 91黄色小视频| 丝袜脚交一区二区| 日韩欧美亚洲国产精品字幕久久久| 日本欧美一区二区三区| 欧美刺激午夜性久久久久久久| 久草中文综合在线| 久久一区二区视频| 成人激情午夜影院| 亚洲女与黑人做爰| 欧美色综合久久| 美女精品一区二区| 久久亚洲综合色一区二区三区| 国产丶欧美丶日本不卡视频| 国产精品久久夜| 欧美日韩综合不卡| 免费成人小视频| 国产日韩影视精品| 91蝌蚪国产九色| 亚洲gay无套男同| 欧美变态口味重另类| 成人综合在线视频| 亚洲最新在线观看| 日韩一区二区三区在线| 国产精品18久久久| 亚洲三级电影全部在线观看高清| 欧美色倩网站大全免费| 另类人妖一区二区av| 久久精品一区四区| 在线观看免费一区| 狠狠色丁香婷婷综合| 中文字幕一区二区三区蜜月| 欧美美女网站色| 国产精品一区二区不卡| 亚洲自拍都市欧美小说| 精品少妇一区二区三区日产乱码| 成人晚上爱看视频| 视频精品一区二区| 国产精品久久久久影院亚瑟 | 中文乱码免费一区二区| 欧美专区亚洲专区| 国内成人自拍视频| 亚洲精品视频自拍| 久久综合九色综合97婷婷女人| 色哟哟在线观看一区二区三区| 久久se这里有精品| 一区二区三区四区在线| 精品欧美一区二区在线观看| 一本大道久久精品懂色aⅴ| 麻豆成人免费电影| 一区二区在线观看免费| 久久综合国产精品| 欧美日韩成人综合| av不卡免费在线观看| 久久国产精品72免费观看| 樱花影视一区二区| 欧美韩国日本不卡| 欧美va天堂va视频va在线| 欧美三级在线视频| av电影在线不卡|