本文整理汇总了C#中Microsoft.Xna.Framework.Vector3.GetLength方法的典型用法代码示例。如果您正苦于以下问题:C# Vector3.GetLength方法的具体用法?C# Vector3.GetLength怎么用?C# Vector3.GetLength使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Microsoft.Xna.Framework.Vector3
的用法示例。
在下文中一共展示了Vector3.GetLength方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ConvertMeshToVertList
/// <summary>
/// warning: cache thrashes
/// </summary>
/// <param name="mesh"></param>
/// <param name="vertexes"></param>
public static void ConvertMeshToVertList(Vector3[,] mesh, ref VertexPositionTexture[] vertexes)
{
int index = 0;
for (int x = 0; x < mesh.GetLength(0) - 1; x++) {
for (int z = 0; z < mesh.GetLength(1) - 1; z++) {
vertexes[index].Position = mesh[x, z];
vertexes[index + 1].Position = mesh[x, z + 1];
vertexes[index + 2].Position = mesh[x + 1, z + 1];
vertexes[index + 3].Position = mesh[x + 1, z];
index += 4;
}
}
}
示例2: ConvertMeshToVertList
public static void ConvertMeshToVertList(Vector3[,] mesh, Vector3[,] normals, ref VertexPositionNormalTexture[] verticies)
{
//convert from 2d array to 1d
int index = 0;
for (int x = 0; x < mesh.GetLength(0) - 1; x++){
for (int z = 0; z < mesh.GetLength(1) - 1; z++){
verticies[index].Position = mesh[x, z];
verticies[index].Normal = normals[x, z];
verticies[index + 1].Position = mesh[x, z + 1];
verticies[index + 1].Normal = normals[x, z + 1];
verticies[index + 2].Position = mesh[x + 1, z + 1];
verticies[index + 2].Normal = normals[x + 1, z + 1];
verticies[index + 3].Position = mesh[x + 1, z];
verticies[index + 3].Normal = normals[x + 1, z];
index += 4;
}
}
}
示例3: GenerateMeshNormals
public static Vector3[,] GenerateMeshNormals(Vector3[,] mesh)
{
var normals = new Vector3[mesh.GetLength(0), mesh.GetLength(1)];
for (int vertX = 0; vertX < mesh.GetLength(0) - 1; vertX++) {
for (int vertZ = 0; vertZ < mesh.GetLength(1) - 1; vertZ++) {
var crossSum = new Vector3();
var s1 = mesh[vertX + 1, vertZ] - mesh[vertX, vertZ];
var s2 = mesh[vertX, vertZ + 1] - mesh[vertX, vertZ];
var s3 = mesh[vertX + 1, vertZ + 1] - mesh[vertX, vertZ];
crossSum += Vector3.Cross(s1, s3);
crossSum += Vector3.Cross(s3, s2);
normals[vertX, vertZ] += crossSum;
if (crossSum != Vector3.Zero) {
normals[vertX, vertZ].Normalize();
}
}
}
for (int vertX = 1; vertX < mesh.GetLength(0); vertX++) {
for (int vertZ = 1; vertZ < mesh.GetLength(1); vertZ++) {
var crossSum = new Vector3();
var s1 = mesh[vertX - 1, vertZ] - mesh[vertX, vertZ];
var s2 = mesh[vertX, vertZ - 1] - mesh[vertX, vertZ];
var s3 = mesh[vertX - 1, vertZ - 1] - mesh[vertX, vertZ];
crossSum += Vector3.Cross(s1, s3);
crossSum += Vector3.Cross(s3, s2);
normals[vertX, vertZ] += crossSum;
normals[vertX, vertZ].Normalize();
}
}
return normals;
}