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

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

?? physics.cpp

?? 網絡游戲魔域源代碼 測試可以完整變異
?? CPP
字號:
// Physics.cpp: implementation of the CPysics class.
//
//////////////////////////////////////////////////////////////////////

#include "Physics.h"

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CPhysics::CPhysics()
{

}

CPhysics::~CPhysics()
{

}

//---------------------------------------------------------------------
DWORD CPhysics::S2DGetDistance(CMyPos posBegin, CMyPos posEnd)
{
	return (DWORD)sqrt(
					(posBegin.x - posEnd.x) * 
					(posBegin.x - posEnd.x) +
					(posBegin.y - posEnd.y) *
					(posBegin.y - posEnd.y) 
				);
}
//---------------------------------------------------------------------
BOOL CPhysics::S2DBMGetPos(int nV, float fA, float fT, CMyPos posBegin, CMyPos posEnd, CMyPos& posCurrent)
{
	double dwDistance = sqrt(
		(posBegin.x - posEnd.x) * 
		(posBegin.x - posEnd.x) +
		(posBegin.y - posEnd.y) *
		(posBegin.y - posEnd.y) 
				);
	if(dwDistance == 0)
	{
		posCurrent = posEnd;
		return true;
	}

	double nCompleteDistance = (int)(nV * fT + fA * fT * fT / 2);
	if(nCompleteDistance >= dwDistance)
	{
		posCurrent = posEnd;
		return true;
	}

	// Get Currentpos
	double dX = posBegin.x + (posEnd.x - posBegin.x) * nCompleteDistance / dwDistance;
	double dY = posBegin.y + (posEnd.y - posBegin.y) * nCompleteDistance / dwDistance;

	posCurrent.x = ::Double2Int(dX);
	posCurrent.y = ::Double2Int(dY);
	return false;
}
//---------------------------------------------------------------------
void CPhysics::S3Get3DDir(CMy3DPos posBegin, CMy3DPos posEnd, CMy3DDir& dir3D)
{
// 計算平行角度
	double fPei=3.14159;
	// 計算夾角先
	int nOffsetX = posEnd.x-posBegin.x;
	if(nOffsetX == 0)
		nOffsetX = 1;
	double fTan = (posEnd.y-posBegin.y)*1.0/nOffsetX;
	if(fTan < 0)
		fTan = -fTan;

	double fHorizontal = atan(fTan);	

	// 判斷在哪個象限,取附加數(shù)值
	int nX = posEnd.x - posBegin.x;
	int nY = posEnd.y - posBegin.y;
	if((nX > 0) && (nY < 0))
	{
		// 第一象限
		dir3D.fHorizontal = (float)(fHorizontal + fPei/2);
	}
	else if((nX < 0) && (nY >= 0))
	{
		// 第二象限
		dir3D.fHorizontal = (float)(fHorizontal - fPei/2);
	}
	else if((nX < 0) && (nY < 0))
	{
		// 第三象限
		dir3D.fHorizontal = (float)(-fPei/2 - fHorizontal);
	}
	else
	{
		// 第四象限
		dir3D.fHorizontal = (float)(fPei/2 - fHorizontal);
	}

// 計算垂直角度
	// 計算夾角先          
	fTan = abs(posEnd.z-posBegin.z)/sqrt((posEnd.y-posBegin.y)*(posEnd.y-posBegin.y) + (posEnd.x-posBegin.x)*(posEnd.x-posBegin.x));
	double fVertical = atan(fTan);

	// 判斷在哪個象限,取附加數(shù)值
	int nZ = posEnd.z-posBegin.z;
	if(nZ >=0 )
		dir3D.fVertical = (float)fVertical;
	else
		dir3D.fVertical = (float)(-fVertical);
}
//---------------------------------------------------------------------
BOOL CPhysics::IsPointInRect(CMyPos posPoint, CMyRect rect)
{
	if((posPoint.x >= rect.l) &&
	   (posPoint.x <= rect.r) &&
	   (posPoint.y >= rect.b) &&
	   (posPoint.y <= rect.t))
	   return true;
	return false;
}
//---------------------------------------------------------------------
void CPhysics::S2DR45VP(CMyPos posTarget, CMyPos& posPoint)
{
	CMyPos posRule={0, 32};

	// 真實長度在 32 和 16 之間
	// 先求真實長度RealDistance
	// 為求真實長度必須求和X軸夾角,用偽橢圓近似
	float fTag = 0.0;
	if(posTarget.x == 0)
		fTag = 0.0;
	else if(posTarget.y == 0)
		fTag = 2.0;
	else 
		fTag = (float)(1.0*posTarget.x/posTarget.y);

	if(fTag < 0)
		fTag = -fTag;
	if(fTag > 2.0)
		fTag = 2.0;
	float fDistance = (float)sqrt(posTarget.x*posTarget.x + posTarget.y*posTarget.y);
	// 靠近0為16, 靠近2.0為32
	float fRealDistance = (float)(16 + 16*fTag*1.0/2);
	CMyPos posRealTarget;

	// 求終點
	if((posTarget.x == 0)&&(posTarget.y != 0))
	{
		posRealTarget.x = 0;
		posRealTarget.y = (int)((posTarget.y/abs(posTarget.y))*fRealDistance);
	}
	else if((posTarget.y == 0)&&(posTarget.x != 0))
	{
		posRealTarget.y = 0;
		posRealTarget.x = (int)((posTarget.x/abs(posTarget.x))*fRealDistance);
	}
	else if((posTarget.y == 0)&&(posTarget.x == 0))
	{
		posRealTarget.x = 0;
		posRealTarget.y = 0;
	}
	else
	{
		posRealTarget.x = (int)(1.0*posTarget.x*fRealDistance/fDistance);
		posRealTarget.y = (int)(1.0*posTarget.y*fRealDistance/fDistance);
	}
	// 求映射點
	float fScale = (float)(posPoint.x*1.0/32);
	if(fScale < 0)
		fScale = -fScale;
	posPoint.x = (int)(posRealTarget.x * fScale);
	posPoint.y = (int)(posRealTarget.y * fScale);
}
//---------------------------------------------------------------------
BOOL CPhysics::S2DCMGetPos(int nV, float fA, float fT, float fRadii, CMyPos posBegin, CMyPos posEnd, CMyPos& posCurrent, BOOL bSide)
{
	// Calculate the shortest distance from begin position to end position
	double dDistance = sqrt( (posBegin.x - posEnd.x) * (posBegin.x - posEnd.x) + (posBegin.y - posEnd.y) * (posBegin.y - posEnd.y) );
	if ( dDistance == 0 )
	{
		posCurrent = posEnd;
		return true;
	}
	
	// Calculate the complete distance(The V&A are beeline, only the move track is curve)
	double dCompleteDistance = (int)( nV * fT + fA * fT * fT / 2 );
	if ( dCompleteDistance >= dDistance )
	{
		posCurrent = posEnd;
		return true;
	}
	
	// Calculate the curve offset from the shortest path
	double dLongRadii	= (int)( dDistance / 2 );
	double dShortRadii	= (int)( fRadii * dLongRadii );
	double dwCurveDistance = sqrt( dShortRadii * dShortRadii - ( dShortRadii * dShortRadii * ( dLongRadii - dCompleteDistance  ) * ( dLongRadii - dCompleteDistance ) ) / ( dLongRadii * dLongRadii ) );
	
	// The X axis and Y axis offset on the shortest path
	double dX = ( posEnd.x - posBegin.x ) * dCompleteDistance / dDistance;
	double dY = ( posEnd.y - posBegin.y ) * dCompleteDistance / dDistance;
	
	// Calculate the angle
	double dAngle = atan( dY / dX );
	
	if ( bSide )
	{
		dX -= sin(dAngle) * dwCurveDistance;
		dY += cos(dAngle) * dwCurveDistance;
	}
	else
	{
		dX += sin(dAngle) * dwCurveDistance;
		dY -= cos(dAngle) * dwCurveDistance;
	}
	
	dX += posBegin.x;
	dY += posBegin.y;
	
	posCurrent.x = ::Double2Int(dX);
	posCurrent.y = ::Double2Int(dY);
	return false;
}
//---------------------------------------------------------------------

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩成人dvd| 欧美在线观看一二区| 9i看片成人免费高清| 欧美日韩情趣电影| 亚洲国产成人在线| 青青草精品视频| 99久久er热在这里只有精品66| 欧美精品xxxxbbbb| 最好看的中文字幕久久| 韩国av一区二区三区| 欧美老年两性高潮| 日韩美女视频一区| 成人性生交大片免费看视频在线 | 国产人妖乱国产精品人妖| 亚洲午夜精品一区二区三区他趣| 国产成人av一区二区三区在线| 国产精品电影一区二区三区| 视频一区在线播放| 欧美在线一二三四区| 亚洲欧美怡红院| 成人激情文学综合网| 久久久五月婷婷| 久久66热re国产| 精品少妇一区二区三区在线播放 | 色婷婷综合久色| 国产精品久久久久四虎| 丁香激情综合国产| 欧美激情一区二区三区| 国产福利一区二区三区在线视频| 欧美va亚洲va香蕉在线| 精品综合久久久久久8888| 欧美一区二区三区啪啪| 日韩精品福利网| 欧美一区二区三区四区五区| 日韩av一区二区三区| 91精品在线观看入口| 亚洲.国产.中文慕字在线| 欧美日韩一区二区在线观看| 亚洲国产婷婷综合在线精品| 欧美在线不卡视频| 亚洲成a人片在线不卡一二三区| 欧美体内she精高潮| 午夜精品久久久久久久久久久| 欧美国产精品中文字幕| 国产高清一区日本| 中文字幕日本不卡| 91国内精品野花午夜精品| 亚洲一区二区三区四区在线| 欧美男生操女生| 久久成人18免费观看| 久久精品欧美一区二区三区不卡| 国产成人在线观看| 亚洲精品乱码久久久久久黑人| 欧美亚洲国产一区在线观看网站| 午夜精品福利一区二区三区av| 欧美一区二区三区免费在线看 | 欧美日韩一区不卡| 免费视频最近日韩| 欧美国产日韩精品免费观看| www.爱久久.com| 午夜精品久久一牛影视| 久久久午夜精品理论片中文字幕| av在线播放一区二区三区| 亚洲一区在线视频| 久久只精品国产| 色综合欧美在线| 蜜桃视频第一区免费观看| 国产精品乱码妇女bbbb| 欧美色中文字幕| 国产精品99久久久| 亚洲一区二区视频在线观看| 日韩美女在线视频 | 色婷婷国产精品久久包臀 | 亚洲精品ww久久久久久p站| 欧美一区二区国产| av不卡在线观看| 麻豆精品视频在线观看免费| 国产精品电影一区二区| 欧美电影免费观看高清完整版在线 | 欧美国产精品专区| 欧美一级片免费看| 99国产精品久久久久久久久久| 成人永久免费视频| 免费成人av在线播放| 亚洲天堂精品视频| 久久久国产综合精品女国产盗摄| 欧美日韩卡一卡二| 成人h版在线观看| 精品一区二区三区av| 亚洲综合色婷婷| 国产精品久久久一区麻豆最新章节| 欧美日韩精品一区二区三区蜜桃| 成人免费精品视频| 精品一区二区精品| 青青青爽久久午夜综合久久午夜| 亚洲精品综合在线| 国产精品毛片高清在线完整版| 日韩一区二区精品在线观看| 91久久精品日日躁夜夜躁欧美| 国产成人精品免费在线| 久久国产欧美日韩精品| 亚洲高清一区二区三区| 亚洲欧美色一区| 中文字幕日韩精品一区| 亚洲国产高清在线观看视频| 精品国产乱码久久久久久闺蜜| 制服.丝袜.亚洲.另类.中文| 欧美性大战久久| 在线观看亚洲精品视频| 色综合天天综合狠狠| 成人伦理片在线| 不卡的电影网站| 成人国产一区二区三区精品| 成人丝袜18视频在线观看| 国产精品1区2区3区| 国产成人精品亚洲777人妖 | 91美女视频网站| 91麻豆视频网站| 一本大道久久精品懂色aⅴ| 99国产精品国产精品久久| av爱爱亚洲一区| 色香蕉成人二区免费| 在线观看不卡视频| 欧美日韩视频在线第一区| 欧美精品乱码久久久久久按摩| 在线91免费看| 日韩精品综合一本久道在线视频| 欧美xxxxxxxxx| 国产欧美一区二区三区网站| 欧美激情一区三区| 樱桃国产成人精品视频| 亚洲午夜视频在线| 美国十次综合导航| 国产精品亚洲а∨天堂免在线| 成人少妇影院yyyy| 91电影在线观看| 日韩三级电影网址| 国产欧美日本一区二区三区| 亚洲同性同志一二三专区| 亚洲一区二区三区四区不卡| 日本aⅴ亚洲精品中文乱码| 精品一区二区三区久久久| 99久久亚洲一区二区三区青草| 色素色在线综合| 日韩一卡二卡三卡国产欧美| 国产欧美精品区一区二区三区| 日韩美女视频19| 另类综合日韩欧美亚洲| 国产成人精品午夜视频免费| 色哟哟一区二区在线观看 | 国产日韩欧美在线一区| 伊人一区二区三区| 欧美系列亚洲系列| 欧美电影免费观看高清完整版| 国产精品国产自产拍高清av| 日本在线不卡视频一二三区| 豆国产96在线|亚洲| 精品视频1区2区3区| 国产亚洲精品久| 香蕉久久夜色精品国产使用方法 | 国产91清纯白嫩初高中在线观看| 99re这里只有精品首页| 日韩视频123| 一区二区三区中文字幕电影| 国内精品视频一区二区三区八戒| 色av一区二区| 久久久亚洲国产美女国产盗摄 | 日韩在线一区二区三区| 高清av一区二区| 日韩欧美综合一区| 伊人开心综合网| 成人一区二区在线观看| 日韩欧美一区在线观看| 亚洲高清在线视频| 不卡大黄网站免费看| 精品国产一区二区精华| 香蕉成人啪国产精品视频综合网| 国产高清精品网站| 欧美大片在线观看一区| 亚洲成av人在线观看| 色94色欧美sute亚洲线路一ni| 久久精品视频在线免费观看| 免费xxxx性欧美18vr| 欧美性色黄大片| 亚洲欧美日本在线| av一区二区三区在线| 午夜精品在线看| 色综合婷婷久久| 亚洲日本电影在线| 成人av动漫网站| 国产精品美女久久久久aⅴ| 国产经典欧美精品| 精品国产亚洲一区二区三区在线观看| 亚洲成人免费视频| 欧美日韩视频在线第一区 | 国产精品国产三级国产aⅴ中文| 国产一区三区三区| 久久综合色鬼综合色| 久久国产精品一区二区| 日韩三级在线免费观看|