📄 cadbase1.cpp
字号:
//-- {CycleCode: 698} file [0..975]
//-- {AddDecl: 699} module.includes preserve=yes [0..61]
//## begin module.includes preserve=yes
#include "stdafx.h"
#include "cadbase.h"
#include "math.h"
//## end module.includes preserve=yes
//-- {InsertRegion: 700} module.vulnerableDeclarations [62..975]
//## begin module.epilog preserve=yes
BOOL IsParallel(VECTOR2D v0,VECTOR2D v1)
{
CVector2D cv0(v0),cv1(v1);
return IS_ZERO((cv0*cv1).dz);
}
BOOL IsParallel(VECTOR3D v0,VECTOR3D v1)
{
CVector3D cv0(v0),cv1(v1);
return IS_ZERO((cv0*cv1).GetLength());
}
BOOL IsOrthogonal(VECTOR3D v0,VECTOR3D v1)
{
CVector3D cv0(v0),cv1(v1);
return IS_ZERO(cv0|cv1);
}
double AngleBetween(VECTOR2D v1,VECTOR2D v2)
{
if(IsParallel(v1,v2)) return 0;
CVector2D cv1(v1),cv2(v2);
return acos((cv1|cv2.GetNormal())/cv1.GetLength());
}
double AngleBetween(VECTOR3D v1,VECTOR3D v2)
{
if(IsParallel(v1,v2)) return 0;
CVector3D cv1(v1),cv2(v2);
return acos((cv1|cv2.GetNormal())/cv1.GetLength());
}
double DistOf(POINT2D pt0,POINT2D pt1)
{
CVector2D vec(pt1.x-pt0.x,pt1.y-pt0.y);
return vec.GetLength();
}
double DistOf(POINT3D pt0,POINT3D pt1)
{
CVector3D vec(pt1.x-pt0.x,pt1.y-pt0.y);
return vec.GetLength();
}
//-1 在外 0 相交 1 在内
//r1 为主
int RectConnection( CRect2D r1 , CRect2D r2 )
{
if(
r1.left > r2.right
|| r1.right < r2.left
|| r1.top < r2.bottom
|| r1.bottom > r2.top
)
{
return -1;
}
else if (
r1.left < r2.left
&& r1.right > r2.right
&& r1.top > r2.top
&& r1.bottom < r2.bottom
)
{
return 1;
}
else
{
return 0;
}
}
//## end module.epilog
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -