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

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

?? unitdesign.cpp

?? 在AUTOCAD環境下沿路線插入圖塊
?? CPP
字號:
// UnitBase.cpp: implementation of the UnitBase class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "resource.h"
#include "UnitDesign.h"
#include "math.h"
#include "compublic.h"
/*
#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif
*/
//////////////////////////////////////////////////
//   單元基類
//////////////////////////////////////////////////
UnitBase::UnitBase() 
{

}

UnitBase::~UnitBase()
{

}

BOOL UnitBase::SetStartInf(double x, double y, double rAzimuth)
{
	return FALSE;
}
BOOL UnitBase::GetEndInf(double &x, double &y, double &rAzimuth)
{
	return TRUE;
}
BOOL UnitBase::Draw(BOOL bDraw)
{
	return FALSE;
}
double UnitBase::ConvertFWJ(double a)
{	
	double rTep;
	rTep = PI / 2 - a;
	if (rTep < 0)
		rTep += (2 * PI);
	else if (rTep >= (2 * PI))
		rTep -= (PI / 2);
	return rTep;
}

double UnitBase::ConvertFWJ(ads_point pt1, ads_point pt2, ads_point pt3, ads_point pt4)
{
	ads_point ptt;
	int n = 0;
	double rFwj, r1, r2;
	r1 = ads_angle(pt1, pt2);
	r2 = ads_angle(pt3, pt4);

	rFwj = r2 - r1;
	if (rFwj > PI)
	{
		rFwj = (2 * PI - r2) - r1;
	}

	if (rFwj <= -PI)
	{
		rFwj = r2 - (r1 - 2 * PI);
	}
	
	return (-1 * rFwj);
}
double UnitBase::ConvertPolar(double a)
{
	double rTep;
	rTep = PI / 2 - a;
	return rTep;
}

BOOL UnitBase::GetXY(double l, double a, int n, double &x, double &y)
{

	double rTepx, rTepy;
	int i = 1, k = -1, m = 1;
	x = l; 	y = pow(l, 3) / (6 * pow(a, 2));
	while (i < n)
	{
		x += k * (pow(l, (m + 4)) / ((m + 4) * pow(2, i * 2) * 
			JieCheng(i * 2) * pow(a, m + 3)));	
		y += k * (pow(l, (m + 6)) / ((m + 6) * pow(2, (i * 2 + 1)) * 
			JieCheng(i * 2 + 1) * pow(a, m + 5)));
		
		k *= (-1);	m += 4; i++;
	}
	return TRUE;
}

double UnitBase::JieCheng(double a)
{
	double i = 1;
	double re = 1.0;
	for (i = 1.0; i <= a; i += 1.0) re *= i;
	return re;

}

BOOL UnitBase::GetLenInf(double len, double &x, double &y, double &rAzimuth)
{
	return TRUE;
}
//////////////////////////////////////////////////
//   積木法線單元
//////////////////////////////////////////////////
LineUnit::LineUnit()
{
}

LineUnit::~LineUnit()
{
}

BOOL LineUnit::SetStartInf(double x, double y, double rAzimuth, double rlen)
{
	m_rStartx = x;
	m_rStarty = y;
	m_rStartAzimuth = rAzimuth;
	m_rLen = rlen;

	m_rEndx = m_rStartx + m_rLen * sin(m_rStartAzimuth);
	m_rEndy = m_rStarty + m_rLen * cos(m_rStartAzimuth);
	m_rEndAzimuth = rAzimuth;
	return TRUE;
}

BOOL LineUnit::GetEndInf(double &x, double &y, double &rAzimuth)
{
	x = m_rEndx;
	y = m_rEndy;
	rAzimuth = m_rEndAzimuth;
	return TRUE;
}

BOOL LineUnit::GetLenInf(double len, double &x, double &y, double &rAzimuth)
{
	double xx, yy, a;
	x = m_rStartx + len * sin(m_rStartAzimuth);
	y = m_rStarty + len * cos(m_rStartAzimuth);
	rAzimuth = m_rStartAzimuth;
	return TRUE;
}

BOOL LineUnit::Draw(BOOL bDraw)
{
	ads_point pt1, pt2;
	struct resbuf *rbTmp = NULL;
	Spoint(pt1, m_rStartx, m_rStarty, 0);
	Spoint(pt2, m_rEndx, m_rEndy, 0);
	MakeLine(pt1, pt2, 4, "0", rbTmp, bDraw);
	ads_relrb(rbTmp);
	return TRUE;
}

//////////////////////////////////////////////////
//   積木法圓曲線單元
//////////////////////////////////////////////////
CircleUnit::CircleUnit()
{
}

CircleUnit::~CircleUnit()
{
}

BOOL CircleUnit::SetStartInf(double x, double y, double rAzimuth, int iTurn, double len, double rR)
{
	double aj, t, xm, ym;
	m_rStartx = x;
	m_rStarty = y;
	m_rStartAzimuth = rAzimuth;
	m_rStartPolar = ConvertPolar(rAzimuth);
	m_iTurn = iTurn;
	m_rLen = len;
	m_rR = rR;

	aj = m_rLen / m_rR;
	t = m_rR * tan(aj / 2);
	xm = m_rStartx + t * sin(m_rStartAzimuth);
	ym = m_rStarty + t * cos(m_rStartAzimuth);
	m_rEndAzimuth = m_rStartAzimuth + iTurn * aj;
	m_rEndPolar = m_rStartPolar + iTurn * aj;
	m_rEndx = xm + t * sin(m_rEndAzimuth);
	m_rEndy = ym + t * cos(m_rEndAzimuth);
	return TRUE;
}

BOOL CircleUnit::GetEndInf(double &x, double &y, double &rAzimuth)
{
	x = m_rEndx;
	y = m_rEndy;
	rAzimuth = m_rEndAzimuth;
	return TRUE;
}

BOOL CircleUnit::GetLenInf(double len, double &x, double &y, double &rAzimuth)
{
	double rlen = 0.0;
	rlen = m_rLen;
	SetStartInf(m_rStartx, m_rStarty, m_rStartAzimuth, m_iTurn, len, m_rR);
	x = m_rEndx;
	y = m_rEndy;
	rAzimuth = m_rEndAzimuth;

	SetStartInf(m_rStartx, m_rStarty, m_rStartAzimuth, m_iTurn, rlen, m_rR);

	return TRUE;
}

BOOL CircleUnit::Draw(BOOL bDraw)
{
	double rTep, rStartAngle, rEndAngle;
	ads_point ptcen, pt1, pt2, ptTep;
	struct resbuf *rbTmp = NULL;
	Spoint(pt1, m_rStartx, m_rStarty, 0.0);
	ads_polar(pt1, m_rStartPolar, 0.01, pt2);
	GetAngLine(pt1, pt2, 0, m_iTurn, PI / 2, m_rR, ptcen, ptTep);
	
	rStartAngle = m_rStartPolar + m_iTurn * (PI / 2);
	rEndAngle = rStartAngle - m_iTurn * (m_rLen / m_rR);

	if (m_iTurn < 0)
	{
		rTep = rStartAngle;
		rStartAngle = rEndAngle;
		rEndAngle = rTep;
	}
	MakeArc(ptcen, m_rR,rEndAngle, rStartAngle, 2, "0", rbTmp, bDraw);
	
	ads_relrb(rbTmp);
	return TRUE;
}

//////////////////////////////////////////////////
//   積木法回旋線單元
//////////////////////////////////////////////////

AllayUnit::AllayUnit()
{
	m_bFull = FALSE;
	m_iBtoS = 1;
}

AllayUnit::~AllayUnit()
{

}

AllayUnit::SetStartInf(double x, double y, double rAzimuth, 
					   int iTurn, double rA, double rstartR, double rendR)
{	

	double rTepR, r2;
	m_iTurn = iTurn; m_rA = rA; m_rStartR = rstartR; m_rEndR = rendR;
	m_rStartx = x; m_rStarty = y, m_rStartAzimuth = rAzimuth;
	m_rEndx = 0.0; m_rEndy = 0.0; m_rEndAzimuth = 0.0;

	m_bFull = FALSE;
	m_iBtoS = 1;

	//處理A值為零
	if (rA == 0.0)
	{
		m_rLen = 0.0;
		m_rEndx = m_rStartx; m_rEndy = m_rStarty; m_rEndAzimuth = m_rStartAzimuth;
		return TRUE;
	}


	if(m_rStartR < m_rEndR) 
	{
		//處理曲率由小到大
		rTepR = m_rStartR;
		m_iBtoS = FALSE;
	}

	else 
	{
		rTepR = m_rEndR;
		m_iBtoS = TRUE;
	}

	//處理完整回旋線
	if (m_rStartR > 1000000 || m_rEndR > 1000000) 
	{
		m_bFull = TRUE;
		m_rLen = m_rA * m_rA / rTepR;
		m_rEndx = INFINITY + 1;
		GetFullAInfo(m_rStartx, m_rStarty, m_rStartAzimuth, m_iTurn,
			m_rLen, m_rEndx, m_rEndy, m_rEndAzimuth);
	}

	//處理不完整回旋線
	else
	{ 
		m_bFull = FALSE;
		m_rLen = fabs(((m_rStartR - m_rEndR) * m_rA * m_rA) / (m_rStartR * m_rEndR));
		m_rEndx = INFINITY + 1;
		
		m_rTepLen = (m_rA * m_rA) / m_rStartR;
		//m_rTepLen記錄按完整回旋線計算至起點的曲線長

		
		if (m_rStartR > m_rEndR)
		{
			r2 = m_rEndR; m_rEndR = 1E+20;	
			//如果大曲率到小曲率,則計算從開始到起點無窮大的參數,并記錄于變量中
			GetFullAInfo(m_rStartx, m_rStarty, m_rStartAzimuth + PI, m_iTurn * (-1), 
				m_rTepLen, m_rTepStartx, m_rTepStarty, m_rTepStartAzimuth);
			m_rEndR = r2; 

		}
		else 
		{
			r2 = m_rEndR; m_rEndR = 1E+20;	
			//如果小曲率到大曲率,則計算從開始到起點無窮大的參數,并記錄于變量中
			GetFullAInfo(m_rStartx, m_rStarty, m_rStartAzimuth, m_iTurn, 
				m_rTepLen, m_rTepStartx, m_rTepStarty, m_rTepStartAzimuth);
			m_rEndR = r2; 
	
		}

		//獲取終點信息

		GetDeficAInfo(m_rStartx, m_rStarty, m_rStartAzimuth, m_iTurn, 
			m_rLen, m_rEndx, m_rEndy, m_rEndAzimuth);
			
	

	}
	return TRUE;
}

BOOL AllayUnit::GetEndInf(double &x, double &y, double &rAzimuth)
{
	x = m_rEndx;
	y = m_rEndy;
	if (m_rEndAzimuth > 2 * PI) 
		rAzimuth = m_rEndAzimuth - 2 * PI;
	else if (m_rEndAzimuth < 0.0) 
		rAzimuth = m_rEndAzimuth + (2 * PI);
	else 
		rAzimuth = m_rEndAzimuth;
	return TRUE;
}

BOOL AllayUnit::GetLenInf(double len, double &x, double &y, double &rAzimuth)
{
	if (TRUE == m_bFull)
	{
		GetFullAInfo(m_rStartx, m_rStarty, m_rStartAzimuth,m_iTurn,
			len, x, y, rAzimuth);
	}
	
	else
	{
		GetDeficAInfo(m_rStartx, m_rStarty, m_rStartAzimuth,m_iTurn,
			len, x, y, rAzimuth);
	}
	return TRUE;
}



double AllayUnit::GetUnitLen()
{
	double rLen;
	rLen = m_rLen;
	return rLen;
}

AllayUnit::GetFullAInfo(double rstartx, double rstarty, double rstartAzimuth, int iTurn,
					double l, double &xx, double &yy, double &rcalAzimuth)
{
		double rX, rY, t1, t2, aj, rTep, xm, ym, rEndR, xxx, yyy;		
		
		//如果計算曲率由小到大,并且是獲取終點信息時調用
		if (m_rEndR > m_rStartR && m_rEndx != INFINITY + 1)
		{
			l = (m_rLen - l + PARTICLE);
			rstartx = m_rEndx;
			rstarty = m_rEndy;
			rstartAzimuth = m_rEndAzimuth + PI;
			iTurn *= (-1);
		}

		//得出終點半徑
		rEndR = m_rA * m_rA / l;
		
		//轉角
		aj = l / (2 * rEndR);

		//由展開式計算X,Y值
		GetXY(l, m_rA, 10, rX, rY);
		
		//計算切線長
		t1 = rX - rY / tan(aj); t2 = rY / sin(aj);

		//如果不是獲取終點信息,如果iBtoS調用
		if (m_rEndR > m_rStartR && m_rEndx == INFINITY + 1) 
		{ rTep = t1; t1 = t2; t2 = rTep; }

		//計算交點坐標
		xm = rstartx + t1 * sin(rstartAzimuth);
		ym = rstarty + t1 * cos(rstartAzimuth);
		
		rcalAzimuth = rstartAzimuth + iTurn * aj;
		xxx = xm + t2 * sin(rcalAzimuth);
		yyy = ym + t2 * cos(rcalAzimuth);

		//糾正假定方位角
		if (m_rEndR > m_rStartR && m_rEndx != INFINITY + 1)
		{
			rcalAzimuth += PI;
		}
		xx = xxx;		//返回計算坐標值
		yy = yyy;
}

AllayUnit::GetDeficAInfo(double rstartx, double rstarty, double rstartAzimuth, int iTurn,
				double l, double &xx, double &yy, double &rcalAzimuth)
{

	ads_point pt;
	struct resbuf *bnn = NULL;
	double rTep, rTepR, a1, a2, a3, b1, b2, b3;
	if (m_rStartR > m_rEndR)
	{
		GetFullAInfo(m_rTepStartx, m_rTepStarty, m_rTepStartAzimuth + PI, 
			m_iTurn, l + m_rTepLen, xx, yy, rcalAzimuth);
	}
	else
	{
		b1 = m_rEndx; b2 = m_rEndy; b3 = m_rEndAzimuth;
		m_rEndx = m_rTepStartx; m_rEndy = m_rTepStarty; m_rEndAzimuth = m_rTepStartAzimuth;
		m_iBtoS = FALSE; rTep = m_rLen; m_rLen = m_rTepLen;
		rTepR = m_rEndR; m_rEndR =  1E+20;

		GetFullAInfo(m_rStartx, m_rStarty, rstartAzimuth,
			m_iTurn, l, a1, a2, a3);

		m_rLen = rTep; m_rEndR = rTepR;
		m_rEndx = b1; m_rEndy = b2; m_rEndAzimuth = b3;
		xx = a1; yy = a2; rcalAzimuth = a3;

	}
	
}


