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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? camera.cpp

?? 通過vc++編程實現3DS格式的模型載入
?? CPP
字號:
//========================================================
/**
*  @file      Camera.cpp
*
*  項目描述: 3DS文件載入
*  文件描述:  攝像機類  
*  適用平臺: Windows98/2000/NT/XP
*  
*  作者:     WWBOSS
*  電子郵件:  wwboss123@gmail.com
*  創建日期: 2006-12-06	
*  修改日期: 2006-12-07
*
*/     
//========================================================

#include "stdafx.h"
#include "Camera.h"                    /**< 包含攝像機頭文件 */
#include "Vector.h"                    /**< 包含向量類 */
#include "GLFrame.h"


Camera* Camera::m_pCamera = NULL;

/** 構造函數 */
Camera::Camera()
{
	/** 初始化向量值 */
	Vector3 zero = Vector3(0.0, 0.0, 0.0);		
	Vector3 view = Vector3(0.0, 1.0, 0.5);		
	Vector3 up   = Vector3(0.0, 0.0, 1.0);		
    
	/** 初始化攝像機 */
	m_Position	= zero;					
	m_View		= view;				
	m_UpVector	= up;	
	m_Speed     = 0.1f;
	
	m_pCamera = this;
}


Camera::~Camera()
{
}

/** 設置攝像機的位置,朝向和向上向量 */
void Camera::setCamera( float positionX, float positionY, float positionZ,
				  		float viewX,     float viewY,     float viewZ,
						float upVectorX, float upVectorY, float upVectorZ)
{
	/** 構造向量 */
	Vector3 Position	= Vector3(positionX, positionY, positionZ);
	Vector3 View		= Vector3(viewX, viewY, viewZ);
	Vector3 UpVector	= Vector3(upVectorX, upVectorY, upVectorZ);

	/** 設置攝像機 */
	m_Position = Position;	
	m_View     = View;			
	m_UpVector = UpVector;	
}

/**  旋轉攝像機方向  */
void Camera::rotateView(float angle, float x, float y, float z)
{
	Vector3 newView;

	/** 計算方向向量 */
	Vector3 view = m_View - m_Position;		

	/** 計算 sin 和cos值 */
	float cosTheta = (float)cos(angle);
	float sinTheta = (float)sin(angle);

	/** 計算旋轉向量的x值 */
	newView.x  = (cosTheta + (1 - cosTheta) * x * x)		* view.x;
	newView.x += ((1 - cosTheta) * x * y - z * sinTheta)	* view.y;
	newView.x += ((1 - cosTheta) * x * z + y * sinTheta)	* view.z;

	/** 計算旋轉向量的y值 */
	newView.y  = ((1 - cosTheta) * x * y + z * sinTheta)	* view.x;
	newView.y += (cosTheta + (1 - cosTheta) * y * y)		* view.y;
	newView.y += ((1 - cosTheta) * y * z - x * sinTheta)	* view.z;

	/** 計算旋轉向量的z值 */
	newView.z  = ((1 - cosTheta) * x * z - y * sinTheta)	* view.x;
	newView.z += ((1 - cosTheta) * y * z + x * sinTheta)	* view.y;
	newView.z += (cosTheta + (1 - cosTheta) * z * z)		* view.z;

	/** 更新攝像機的方向 */
	m_View = m_Position + newView;
}

