本文整理汇总了C#中Plane.ToString方法的典型用法代码示例。如果您正苦于以下问题:C# Plane.ToString方法的具体用法?C# Plane.ToString怎么用?C# Plane.ToString使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Plane
的用法示例。
在下文中一共展示了Plane.ToString方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ToStringTest
public void ToStringTest()
{
Plane target = new Plane(-12, 3, -18, 1);
{
string expected = "-12x +3y -18z +1 = 0";
string actual = target.ToString();
Assert.AreEqual(expected, actual);
}
{
string expected = "x = +0.25y -1.5z +0.08333334";
string actual = target.ToString('x', CultureInfo.InvariantCulture);
Assert.AreEqual(expected, actual);
}
}
示例2: PlaneToStringTest
public void PlaneToStringTest()
{
Plane target = new Plane(1, 2, 3, 4);
string expected = string.Format(
CultureInfo.CurrentCulture,
"{{Normal:{0:G} D:{1}}}",
target.Normal,
target.D);
Assert.Equal(expected, target.ToString());
}
示例3: PlaneToStringTest
public void PlaneToStringTest()
{
Plane target = new Plane(1.0f, 2.0f, 3.0f, 4.1f);
string expected = "{Normal:{X:1 Y:2 Z:3} D:4.1}";
string actual = target.ToString();
Assert.AreEqual(expected, actual, "Plane.ToString did not return the expected value.");
}
示例4: ConvertQuakeEdTo220
static List<string> ConvertQuakeEdTo220(List<string> lines_in)
{
List<string> lines_out = new List<string>();
// The order of planes here is specifically designed to match up
// with the texture orientation results provided by editors and
// compilers. First -Z and its normal-flipped counterpart, then -X
// and its alternative, and finally -Y.
List<Plane> cardinals = new List<Plane>() {
new Plane("(0 0 0) (1 0 0) (0 -1 0)"), // XY, normal points toward -Z
new Plane("(0 0 0) (1 0 0) (0 -1 0)", true),
new Plane("(0 0 0) (0 1 0) (0 0 -1)"), // YZ, normal points toward -X
new Plane("(0 0 0) (0 1 0) (0 0 -1)", true),
new Plane("(0 0 0) (1 0 0) (0 0 -1)"), // ZX, normal points toward -Y
new Plane("(0 0 0) (1 0 0) (0 0 -1)", true)};
for (int i = 0; i < lines_in.Count; ++i) {
string line_in = Quinstance.Util.StripComment(lines_in[i]);
string trimmed = line_in.Trim();
if (!trimmed.StartsWith("(")) {
if (i > 0 && lines_in[i - 1].Trim().EndsWith("\"worldspawn\""))
lines_out.Add("\"mapversion\" \"220\"");
lines_out.Add(line_in);
continue;
}
string indent = line_in.Substring(0, line_in.IndexOf('('));
Plane p = new Plane(line_in.Substring(line_in.IndexOf('('), line_in.LastIndexOf(')') + 1));
char[] texinfo_delims = { ' ' };
string[] texinfo = line_in.Substring(line_in.LastIndexOf(')') + 1).Split(texinfo_delims, StringSplitOptions.RemoveEmptyEntries);
double smallest_angle = 180.0;
Plane closest_plane = cardinals[0];
foreach (Plane q in cardinals) {
double current_angle = Quin3d.Util.UnsignedAngleBetweenVectors(p.normal, q.normal);
if (current_angle < smallest_angle) {
closest_plane = q;
smallest_angle = current_angle;
}
}
double angle;
Double.TryParse(texinfo[3], out angle);
// TODO: Add something for angle == 0.0!
double cos = Math.Cos(angle * (System.Math.PI / 180.0)),
sin = Math.Sin(angle * (System.Math.PI / 180.0));
Matrix3x3 matrix_x = new Matrix3x3(new double[] { 1.0, 0.0, 0.0,
0.0, cos, -sin,
0.0, sin, cos }),
matrix_y = new Matrix3x3(new double[] { cos, 0.0, sin,
0.0, 1.0, 0.0,
-sin, 0.0, cos }),
matrix_z = new Matrix3x3(new double[] { cos, -sin, 0.0,
sin, cos, 0.0,
0.0, 0.0, 1.0 });
Matrix3x3 matrix = new Matrix3x3();
// Equality checks for doubles, I know, but in this case the
// only possible values of 'closest_plane' will have normals
// with exact coordinates. I hope.
if (closest_plane.normal.x == 1.0 || closest_plane.normal.x == -1.0)
matrix = matrix_x;
else if (closest_plane.normal.y == 1.0 || closest_plane.normal.y == -1.0)
matrix = matrix_y;
else
matrix = matrix_z;
Point3d rot_b = Quin3d.Util.MulMatrix3x3ByPoint3d(matrix, closest_plane.b);
Point3d rot_c = Quin3d.Util.MulMatrix3x3ByPoint3d(matrix, closest_plane.c);
// Each cardinal plane's vectors are assumed to start at 0 0 0,
// which means no need to subtract anything to get the actual
// vectors to use here, just throw in the values.
lines_out.Add(indent + p.ToString() + ' ' + texinfo[0] + ' ' +
rot_b.ToString().Replace('(', '[').Replace(")", "") + texinfo[1] + " ] " +
rot_c.ToString().Replace('(', '[').Replace(")", "") + texinfo[2] + " ] " +
texinfo[3] + ' ' + texinfo[4] + ' ' + texinfo[5]);
}
return lines_out;
}