📄 point3d_test.cpp
字号:
//===========================================================================//
// File: point.tst //
// Contents: test code for point class //
//---------------------------------------------------------------------------//
// Copyright (C) Microsoft Corporation. All rights reserved. //
//===========================================================================//
#include "StuffHeaders.hpp"
//
//###########################################################################
//###########################################################################
//
bool
Point3D::TestClass()
{
SPEW((GROUP_STUFF_TEST, "Starting Point3D test...\n"));
const Point3D
a(Identity);
Point3D
b;
const Point3D
c(1.0f,2.0f,3.0f);
Point3D
d(2.0f,3.0f,1.0f);
Test_Assumption(!a.x && !a.y && !a.z);
#if 0
Test_Assumption(c.x == 1.0f && c.y == 2.0f && c.z == 3.0f);
Test_Assumption(c[2] == c.z);
Test_Assumption(a[1] == a.y);
#endif
Test_Assumption(Small_Enough(a));
// Test_Assumption(!a);
b = c;
#if 0
Test_Assumption(b.x == c.x && b.y == c.y && b.z == c.z);
#endif
Test_Assumption(Close_Enough(b,c));
Test_Assumption(b == c);
Test_Assumption(a != b);
b.Negate(c);
Test_Assumption(b == Point3D(-c.x,-c.y,-c.z));
b.Add(c,d);
Test_Assumption(b == Point3D(c.x+d.x,c.y+d.y,c.z+d.z));
b = c;
b += d;
Test_Assumption(b == Point3D(c.x+d.x,c.y+d.y,c.z+d.z));
b.Subtract(d,c);
Test_Assumption(b == Point3D(d.x-c.x,d.y-c.y,d.z-c.z));
b = d;
b -= c;
Test_Assumption(b == Point3D(d.x-c.x,d.y-c.y,d.z-c.z));
Scalar f = c*d;
#if 0
Test_Assumption(f == c.x*d.x + c.y*d.y + c.z*d.z);
#endif
b.Cross(c,d);
Test_Assumption(b == Point3D(c.y*d.z-c.z*d.y,c.z*d.x-c.x*d.z,c.x*d.y-c.y*d.x));
f = 2.0f;
b.Multiply(c,f);
Test_Assumption(b == Point3D(f*c.x,f*c.y,f*c.z));
b = c;
b *= f;
Test_Assumption(b == Point3D(f*c.x,f*c.y,f*c.z));
b.Multiply(c,d);
Test_Assumption(b == Point3D(c.x*d.x,c.y*d.y,c.z*d.z));
b = c;
b *= d;
Test_Assumption(b == Point3D(c.x*d.x,c.y*d.y,c.z*d.z));
b.Divide(c,f);
Test_Assumption(b == Point3D(c.x/f,c.y/f,c.z/f));
b = c;
b /= f;
Test_Assumption(b == Point3D(c.x/f,c.y/f,c.z/f));
b.Divide(c,d);
Test_Assumption(b == Point3D(c.x/d.x,c.y/d.y,c.z/d.z));
b = c;
b /= d;
Test_Assumption(b == Point3D(c.x/d.x,c.y/d.y,c.z/d.z));
AffineMatrix4D
m;
EulerAngles
r(Pi_Over_4,0.0f,0.0f);
m.BuildRotation(r);
m.BuildTranslation(c);
b = m;
Test_Assumption(b == c);
b.Multiply(c,m);
Test_Assumption(b == Point3D(c.x+m(3,0),c.y*m(1,1)+c.z*m(2,1)+m(3,1),c.y*m(1,2)+c.z*m(2,2)+m(3,2)));
b = c;
b *= m;
Test_Assumption(b == Point3D(c.x+m(3,0),c.y*m(1,1)+c.z*m(2,1)+m(3,1),c.y*m(1,2)+c.z*m(2,2)+m(3,2)));
Test_Assumption(!a.GetLengthSquared());
f = c.GetLengthSquared();
Test_Assumption(f == c.x*c.x + c.y*c.y + c.z*c.z);
f = c.GetLength();
Test_Assumption(Close_Enough(f,Sqrt(c.x*c.x + c.y*c.y + c.z*c.z)));
b.Normalize(c);
Test_Assumption(b == Point3D(c.x/f, c.y/f, c.z/f));
b.Combine(c,2.0f,d,2.0f);
Test_Assumption(b == Point3D(2.0f*(c.x+d.x),2.0f*(c.y+d.y),2.0f*(c.z+d.z)));
b.Lerp(c,d,0.5f);
Test_Assumption(b == Point3D(0.5f*(c.x+d.x),0.5f*(c.y+d.y),0.5f*(c.z+d.z)));
Vector4D v(2.0f,4.0f,6.0f,2.0f);
b = v;
Test_Assumption(b == Point3D(v.x/v.w, v.y/v.w, v.z/v.w));
Origin3D t;
t.linearPosition = Point3D(2.0f,3.0f,4.0f);
t.angularPosition = EulerAngles(0.0f,0.0f,0.0f);
b = t;
Test_Assumption(b == Point3D(t.linearPosition.x,t.linearPosition.y,t.linearPosition.z));
return true;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -