Returns the instantiated Mesh assigned to the mesh filter.
mesh
property will create a duplicate of it, and this copy
will be returned. Further queries of mesh
property will return this duplicated mesh instance. If you want to avoid this automatic
mesh duplication, use MeshFilter.sharedMesh instead.By using mesh
property you can modify the mesh for a single object only. The
other objects that used the same mesh will not be modified.// Distortionates the mesh vertically. function Update () { // Get instantiated mesh var mesh : Mesh = GetComponent(MeshFilter).mesh; // Randomly change vertices var vertices : Vector3[] = mesh.vertices; for (var p : int = 0; p < vertices.Length; p++) { vertices[p] += Vector3(0, Random.Range(-0.3, 0.3), 0); } mesh.vertices = vertices; mesh.RecalculateNormals(); }
using UnityEngine; using System.Collections; public class Example : MonoBehaviour { void Update() { Mesh mesh = GetComponent<MeshFilter>().mesh; Vector3[] vertices = mesh.vertices; int p = 0; while (p < vertices.Length) { vertices[p] += new Vector3(0, Random.Range(-0.3F, 0.3F), 0); p++; } mesh.vertices = vertices; mesh.RecalculateNormals(); } }
import UnityEngine import System.Collections public class Example(MonoBehaviour): def Update() as void: mesh as Mesh = GetComponent[of MeshFilter]().mesh vertices as (Vector3) = mesh.vertices p as int = 0 while p < vertices.Length: vertices[p] += Vector3(0, Random.Range(-0.3F, 0.3F), 0) p++ mesh.vertices = vertices mesh.RecalculateNormals()