AllayUnit::Draw(BOOL bDraw)
{
	int n, i, iColor = 1;
	double rTepLong = 0.0, rTepx, rTepy, rfwj,rUnitLong = 0.0;
	struct resbuf *rbTep = NULL;
	AcGePoint3d ptTep;
	AcGePoint3dArray ptTepArray;
	

	if (m_rA == 0.0) return TRUE;

	if (m_rStartR < m_rEndR) iColor = 6;

	rUnitLong = m_rLen / 180;
	n = 180;

	if (FALSE == bDraw) 
	{
		rUnitLong = 1.0;
		double rTepLong;
		ads_point pt1, pt2;
		rTepLong = GetScreenH() / 30;

		//生成起始及結束斷面的短線
		Spoint(pt1, m_rStartx, m_rStarty, 0.0);
		ads_polar(pt1, ConvertPolar(m_rStartAzimuth + PI / 2.0),rTepLong / 2, pt1);
		ads_polar(pt1, ConvertPolar(m_rStartAzimuth - PI / 2.0), rTepLong, pt2);
		ads_grdraw(pt1, pt2, 256, 0);

		Spoint(pt1, m_rEndx, m_rEndy, 0.0);
		ads_polar(pt1, ConvertPolar(m_rEndAzimuth + PI / 2.0),rTepLong / 2, pt1);
		ads_polar(pt1, ConvertPolar(m_rEndAzimuth - PI / 2.0), rTepLong, pt2);
		ads_grdraw(pt1, pt2, 256, 0);

		rUnitLong = m_rLen / 10;
		n = 10;
		iColor = 256;
	}

	ptTep.set(m_rStartx, m_rStarty, 0.00);
	ptTepArray.append(ptTep);
	if (TRUE == m_bFull)
	{
		for (i = 0; i < n; i++)
		{
			rTepLong += rUnitLong;
			GetFullAInfo(m_rStartx, m_rStarty, m_rStartAzimuth,m_iTurn,
				rTepLong, rTepx, rTepy, rfwj);
			ptTep.set(rTepx, rTepy, 0.00);
			ptTepArray.append(ptTep);
		}
	}
	
	else
	{
		for (i = 0; i < n; i++)
		{
			rTepLong += rUnitLong;
			GetDeficAInfo(m_rStartx, m_rStarty, m_rStartAzimuth,m_iTurn,
				rTepLong, rTepx, rTepy, rfwj);
			ptTep.set(rTepx, rTepy, 0.00);
			ptTepArray.append(ptTep);
		}
	}

	ptTep.set(m_rEndx, m_rEndy, 0.00);
	ptTepArray.append(ptTep);
	MakePline(ptTepArray, "0", 0.0, iColor, rbTep, bDraw);




	ads_relrb(rbTep);
	return TRUE;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人av在线观| 国产精品久久精品日日| 久久亚洲综合av| 亚洲男女毛片无遮挡| 激情五月播播久久久精品| av爱爱亚洲一区| 欧美大片顶级少妇| 亚洲一区二区成人在线观看| 国产999精品久久久久久绿帽| 欧美三级视频在线播放| 国产精品久久久一本精品| 久久se这里有精品| 欧美丰满美乳xxx高潮www| 亚洲视频资源在线| 大陆成人av片| 久久只精品国产| 日本欧美一区二区在线观看| 欧亚一区二区三区| 亚洲精品一二三区| 91首页免费视频| 国产精品麻豆欧美日韩ww| 国产成人精品免费一区二区| 精品成人一区二区三区| 免费看精品久久片| 欧美一级片在线| 日本一道高清亚洲日美韩| 777久久久精品| 午夜精品福利一区二区三区蜜桃| 91蝌蚪porny九色| 亚洲视频电影在线| 色综合天天综合狠狠| 一区二区在线免费| 欧美色综合网站| 亚洲成人精品在线观看| 欧美色爱综合网| 丝袜亚洲另类丝袜在线| 欧美顶级少妇做爰| 天堂影院一区二区| 日韩精品专区在线| 另类小说一区二区三区| 久久久精品日韩欧美| 国产91高潮流白浆在线麻豆 | 亚洲欧洲av在线| 波多野结衣中文一区| 国产精品夫妻自拍| 欧美日韩一区在线| 视频一区二区中文字幕| 精品免费国产一区二区三区四区| 国产做a爰片久久毛片| 国产精品每日更新在线播放网址 | 男女性色大片免费观看一区二区| 91精品国产一区二区三区蜜臀| 日韩av电影免费观看高清完整版在线观看 | 蜜桃一区二区三区在线观看| 精品国产区一区| 国产精品一级黄| 欧美大肚乱孕交hd孕妇| 国产精品成人一区二区艾草| 日韩欧美视频在线| 精品欧美乱码久久久久久1区2区| 欧美大黄免费观看| 国产欧美一区二区在线观看| 夜夜操天天操亚洲| 精品一区二区三区在线观看 | 日韩av在线发布| 日本欧美韩国一区三区| 成人黄色网址在线观看| 欧美一区二区观看视频| 亚洲一级片在线观看| 亚洲欧美影音先锋| 国产一区二区三区在线观看精品| 亚洲免费高清视频在线| 日本色综合中文字幕| 色婷婷综合久久久中文一区二区| ...中文天堂在线一区| 中文字幕日韩一区二区| 欧美激情一区在线| 久久综合资源网| 欧美精品一区二区在线观看| 久久久影视传媒| 日本一区二区三区久久久久久久久不 | 婷婷丁香激情综合| 国产aⅴ综合色| 精品国产乱码久久| 97精品超碰一区二区三区| 777xxx欧美| 国产真实乱子伦精品视频| 欧美日韩一级黄| 国产亚洲综合在线| 欧美久久婷婷综合色| 国产精品一区二区免费不卡 | 韩国在线一区二区| 午夜久久久影院| 亚洲免费观看在线观看| 国产午夜精品在线观看| 91精品国产欧美一区二区18| 在线观看视频一区二区| a在线播放不卡| 国产成人免费在线观看| 狠狠网亚洲精品| 午夜精品aaa| 亚洲精品国产视频| 欧美国产97人人爽人人喊| 精品伦理精品一区| 69成人精品免费视频| 日本道精品一区二区三区| 99热99精品| 高清不卡一区二区| 国产二区国产一区在线观看| 国产精品99久久久久久久女警| 久热成人在线视频| 激情亚洲综合在线| 美洲天堂一区二卡三卡四卡视频| 日韩专区一卡二卡| 日本中文字幕一区二区视频| 日本va欧美va精品发布| 日日摸夜夜添夜夜添精品视频| 日本成人超碰在线观看| 日韩高清中文字幕一区| 日韩av网站免费在线| 久久精品国产**网站演员| 麻豆精品久久久| 国产一区二区三区最好精华液| 极品少妇一区二区| 国产福利电影一区二区三区| 国产91富婆露脸刺激对白| 99re成人精品视频| 欧美亚洲一区二区在线| 69久久99精品久久久久婷婷| 精品毛片乱码1区2区3区| 久久精品人人做人人综合| 国产精品天干天干在观线| 亚洲精品日韩专区silk| 天天综合天天综合色| 精品一区二区三区免费| 福利电影一区二区| 在线精品视频免费观看| 91精品国产91久久综合桃花| 欧美精品一区二区精品网| 国产精品毛片大码女人| 亚洲午夜免费电影| 狠狠色2019综合网| 99精品在线观看视频| 欧美精品一级二级| 国产亚洲精品免费| 亚洲猫色日本管| 久久国产精品色婷婷| 成人免费高清在线观看| 欧美另类久久久品| 亚洲国产精华液网站w| 亚洲h在线观看| 国产一区二区三区蝌蚪| 91国偷自产一区二区三区成为亚洲经典 | 久久久高清一区二区三区| 综合中文字幕亚洲| 麻豆精品国产91久久久久久| 国产成人免费视频网站| 欧美精品日韩综合在线| 国产精品视频看| 日韩二区在线观看| 成人听书哪个软件好| 欧美男人的天堂一二区| 欧美激情中文字幕| 日韩电影免费一区| 99久久亚洲一区二区三区青草| 91 com成人网| 国产精品传媒视频| 国产在线播放一区三区四| 欧美三区免费完整视频在线观看| 久久看人人爽人人| 蜜桃一区二区三区四区| 91久久精品一区二区三区| 国产情人综合久久777777| 日韩1区2区日韩1区2区| 色综合欧美在线视频区| 精品国产自在久精品国产| 亚洲一区在线观看网站| 国产黑丝在线一区二区三区| 欧美一区二区视频网站| 夜色激情一区二区| youjizz久久| 国产欧美日韩视频在线观看| 美国av一区二区| 6080日韩午夜伦伦午夜伦| 亚洲精品午夜久久久| 成人黄色网址在线观看| 国产欧美一区视频| 国产精品一区一区| 2020国产精品久久精品美国| 日韩精品一区第一页| 欧美性受xxxx| 夜夜嗨av一区二区三区中文字幕| 99久久精品国产网站| 中文字幕在线不卡国产视频| 成人免费毛片高清视频| 国产精品午夜久久| heyzo一本久久综合| 国产精品免费看片| 99视频热这里只有精品免费| 国产精品网站在线观看|