本文整理汇总了C#中MeshData类的典型用法代码示例。如果您正苦于以下问题:C# MeshData类的具体用法?C# MeshData怎么用?C# MeshData使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
MeshData类属于命名空间,在下文中一共展示了MeshData类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: AddMesh
public bool AddMesh(GameObject go)
{
if (_lut.ContainsKey(go.GetInstanceID())) {
return true;
}
// returns false if renderer is not available
if (go.GetComponent<Renderer>() == null) {
return false;
}
// returns false if not a mesh
MeshFilter mf = (MeshFilter)go.GetComponent (typeof(MeshFilter));
if (mf == null) {
return false;
}
MeshData md = new MeshData ();
md._instID = go.GetInstanceID ();
md._vertCount = mf.mesh.vertexCount;
md._triCount = mf.mesh.triangles.Length / 3;
md._materialCount = go.GetComponent<Renderer>().sharedMaterials.Length;
md._boundSize = go.GetComponent<Renderer>().bounds.size.magnitude;
_lut.Add (md._instID, md);
return true;
}
示例2: Update
//Update is called once per frame
void Update()
{
if (update) {
//HasUpdatedLights = false;
if (!IsUpdating) {
if (!CanUpdateRenderer) {
IsUpdating = true;
MyMeshData = new MeshData();
MyWaterMeshData = new MeshData();
if (IsUpdateOnThread) {
UnityThreading.ActionThread NewThread = UnityThreadHelper.CreateThread(() =>
{
// thread processing
UpdateChunk();
CanUpdateRenderer = true;
});
} else {
UpdateChunk();
CanUpdateRenderer = true;
}
}
} else {
if (CanUpdateRenderer) {
UpdateRender();
update = false;
IsUpdating = false;
CanUpdateRenderer = false;
}
}
}
//if (HasUpdatedLights) {
//UpdateChunkLightsOnly();
// HasUpdatedLights = false;
//}
}
示例3: GenerateTerrainMesh
public static MeshData GenerateTerrainMesh(float[,] heightMap, float heightMultiplier, AnimationCurve _heightCurve, int levelOfDetail) {
AnimationCurve heightCurve = new AnimationCurve (_heightCurve.keys);
int width = heightMap.GetLength (0);
int height = heightMap.GetLength (1);
float topLeftX = (width - 1) / -2f;
float topLeftZ = (height - 1) / 2f;
int meshSimplificationIncrement = (levelOfDetail == 0)?1:levelOfDetail * 2;
int verticesPerLine = (width - 1) / meshSimplificationIncrement + 1;
MeshData meshData = new MeshData (verticesPerLine, verticesPerLine);
int vertexIndex = 0;
for (int y = 0; y < height; y += meshSimplificationIncrement) {
for (int x = 0; x < width; x += meshSimplificationIncrement) {
meshData.vertices [vertexIndex] = new Vector3 (topLeftX + x, heightCurve.Evaluate (heightMap [x, y]) * heightMultiplier, topLeftZ - y);
meshData.uvs [vertexIndex] = new Vector2 (x / (float)width, y / (float)height);
if (x < width - 1 && y < height - 1) {
meshData.AddTriangle (vertexIndex, vertexIndex + verticesPerLine + 1, vertexIndex + verticesPerLine);
meshData.AddTriangle (vertexIndex + verticesPerLine + 1, vertexIndex, vertexIndex + 1);
}
vertexIndex++;
}
}
return meshData;
}
示例4: Blockdata
public virtual MeshData Blockdata(Chunk chunk, int x, int y, int z, MeshData meshData)
{
if (!chunk.GetBlock(x, y + 1, z).IsSolid(Direction.down))
{
meshData = FaceDataUp(chunk, x, y, z, meshData);
}
if (!chunk.GetBlock(x, y - 1, z).IsSolid(Direction.up))
{
meshData = FaceDataDown(chunk, x, y, z, meshData);
}
if (!chunk.GetBlock(x, y, z + 1).IsSolid(Direction.south))
{
meshData = FaceDataNorth(chunk, x, y, z, meshData);
}
if (!chunk.GetBlock(x, y, z - 1).IsSolid(Direction.north))
{
meshData = FaceDataSouth(chunk, x, y, z, meshData);
}
if (!chunk.GetBlock(x + 1, y, z).IsSolid(Direction.west))
{
meshData = FaceDataEast(chunk, x, y, z, meshData);
}
if (!chunk.GetBlock(x - 1, y, z).IsSolid(Direction.east))
{
meshData = FaceDataWest(chunk, x, y, z, meshData);
}
return meshData;
}
示例5: BuildRenderer
public static void BuildRenderer(Chunk chunk, BlockPos pos, MeshData meshData, Direction direction, Vector3 ModelSize, Vector3 ConnMeshSizeX, Vector3 ConnMeshSizeY, Vector3 ConnMeshSizeZ, Direction[] Dir)
{
MakeStickFace(chunk, pos, meshData, direction, false, ModelSize);
Debug.Log(Dir.Length);
if (Dir.Length > 0)
MakeFenceFace(chunk, pos, meshData, direction, false, ModelSize, ConnMeshSizeX, ConnMeshSizeY, ConnMeshSizeZ, Dir);
}
示例6: GenerateTerrainMesh
public static MeshData GenerateTerrainMesh(float[,] heightMap) {
int width = heightMap.GetLength (0);
int height = heightMap.GetLength (1);
float topLeftX = (width - 1) / -2f;
float topLeftZ = (height - 1) / 2f;
MeshData meshData = new MeshData (width, height);
int vertexIndex = 0;
for (int y = 0; y < height; y++) {
for (int x = 0; x < width; x++) {
meshData.vertices [vertexIndex] = new Vector3 (topLeftX + x, heightMap [x, y], topLeftZ - y);
meshData.uvs [vertexIndex] = new Vector2 (x / (float)width, y / (float)height);
if (x < width - 1 && y < height - 1) {
meshData.AddTriangle (vertexIndex, vertexIndex + width + 1, vertexIndex + width);
meshData.AddTriangle (vertexIndex + width + 1, vertexIndex, vertexIndex + 1);
}
vertexIndex++;
}
}
return meshData;
}
示例7: Blockdata
public virtual MeshData Blockdata(Chunk chunk, int x, int y, int z, MeshData meshData)
{
// Check if block on top has a solid down face
if (!chunk.GetBlock(x, y + 1, z).IsSolid(Direction.down)) {
meshData = FaceDataUp(chunk, x, y, z, meshData);
}
// Check if the block below has a solid up face
if (!chunk.GetBlock(x, y - 1, z).IsSolid(Direction.up)) {
meshData = FaceDataDown(chunk, x, y, z, meshData);
}
// Check if the block north has a solid south face
if (!chunk.GetBlock(x, y, z + 1).IsSolid(Direction.south)) {
meshData = FaceDataNorth(chunk, x, y, z, meshData);
}
// Check if the block south has a solid north face
if (!chunk.GetBlock(x, y, z - 1).IsSolid(Direction.north)) {
meshData = FaceDataSouth(chunk, x, y, z, meshData);
}
// Check if the block east has a solid west face
if (!chunk.GetBlock(x + 1, y, z).IsSolid(Direction.west)) {
meshData = FaceDataEast(chunk, x, y, z, meshData);
}
// Check if the block west has a solid east face
if (!chunk.GetBlock(x - 1, y, z).IsSolid(Direction.east)) {
meshData = FaceDataWest(chunk, x, y, z, meshData);
}
return meshData;
}
示例8: AddBounds
public void AddBounds(Bounds bounds, Color color)
{
MeshData meshData = null;
for (int i = 0; i < datas.Count; ++i)
{
if (datas[i].vertexCount >= vertexBuffSize) continue;
else meshData = datas[i];
}
if (meshData == null)
{
meshData = new MeshData();
datas.Add(meshData);
}
Vector3 min = bounds.min;
Vector3 max = bounds.max;
meshData.vertices[meshData.vertexCount + 0] = min;
meshData.vertices[meshData.vertexCount + 1].Set(min.x, min.y, max.z);
meshData.vertices[meshData.vertexCount + 2].Set(min.x, max.y, min.z);
meshData.vertices[meshData.vertexCount + 3].Set(min.x, max.y, max.z);
meshData.vertices[meshData.vertexCount + 4].Set(max.x, min.y, min.z);
meshData.vertices[meshData.vertexCount + 5].Set(max.x, min.y, max.z);
meshData.vertices[meshData.vertexCount + 6].Set(max.x, max.y, min.z);
meshData.vertices[meshData.vertexCount + 7] = max;
for (int i = 0; i < 8; ++i) meshData.colors[meshData.vertexCount + i] = color;
for (int i = 0; i < 24; ++i) meshData.indices[meshData.vertexCount * 3 + i] = gWireFrameIndex[i] + meshData.vertexCount;
meshData.vertexCount += 8;
}
示例9: blockData
public override MeshData blockData(Chunk chunk, int x, int y, int z, MeshData meshData)
{
meshData.useRenderDataForCol = false;
if (!chunk.getBlock (x, y + 1, z).isSolid (Direction.up)) {
meshData = FaceDataUp (chunk, x, y, z, meshData);
}
if (!chunk.getBlock (x, y - 1, z).isSolid (Direction.down)) {
meshData = FaceDataDown (chunk, x, y, z, meshData);
}
if (!chunk.getBlock (x, y, z + 1).isSolid (Direction.north)) {
meshData = FaceDataNorth (chunk, x, y, z, meshData);
}
if (!chunk.getBlock (x, y, z - 1).isSolid (Direction.south)) {
meshData = FaceDataSouth (chunk, x, y, z, meshData);
}
if (!chunk.getBlock (x + 1, y, z).isSolid (Direction.east)) {
meshData = FaceDataEast (chunk, x, y, z, meshData);
}
if (!chunk.getBlock (x - 1, y, z).isSolid (Direction.west)) {
meshData = FaceDataWest (chunk, x, y, z, meshData);
}
return meshData;
}
示例10: AddQuadFlatBlend
public virtual MeshData AddQuadFlatBlend( Vector3[] points, MeshData meshData)
{
//Takes 4 points, calculates two normals for two faces
//Adds the points and triangles to the mesh
Vector3 flatnorm1 = new Vector3();
flatnorm1 = Vector3.Cross (points [1] - points [0], points [3] - points [0]);
Vector3 flatnorm2 = new Vector3();
flatnorm2 = Vector3.Cross (points [3] - points [2], points [1] - points [2]);
//set the vertices
meshData.AddVertex(points [0], flatnorm1);
meshData.AddVertex(points [1], flatnorm1);
meshData.AddVertex(points [3], flatnorm1);
meshData.AddBlendTriangle ();
meshData.AddVertex(points [1], flatnorm2);
meshData.AddVertex(points [2], flatnorm2);
meshData.AddVertex(points [3], flatnorm2);
meshData.AddBlendTriangle ();
Color32[] vcolors = new Color32[6];
vcolors [2] = Color.clear;
vcolors [4] = Color.clear;
vcolors [5] = Color.clear;
vcolors [0] = Color.white;
vcolors [1] = Color.white;
vcolors [3] = Color.white;
meshData.colors.AddRange (vcolors);
return meshData;
}
示例11: GenerateTerrainMesh
public static MeshData GenerateTerrainMesh(float[,] heightMap, float heightMultiplier, AnimationCurve _heightCurve, int levelOfDetail) {
AnimationCurve heightCurve = new AnimationCurve (_heightCurve.keys);
int meshSimplificationIncrement = (levelOfDetail == 0)?1:levelOfDetail * 2;
int borderedSize = heightMap.GetLength (0);
int meshSize = borderedSize - 2*meshSimplificationIncrement;
int meshSizeUnsimplified = borderedSize - 2;
float topLeftX = (meshSizeUnsimplified - 1) / -2f;
float topLeftZ = (meshSizeUnsimplified - 1) / 2f;
int verticesPerLine = (meshSize - 1) / meshSimplificationIncrement + 1;
MeshData meshData = new MeshData (verticesPerLine);
int[,] vertexIndicesMap = new int[borderedSize,borderedSize];
int meshVertexIndex = 0;
int borderVertexIndex = -1;
for (int y = 0; y < borderedSize; y += meshSimplificationIncrement) {
for (int x = 0; x < borderedSize; x += meshSimplificationIncrement) {
bool isBorderVertex = y == 0 || y == borderedSize - 1 || x == 0 || x == borderedSize - 1;
if (isBorderVertex) {
vertexIndicesMap [x, y] = borderVertexIndex;
borderVertexIndex--;
} else {
vertexIndicesMap [x, y] = meshVertexIndex;
meshVertexIndex++;
}
}
}
for (int y = 0; y < borderedSize; y += meshSimplificationIncrement) {
for (int x = 0; x < borderedSize; x += meshSimplificationIncrement) {
int vertexIndex = vertexIndicesMap [x, y];
Vector2 percent = new Vector2 ((x-meshSimplificationIncrement) / (float)meshSize, (y-meshSimplificationIncrement) / (float)meshSize);
float height = heightCurve.Evaluate (heightMap [x, y]) * heightMultiplier;
Vector3 vertexPosition = new Vector3 (topLeftX + percent.x * meshSizeUnsimplified, height, topLeftZ - percent.y * meshSizeUnsimplified);
meshData.AddVertex (vertexPosition, percent, vertexIndex);
if (x < borderedSize - 1 && y < borderedSize - 1) {
int a = vertexIndicesMap [x, y];
int b = vertexIndicesMap [x + meshSimplificationIncrement, y];
int c = vertexIndicesMap [x, y + meshSimplificationIncrement];
int d = vertexIndicesMap [x + meshSimplificationIncrement, y + meshSimplificationIncrement];
meshData.AddTriangle (a,d,c);
meshData.AddTriangle (d,a,b);
}
vertexIndex++;
}
}
return meshData;
}
示例12: getBeamMesh
public virtual MeshData getBeamMesh(Vector3 start, Vector3 end, float width, MeshData meshData)
{
Vector3[] points = new Vector3[3];
Vector2[] UVs = new Vector2[3];
Vector3 tip = end - start;
float mag = tip.magnitude;
Vector3 perp = new Vector3 (-tip.y, tip.x, tip.z) / mag;
Vector3 base1 = (perp * width/4) + tip/mag;
Vector3 base2 = (perp * -width/4) + tip/mag;
//Vector3 base3 = Quaternion.Euler(300, 0, 0) * perp;
UVs [2] = new Vector2 (0.0f, Math.Min (0.4f+width,1.0f));
UVs [1] = new Vector2 (0.0f, Math.Max (0.6f-width,0.0f));
UVs [0] = new Vector2 (0.1f, 0.5f);
meshData.AddVertex(Vector3.zero);
meshData.AddVertex(base1);
meshData.AddVertex(base2);
meshData.AddTriangle();
meshData.uv.AddRange(UVs);
UVs [1] = new Vector2 (0.0f, Math.Min (0.4f+width,1.0f));
UVs [2] = new Vector2 (0.0f, Math.Max (0.6f-width,0.0f));
UVs [0] = new Vector2 (0.1f, 0.5f);
meshData.AddVertex(tip);
meshData.AddVertex(base2);
meshData.AddVertex(base1);
meshData.AddTriangle();
meshData.uv.AddRange(UVs);
return meshData;
}
示例13: DrawMesh
public void DrawMesh(MeshData meshData, Texture2D texture)
{
// Mesh filter is used to proceduraly change mesh
// It allow us to get to the mesh components
meshFilter.sharedMesh = meshData.GenerateMesh();
meshRenderer.sharedMaterial.mainTexture = texture;
}
示例14: AddTypeElement
public bool AddTypeElement(System.Xml.Linq.XElement elemtype)
{
XAttribute fileAtt = elemtype.Attribute("file");
if (fileAtt == null)
{
//Add error message here
return false;
}
string filePath = Path.Combine(Path.GetDirectoryName(new Uri(elemtype.BaseUri).LocalPath), fileAtt.Value);
filePath = Path.GetFullPath(filePath);
// Load the OBJ in
var lStream = new FileStream(filePath, FileMode.Open);
var lOBJData = OBJLoader.LoadOBJ(lStream);
lStream.Close();
meshData = new MeshData[(int)MeshLayer.Count];
Mesh tempMesh = new Mesh();
for (int i = 0; i < meshData.Length; i++)
{
tempMesh.LoadOBJ(lOBJData, ((MeshLayer)i).ToString());
meshData[i] = new MeshData(tempMesh);
tempMesh.Clear();
}
lStream = null;
lOBJData = null;
return true;
}
示例15: AddCircularPlane
public static void AddCircularPlane(float radius, int rings, int segments, Vector3 axis, MeshData meshData)
{
var vertices = meshData.Vertices;
var triangles = meshData.Triangles;
float radiusScalar = radius / rings;
var ringPoints = Enumerable.Range(1, rings).Select(i => GetCircleOfPoints(i * radiusScalar, segments, axis)).ToArray();
int startingIndex = vertices.Count;
vertices.Add(Vector3.zero);
//add points to vertex list
foreach (var circle in ringPoints) foreach (var point in circle) vertices.Add(point);
//Add triangles from center point to the first ring
for (int i = 2; i <= segments; i++)
{
triangles.AddRange(new int[] { startingIndex, startingIndex + i - 1, startingIndex + i });
}
//Add the last triangle
triangles.AddRange(new int[] { startingIndex, startingIndex + segments, startingIndex + 1 });
//Now add the rest of the rings
for(int r=1;r<rings;r++)
{
int ringIndex = r * segments + 1 + startingIndex;
int prevRingIndex = (r - 1) * segments + 1 + startingIndex;
for(int s=1;s<segments;s++)
{
triangles.AddRange(new int[]
{
ringIndex + s - 1,
ringIndex + s,
prevRingIndex + s - 1
});
triangles.AddRange(new int[]
{
prevRingIndex + s - 1,
ringIndex + s,
prevRingIndex + s
});
}
//Add final quad
triangles.AddRange(new int[]
{
ringIndex + segments-1,
ringIndex + 0,
prevRingIndex + segments-1
});
triangles.AddRange(new int[]
{
prevRingIndex + segments-1,
ringIndex + 0,
prevRingIndex + 0
});
}
}