/** 用鼠標旋轉攝像機 */
void Camera::setViewByMouse()
{
	POINT mousePos;									  /**< 保存當前鼠標位置 */
	int middleX = GetSystemMetrics(SM_CXSCREEN) >> 1; /**< 得到屏幕寬度的一半 */
	int middleY = GetSystemMetrics(SM_CYSCREEN) >> 1; /**< 得到屏幕高度的一半 */
	float angleY = 0.0f;							  /**< 攝像機左右旋轉角度 */
	float angleZ = 0.0f;		                      /**< 攝像機上下旋轉角度 */					
	static float currentRotX = 0.0f;
	
	/** 得到當前鼠標位置 */
	GetCursorPos(&mousePos);						
	ShowCursor(TRUE);
	
	/** 如果鼠標沒有移動,則不用更新 */
	if( (mousePos.x == middleX) && (mousePos.y == middleY) )
		return;

	/** 設置鼠標位置在屏幕中心 */
	SetCursorPos(middleX, middleY);	
	
	/**< 得到鼠標移動方向 */
	angleY = (float)( (middleX - mousePos.x) ) / 1000.0f;		
	angleZ = (float)( (middleY - mousePos.y) ) / 1000.0f;		

    static float lastRotX = 0.0f;      /**< 用于保存旋轉角度 */
 	lastRotX = currentRotX; 
	
	/** 跟蹤攝像機上下旋轉角度 */
	currentRotX += angleZ;
 
	/** 如果上下旋轉弧度大于1.0,我們截取到1.0并旋轉 */
	if(currentRotX > 1.0f)     
	{
		currentRotX = 1.0f;
		
		/** 根據保存的角度旋轉方向 */
		if(lastRotX != 1.0f) 
		{
			/** 通過叉積找到與旋轉方向垂直的向量 */
			Vector3 vAxis = m_View - m_Position;
			vAxis = vAxis.crossProduct(m_UpVector);
			vAxis = vAxis.normalize();
			
			///旋轉
			rotateView( 1.0f - lastRotX, vAxis.x, vAxis.y, vAxis.z);
		}
	}
	/** 如果旋轉弧度小于-1.0,則也截取到-1.0并旋轉 */
	else if(currentRotX < -1.0f)
	{
		currentRotX = -1.0f;
				
		if(lastRotX != -1.0f)
		{
			
			/** 通過叉積找到與旋轉方向垂直的向量 */
			Vector3 vAxis = m_View - m_Position;
			vAxis = vAxis.crossProduct(m_UpVector);
			vAxis = vAxis.normalize();
			
			///旋轉
			rotateView( -1.0f - lastRotX, vAxis.x, vAxis.y, vAxis.z);
		}
	}
	/** 否則就旋轉angleZ度 */
	else 
	{	
		/** 找到與旋轉方向垂直向量 */
		Vector3 vAxis = m_View - m_Position;
		vAxis = vAxis.crossProduct(m_UpVector);
		vAxis = vAxis.normalize();
	
		///旋轉
		rotateView(angleZ, vAxis.x, vAxis.y, vAxis.z);
	}

	/** 總是左右旋轉攝像機 */
	rotateView(angleY, 0, 1, 0);
}


/** 左右移動攝像機 */
void Camera::yawCamera(float speed)
{
	Vector3 yaw;
	Vector3 oldPos,oldView;
	Vector3 cross = m_View - m_Position;
	oldPos = m_Position;
	oldView = m_View;
	cross = cross.crossProduct(m_UpVector);

	///歸一化向量
	yaw = cross.normalize();
 
	m_Position.x += yaw.x * speed;
	m_Position.z += yaw.z * speed;

	m_View.x += yaw.x * speed;
	m_View.z += yaw.z * speed;
	
	/** 進行邊界檢查和限定 */
	if(m_View.x > MAP_WIDTH - 20 || m_View.x < 2*CELL_WIDTH)
	{
		m_Position.x = oldPos.x ;
		m_View.x = oldView.x;
	}

	if(m_View.z > MAP_WIDTH - 20 || m_View.z < 2*CELL_WIDTH)
	{
		m_Position.z = oldPos.z ;
		m_View.z = oldView.z;
	}
		
	

}

/** 前后移動攝像機 */
void Camera::moveCamera(float speed)
{
	/** 計算方向向量 */
	Vector3 vector = m_View - m_Position;
	vector = vector.normalize();         /**< 單位化 */
	Vector3 oldPos,oldView;
	oldPos = m_Position;
	oldView = m_View;
	
	/** 更新攝像機 */
	m_Position.x += vector.x * speed;    /**< 根據速度更新位置 */
	m_Position.z += vector.z * speed;	
	m_Position.y += vector.y * speed;
	
	
	m_View.x += vector.x * speed;		 /**< 根據速度更新方向 */	
	m_View.y += vector.y * speed;
	m_View.z += vector.z * speed;
	
    /** 進行邊界檢查和限定 */	
	if(m_View.x > MAP_WIDTH - 20 || m_View.x <  2*CELL_WIDTH)
	{
		m_Position.x = oldPos.x ;
		m_View.x = oldView.x;
	}

	if(m_View.z > MAP_WIDTH - 20 || m_View.z < 2*CELL_WIDTH)
	{
		m_Position.z = oldPos.z ;
		m_View.z = oldView.z;
	}
	

}

/** 設置視點 */
void Camera::setLook()
{
	
	/** 設置視口 */
	gluLookAt(m_Position.x, m_Position.y, m_Position.z,	
			  m_View.x,	 m_View.y,     m_View.z,	
			  m_UpVector.x, m_UpVector.y, m_UpVector.z);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
韩国欧美一区二区| 免费观看一级特黄欧美大片| 久久久99精品免费观看不卡| 91精选在线观看| 欧美成人国产一区二区| 久久久久久亚洲综合影院红桃| 久久久噜噜噜久噜久久综合| 国产喷白浆一区二区三区| 国产精品私房写真福利视频| 亚洲精品福利视频网站| 日本成人在线电影网| 国产麻豆视频一区| 91看片淫黄大片一级| 91蜜桃网址入口| 日韩欧美中文字幕一区| 欧美激情一区在线观看| 亚洲成人中文在线| 成人性视频免费网站| 99视频一区二区| 日韩欧美国产三级| 亚洲视频一二三| 麻豆成人免费电影| 在线亚洲一区二区| 精品日韩99亚洲| 日本中文字幕一区二区视频| 国内成人精品2018免费看| 欧美在线看片a免费观看| 国产欧美一区视频| 青青草国产精品97视觉盛宴| 欧美日本国产视频| 欧美日韩色综合| 一区二区三国产精华液| 91香蕉国产在线观看软件| 欧美视频一区二区在线观看| 国产精品区一区二区三| 国产在线精品免费| 91精品国产91久久综合桃花| 又紧又大又爽精品一区二区| 成人影视亚洲图片在线| 精品国产制服丝袜高跟| 日韩电影免费在线观看网站| 欧美色男人天堂| 亚洲三级视频在线观看| 日韩免费电影一区| 精品一二线国产| 亚洲四区在线观看| 国产成人av电影在线| 91精品国产黑色紧身裤美女| 亚洲精品免费在线| 成人福利电影精品一区二区在线观看| 91成人在线免费观看| 国产精品久久精品日日| 高清成人免费视频| 国产精品日韩成人| 欧美性高清videossexo| 免费高清在线视频一区·| 国产亚洲成年网址在线观看| 成人毛片在线观看| 一区二区三区成人| 精品国产成人系列| 国产精品一区2区| 日韩久久一区二区| 欧美成人精品3d动漫h| 成人av集中营| 美女看a上一区| 欧美日韩一区国产| 在线这里只有精品| 精品久久久久久久一区二区蜜臀| 日韩视频永久免费| 欧美一级黄色大片| 欧美一区二区三区在线电影| 欧美私人免费视频| 欧美在线观看视频一区二区| 99久久国产综合精品女不卡| 国产成人av一区二区| 精品在线亚洲视频| 成人丝袜18视频在线观看| 国产高清不卡一区| 国内成人免费视频| 久久99精品久久只有精品| 麻豆成人久久精品二区三区红 | 蜜桃av一区二区在线观看 | 欧美在线一区二区三区| 成人精品小蝌蚪| 91麻豆精东视频| 99久久精品99国产精品| 欧美亚洲动漫制服丝袜| 欧美精品vⅰdeose4hd| 精品国产一区二区三区四区四 | 日韩视频一区二区三区| 欧美日韩视频在线第一区| 精品国产乱码久久久久久夜甘婷婷| 9191久久久久久久久久久| 欧美电影免费观看高清完整版在线 | 天堂影院一区二区| 美国欧美日韩国产在线播放| 成人国产亚洲欧美成人综合网| 91在线小视频| 欧美大片免费久久精品三p| 国产精品久久久久久久第一福利 | 欧美另类久久久品| 国产欧美精品一区| 亚洲第一成年网| 成人黄色在线网站| 日韩一级二级三级| 亚洲国产精品久久不卡毛片 | 久久色视频免费观看| 香蕉成人啪国产精品视频综合网 | 国产欧美精品一区| 国产一区二区三区在线看麻豆| 欧美私模裸体表演在线观看| 国产精品污网站| 久久97超碰国产精品超碰| 欧美天天综合网| 亚洲国产精品一区二区尤物区| 国产成人午夜高潮毛片| 精品欧美一区二区久久 | 欧美视频中文字幕| 亚洲成人先锋电影| 欧美日韩另类一区| 亚洲午夜一区二区三区| 欧美日韩成人一区| 久久se这里有精品| 精品国产一二三区| 精品一区二区在线播放| 欧美精品一区二区三区很污很色的 | 午夜欧美大尺度福利影院在线看| 日本精品一级二级| 亚洲综合色成人| 欧美精品一二三| 美女一区二区视频| 久久网这里都是精品| 国产成人av资源| 亚洲精品国产成人久久av盗摄 | 亚洲成人资源在线| 日韩欧美成人一区| 国产传媒一区在线| 一区二区在线观看免费视频播放| 91精品国产入口在线| 国产酒店精品激情| 亚洲日本va午夜在线电影| 欧美日韩视频在线第一区| 国产米奇在线777精品观看| 中文字幕一区二区三| 欧美一区二区三区精品| 99久久国产综合精品女不卡| 日韩av网站免费在线| 亚洲视频免费在线观看| 日韩三级视频在线观看| 欧美视频一区二区三区四区| 国产成人在线观看免费网站| 麻豆国产91在线播放| 性久久久久久久久| 亚洲少妇屁股交4| 欧美激情中文字幕| 久久亚洲一级片| 日韩欧美精品三级| 欧美人体做爰大胆视频| 成人福利视频在线| 国产经典欧美精品| 国产一区二区三区av电影| 午夜精品久久一牛影视| 一区二区三区不卡视频| 亚洲男人都懂的| 亚洲精品乱码久久久久久黑人| 国产精品久久久久久亚洲伦 | 国产成人免费网站| 国产麻豆精品theporn| 激情欧美一区二区| 国产乱色国产精品免费视频| 国产麻豆视频精品| 懂色av一区二区三区免费看| 国产成人精品网址| 色视频欧美一区二区三区| 在线国产电影不卡| 日韩午夜在线影院| 国产人成一区二区三区影院| 国产欧美一区二区精品婷婷| 中文字幕精品一区| 亚洲国产一区视频| 国产一区二区精品久久| av在线不卡电影| 91精品综合久久久久久| 久久综合久久鬼色| 一区二区三区在线观看欧美| 丝袜脚交一区二区| 成人不卡免费av| 日韩欧美亚洲另类制服综合在线| 日本一区二区三区四区| 午夜精品在线看| 成人精品电影在线观看| 91精品国产品国语在线不卡| 国产精品嫩草99a| 国产一区二区三区四区五区美女| 欧美在线你懂的| 国产精品久久一卡二卡| 国产精品一卡二卡| 精品国产一区久久| 日本伊人精品一区二区三区观看方式| 高清不卡在线观看av|