當前位置: 首頁>>代碼示例>>C#>>正文


C# Mesh.SetIndices方法代碼示例

本文整理匯總了C#中UnityEngine.Mesh.SetIndices方法的典型用法代碼示例。如果您正苦於以下問題:C# Mesh.SetIndices方法的具體用法?C# Mesh.SetIndices怎麽用?C# Mesh.SetIndices使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在UnityEngine.Mesh的用法示例。


在下文中一共展示了Mesh.SetIndices方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: CreateOverlayMesh

		/**
		 *	Creates a new mesh using only the @src positions, normals, and a new color array.
		 */
		public static Mesh CreateOverlayMesh(Mesh src)
		{
			Mesh m = new Mesh();
			m.name = "Overlay Mesh: " + src.name;
			m.vertices = src.vertices;
			m.normals = src.normals;
			m.colors = z_Util.Fill<Color>(new Color(0f, 0f, 0f, 0f), m.vertexCount);
			m.subMeshCount = src.subMeshCount;
			for(int i = 0; i < src.subMeshCount; i++)
			{
				if(src.GetTopology(i) == MeshTopology.Triangles)
				{
					int[] tris = src.GetIndices(i);
					int[] lines = new int[tris.Length * 2];
					int index = 0;
					for(int n = 0; n < tris.Length; n+=3)
					{
						lines[index++] = tris[n+0];
						lines[index++] = tris[n+1];
						lines[index++] = tris[n+1];
						lines[index++] = tris[n+2];
						lines[index++] = tris[n+2];
						lines[index++] = tris[n+0];
					}
					m.SetIndices(lines, MeshTopology.Lines, i);
				}
				else
				{
					m.SetIndices(src.GetIndices(i), src.GetTopology(i), i);
				}
			}
			return m;
		}
開發者ID:alex-carlson,項目名稱:PixelitisGGJ,代碼行數:36,代碼來源:z_MeshUtility.cs

示例2: InitializeSharedMesh

    static void InitializeSharedMesh()
    {
        sharedMesh = new Mesh ();
        sharedMesh.subMeshCount = 2;

        var vertices = new Vector3 [4 * 6];

        vertices [0] = new Vector3 (-1, +1, -1);
        vertices [1] = new Vector3 (+1, +1, -1);
        vertices [2] = new Vector3 (+1, -1, -1);
        vertices [3] = new Vector3 (-1, -1, -1);

        vertices [4] = new Vector3 (+1, +1, -1);
        vertices [5] = new Vector3 (+1, +1, +1);
        vertices [6] = new Vector3 (+1, -1, +1);
        vertices [7] = new Vector3 (+1, -1, -1);

        vertices [8] = new Vector3 (+1, +1, +1);
        vertices [9] = new Vector3 (-1, +1, +1);
        vertices [10] = new Vector3 (-1, -1, +1);
        vertices [11] = new Vector3 (+1, -1, +1);

        vertices [12] = new Vector3 (-1, +1, +1);
        vertices [13] = new Vector3 (-1, +1, -1);
        vertices [14] = new Vector3 (-1, -1, -1);
        vertices [15] = new Vector3 (-1, -1, +1);

        vertices [16] = new Vector3 (-1, +1, +1);
        vertices [17] = new Vector3 (+1, +1, +1);
        vertices [18] = new Vector3 (+1, +1, -1);
        vertices [19] = new Vector3 (-1, +1, -1);

        vertices [20] = new Vector3 (-1, -1, -1);
        vertices [21] = new Vector3 (+1, -1, -1);
        vertices [22] = new Vector3 (+1, -1, +1);
        vertices [23] = new Vector3 (-1, -1, +1);

        sharedMesh.vertices = vertices;

        var indices = new int[vertices.Length];
        for (var i = 0; i < indices.Length; i++) {
            indices [i] = i;
        }
        sharedMesh.SetIndices (indices, MeshTopology.Quads, 0);

        sharedMesh.Optimize ();
        sharedMesh.RecalculateNormals ();

        indices = new int[4 * 3 * 2];
        var offs = 0;
        for (var i1 = 0; i1 < 16; i1 += 4) {
            for (var i2 = i1; i2 < i1 + 3; i2++) {
                indices [offs++] = i2;
                indices [offs++] = i2 + 1;
            }
        }
        sharedMesh.SetIndices (indices, MeshTopology.Lines, 1);
    }
開發者ID:keijiro,項目名稱:VJ01,代碼行數:58,代碼來源:WireSolidMeshBuilder.cs

示例3: Start

	// Use this for initialization
	void Start () 
	{
		CreateLineMaterial();
		
		mesh = new Mesh();
		Vertex2[] vertices = new Vertex2[NumberOfVertices];
		Vector3[] meshVerts = new Vector3[NumberOfVertices];
		int[] indices = new int[NumberOfVertices];
		
		Random.seed = 0;
		for (var i = 0; i < NumberOfVertices; i++)
		{
			vertices[i] = new Vertex2(size * Random.Range(-1.0f, 1.0f), size * Random.Range(-1.0f, 1.0f));
			meshVerts[i] = vertices[i].ToVector3();
			indices[i] = i;
		}
		
		mesh.vertices = meshVerts;
		mesh.SetIndices(indices, MeshTopology.Points, 0);
		//mesh.bounds = new Bounds(Vector3.zero, new Vector3((float)size,(float)size,(float)size));
		
		float now = Time.realtimeSinceStartup;
		voronoiMesh = VoronoiMesh.Create<Vertex2, Cell2>(vertices);
		float interval = Time.realtimeSinceStartup - now;

		Debug.Log("time = " + interval * 1000.0f);
		
	}
開發者ID:fecca,項目名稱:Code,代碼行數:29,代碼來源:ExampleDelaunayAndVoronoi2D.cs

示例4: Start

	// Use this for initialization
	void Start () 
	{
		CreateLineMaterial();

		mesh = new Mesh();
		Vertex2[] vertices = new Vertex2[NumberOfVertices];
		Vector3[] meshVerts = new Vector3[NumberOfVertices];
		int[] indices = new int[NumberOfVertices];

		Random.seed = 0;
		for (var i = 0; i < NumberOfVertices; i++)
		{
			vertices[i] = new Vertex2(size * Random.Range(-1.0f, 1.0f), size * Random.Range(-1.0f, 1.0f));
			meshVerts[i] = vertices[i].ToVector3();
			indices[i] = i;
		}

		mesh.vertices = meshVerts;
		mesh.SetIndices(indices, MeshTopology.Points, 0);
		//mesh.bounds = new Bounds(Vector3.zero, new Vector3((float)size,(float)size,(float)size));

		float now = Time.realtimeSinceStartup;
		ConvexHull<Vertex2, Face2> convexHull = ConvexHull.Create<Vertex2, Face2>(vertices);
		float interval = Time.realtimeSinceStartup - now;

		convexHullVertices = new List<Vertex2>(convexHull.Points);
		convexHullFaces = new List<Face2>(convexHull.Faces);

		Debug.Log("Out of the " + NumberOfVertices + " vertices, there are " + convexHullVertices.Count + " verts on the convex hull.");
		Debug.Log("time = " + interval * 1000.0f + " ms");

	}
開發者ID:fecca,項目名稱:Code,代碼行數:33,代碼來源:ExampleConvexHull2D.cs

示例5: UpdateLineMesh

    public static void UpdateLineMesh(OpticalFlowWorker.AsyncResult r, Mesh mesh, CvPoint2D32f[] velocities, float limitVelocity)
    {
        var vertices = new Vector3[r.nCorners * 2];
        var colors = new Color[vertices.Length];
        var indices = new int[vertices.Length];
        var limitSqrVelocity = limitVelocity * limitVelocity;
        var c0s = r.corners0;
        var rTexelSize = new Vector2(1f / r.imageWidth, 1f / r.imageHeight);
        for (var i = 0; i < r.nCorners; i++) {
            var vertexIndex = 2 * i;
            var c0 = c0s[i];
            var v0 = new Vector3(c0.X * rTexelSize.x - 0.5f,  -(c0.Y * rTexelSize.y - 0.5f), 0f);

            var cv = velocities[i];
            var v = new Vector3(cv.X * rTexelSize.x, cv.Y * rTexelSize.y, 0f);
            var rad = Mathf.Atan2(v.y, v.x);
            if (rad < 0)
                rad += 2 * Mathf.PI;
            var color = HSBColor.ToColor(new HSBColor(rad * R_TWO_PI, 1f, 1f));

            if (limitSqrVelocity < v.sqrMagnitude)
                v = Vector3.zero;
            vertices[vertexIndex] = v0;
            vertices[vertexIndex + 1] = v0 + v;
            colors[vertexIndex] = color;
            colors[vertexIndex + 1] = color;
            indices[vertexIndex] = vertexIndex;
            indices[vertexIndex + 1] = vertexIndex + 1;
        }
        mesh.vertices = vertices;
        mesh.colors = colors;
        mesh.SetIndices(indices, MeshTopology.Lines, 0);
        mesh.RecalculateBounds();
    }
開發者ID:nobnak,項目名稱:OpenCvSharpForUnity,代碼行數:34,代碼來源:FlowUtil.cs

示例6: Generate

    private Mesh Generate()
    {
        Debug.Assert(starCount < 65536, "Number of stars must less than 65536");

        var random = new System.Random(seed);

        var mesh = new Mesh();
        var vertices = new Vector3[starCount];
        var indices = new int[starCount];
        var colors = new Color[starCount];

        for (var i = 0; i < starCount; ++i)
        {
            vertices[i] = random.OnUnitSphere();

            indices[i] = i;

            colors[i] = starColors[random.Next(starColors.Length)];
            colors[i].a = (0.2f + 0.8f * MathUtils.NextFloat(random)) * (1 - (Mathf.Abs(vertices[i].y)));
        }

        mesh.vertices = vertices;
        mesh.colors = colors;
        mesh.SetIndices(indices, MeshTopology.Points, 0);

        return mesh;
    }
開發者ID:spriest487,項目名稱:spacetrader-unity,代碼行數:27,代碼來源:StarfieldMeshGenerator.cs

示例7: CreateLineCircle

    public static void CreateLineCircle()
    {
        Mesh mesh = new Mesh();
        Vector3[] vertices = new Vector3[33];
        Vector2[] uv = new Vector2[33];
        int[] indices = new int[33];

        for(int i = 0; i < 33; i++){
            float fi = (float)i;
            vertices[i] = new Vector3(Mathf.Sin(fi/32f * 2f * Mathf.PI), Mathf.Cos(fi/32f * 2f * Mathf.PI), 0) * 0.5f;
            uv[i] = new Vector2(fi/32f, 0);
            indices[i] = i;
        }

        mesh.vertices = vertices;
        mesh.normals = vertices;
        mesh.uv = uv;
        mesh.SetIndices(indices, MeshTopology.LineStrip, 0);

        string path = GetCurrentPath() + "LineCircle.asset";
        AssetDatabase.CreateAsset(mesh, path);
        AssetDatabase.SaveAssets();
        AssetDatabase.Refresh();

        Selection.activeObject = AssetDatabase.LoadAssetAtPath(path, typeof(Mesh));
    }
開發者ID:sugi-cho,項目名稱:UnityGraphicsPrograming,代碼行數:26,代碼來源:CreateMesh.cs

示例8: Awake

    void Awake()
    {
        var vertices = new Vector3[(width + 1) * 2 + (height + 1) * 2];
        var offs = 0;

        for (var h = 0; h <= height; h++) {
            vertices [offs++] = new Vector3 (0, h, 0);
            vertices [offs++] = new Vector3 (width, h, 0);
        }

        for (var w = 0; w <= width; w++) {
            vertices [offs++] = new Vector3 (w, 0, 0);
            vertices [offs++] = new Vector3 (w, height, 0);
        }

        var indices = new int[(width + 1) * 2 + (height + 1) * 2];

        for (var i = 0; i < offs; i++) {
            indices [i] = i;
        }

        var mesh = new Mesh ();
        mesh.vertices = vertices;
        mesh.SetIndices (indices, MeshTopology.Lines, 0);

        GetComponent<MeshFilter> ().mesh = mesh;
    }
開發者ID:Jashengmato,項目名稱:unity-leapmotion-testbed,代碼行數:27,代碼來源:GridBuilder.cs

示例9: make_wireframecircle

    void make_wireframecircle()
    {
        GameObject go = new GameObject ();
        go.name = "wireframeCircle";
        go.transform.localPosition = new Vector3 (10, 0, 20);

        MeshFilter mf = go.AddComponent<MeshFilter> ();
        go.AddComponent<MeshRenderer> ();

        int[] line_indices = new int[stepCount * 2];
        Vector3[] vertices = new Vector3[stepCount];

        Vector3 mid = new Vector3(0, 0, 0);
        for (int i = 0; i < stepCount; i++)
        {
            vertices[i] = new Vector3(go.transform.localPosition.x + radius * Mathf.Cos((360.0f / stepCount) * i * 3.14f / 180.0f), go.transform.localPosition.y + radius * Mathf.Sin((360.0f / stepCount) * i * 3.14f / 180.0f), 0);
            line_indices[i * 2] = i;
            if (i == stepCount - 1)
                line_indices[i * 2 + 1] = 0;
            else
                line_indices[i * 2 + 1] = i + 1;
        }

        Mesh mesh = new Mesh ();
        mesh.vertices = vertices;
        mesh.SetIndices (line_indices, MeshTopology.Lines, 0);
        mf.mesh = mesh;
    }
開發者ID:JeanPascalEvette,項目名稱:unity_triangle_example,代碼行數:28,代碼來源:Circle.cs

示例10: BuildMesh

    void BuildMesh(ref Mesh mesh, Vector3[] verts, Vector2[] uvs, int[] tris, Color[] colors, Vector3[] normals, int meshCount, bool readRGB, bool readIntensity, bool readNormals, int vertexCount)
    {
        mesh.subMeshCount = 1;

        Vector3[] v = new Vector3[vertexCount];
        Vector2[] uv = new Vector2[vertexCount];
        Array.Copy(verts, v, vertexCount);
        Array.Copy(uvs, uv, vertexCount);
        mesh.vertices = v;
        mesh.uv = uv;

        if (readRGB || readIntensity)
        {
            Color[] clr = new Color[vertexCount];
            Array.Copy(colors, clr, vertexCount);
            mesh.colors = clr;
        }

        if (readNormals)
        {
            Vector3[] n = new Vector3[vertexCount];
            Array.Copy(normals, n, vertexCount);
            mesh.normals = n;
        }

        int[] indices = new int[vertexCount];
        Array.Copy(tris, indices, vertexCount);
        //mesh.SetTriangles(triangles, 0);
        mesh.SetIndices(indices, MeshTopology.Quads, 0);
    }
開發者ID:ruben-farrus,項目名稱:the-airport-prototype,代碼行數:30,代碼來源:MeshConverter.cs

示例11: AddFace

        private void AddFace(WaterFace face)
        {
            // TODO
            if ((face.Flags & WaterFlags.Visible) != WaterFlags.Visible) return;

            var obj = Instantiate(WaterPrefab);
            obj.transform.SetParent(transform);
            var mid = obj.transform.position = face.Vertices.Aggregate(Vector3.zero,
                (s, x) => s + x.Position) / face.Vertices.Length;

            obj.name = string.Format("WaterFace ({0})", mid);

            var mesh = new Mesh();

            mesh.vertices = face.Vertices.Select(x => x.Position - mid).ToArray();
            mesh.normals = face.Vertices.Select(x => Vector3.up).ToArray();

            var indices = new int[(face.Vertices.Length - 2) * 3];
            for (var i = 0; i < face.Vertices.Length - 2; ++i) {
                var flip = i & 1;
                indices[i * 3 + 0] = i + 1 - flip;
                indices[i * 3 + 1] = i + 0 + flip;
                indices[i * 3 + 2] = i + 2;
            }

            mesh.SetIndices(indices, MeshTopology.Triangles, 0);

            obj.GetComponent<MeshFilter>().sharedMesh = mesh;
        }
開發者ID:katalist5296,項目名稱:SanAndreasUnity,代碼行數:29,代碼來源:Water.cs

示例12: Start

    // Use this for initialization
    void Start()
    {
        var meshMarkers = transform.FindChild("MeshMarkers");
          Transform firstChild = null;
          var meshFilter = gameObject.AddComponent<MeshFilter>();
        Mesh m = new Mesh();
          var vertices = new List<Vector3>();
          var normals = new List<Vector3>();
        foreach (Transform child in meshMarkers) {
        if (!firstChild) { firstChild = child;}
          vertices.Add(child.position);
          normals.Add(new Vector3(0,0,-1));
          }
        m.SetVertices(vertices);

          var indices = new List<int>();

          for (int i = 0; i < vertices.Count -2; i++) {
          indices.Add(i);
          indices.Add(i+1);
          indices.Add(i+2);
          }

        m.SetIndices(indices.ToArray(), MeshTopology.Triangles, 0);
        m.SetNormals(normals);

          meshFilter.mesh = m;

        var pathmarkers = transform.FindChild("PathMarkers");
        var tp = from Transform path in pathmarkers select path.position;
        var tr = from Transform path in pathmarkers select path.GetComponent<Renderer>();
          foreach (var renderer1 in tr) {
        renderer1.sortingLayerName = "Middle";
          renderer1.material.color = Color.blue;

        }
        //tracePosList = Curver.MakeSmoothCurve(tp.ToArray(), 6);
        tracePosList = tp.ToArray();

        GetComponent<MeshRenderer>().sortingLayerName = "Background";

        line = new GameObject().AddComponent<LineRenderer>();
        line.transform.parent = transform;
        line.SetWidth(0.5f,0.5f);
          line.material = mat;
        line.SetColors(Color.black, Color.black);

        trace = new GameObject().AddComponent<LineRenderer>();
        trace.transform.parent = transform;
        trace.SetWidth(0.5f, 0.5f);
        trace.material = mat;
        trace.SetColors(Color.red, Color.red);

          marble.transform.position = tracePosList[0];
          marble.GetComponent<Renderer>().sortingLayerName = "Marble";
          marble.GetComponent<MeshRenderer>().material.color = Color.yellow;
    }
開發者ID:Ideae,項目名稱:LettersGame,代碼行數:58,代碼來源:LetterMaker.cs

示例13: Generate

        public Mesh Generate(Chunk chunk)
        {
            var mesh = new Mesh();
            var normalsCache = PrecalculateNormals(chunk);
            var verts = new Vector3[chunk.BlocksCount * chunk.BlocksCount * 4];
            var normals = new Vector3[chunk.BlocksCount * chunk.BlocksCount * 4];
            for (int z = 0; z < chunk.BlocksCount; z++)
                for (int x = 0; x < chunk.BlocksCount; x++)
                {
                    //Get neighbor chunks to form a tile
                    var vertIndex = (x + z*chunk.BlocksCount) * 4;
                    verts[vertIndex] = new Vector3(x * chunk.BlockSize, chunk.HeightMap[x, z], z * chunk.BlockSize);
                    verts[vertIndex + 1] = new Vector3(x * chunk.BlockSize, chunk.HeightMap[x, z + 1], (z + 1) * chunk.BlockSize);
                    verts[vertIndex + 2] = new Vector3((x + 1) * chunk.BlockSize, chunk.HeightMap[x + 1, z], z * chunk.BlockSize);
                    verts[vertIndex + 3] = new Vector3((x + 1) * chunk.BlockSize, chunk.HeightMap[x + 1, z + 1], (z + 1) * chunk.BlockSize);
                    normals[vertIndex] = normalsCache[x, z];
                    normals[vertIndex + 1] = normalsCache[x, z + 1];
                    normals[vertIndex + 2] = normalsCache[x + 1, z];
                    normals[vertIndex + 3] = normalsCache[x + 1, z + 1];
                }

            mesh.vertices = verts;

            var indx = new int[chunk.BlocksCount * chunk.BlocksCount *4];
            for (int z = 0; z < chunk.BlocksCount; z++)
                for (int x = 0; x < chunk.BlocksCount; x++)
                {
                    var index = (x + z*chunk.BlocksCount)*4;
                    indx[index + 0] = index;
                    indx[index + 1] = index + 1;
                    indx[index + 2] = index + 3;
                    indx[index + 3] = index + 2;
                }

            mesh.SetIndices(indx, MeshTopology.Quads, 0);

            var colors = new Color[mesh.vertexCount];
            for (int z = 0; z < chunk.BlocksCount; z++)
                for (int x = 0; x < chunk.BlocksCount; x++)
                {
                    var block = chunk.BlockType[x, z];
                    var color = _blocksColors[(int) block];
                    var index = (x + z * chunk.BlocksCount) * 4;

                    colors[index + 0] = color;
                    colors[index + 1] = color;
                    colors[index + 2] = color;
                    colors[index + 3] = color;
                }

            mesh.colors = colors;
            mesh.normals = normals;

            return mesh;
        }
開發者ID:Silentor,項目名稱:InfluenceTerrainDemo,代碼行數:55,代碼來源:ColorMesher.cs

示例14: CreateMeshes

    void CreateMeshes()
    {
        int width = m_depthImage.m_width;
        int height = m_depthImage.m_height;

        int numPoints = width * height;
        int numPointsPerMesh = 20000;
        int numMeshes = (numPoints + numPointsPerMesh - 1) / numPointsPerMesh;

        Vector3[][] points = new Vector3[numMeshes][];
        Vector2[][] uvs = new Vector2[numMeshes][];
        int[] indices = Enumerable.Range(0, numPointsPerMesh).ToArray();

        for (int i = 0; i < numMeshes; ++i)
        {
            points[i] = new Vector3[numPointsPerMesh];
            uvs[i] = new Vector2[numPointsPerMesh];
        }

        for (int i = 0; i < numPoints; ++i)
        {
            int iMesh = i / numPointsPerMesh;
            int iIndex = i % numPointsPerMesh;

            int xi = i % width;
            int yi = i / width;
            float x = ((float)xi / width) - 0.5f;
            float y = ((float)yi / height) - 0.5f;
            float u = (float)xi / width;
            float v = (float)yi / height;

            points[iMesh][iIndex] = new Vector3(x, y, 0);
            uvs[iMesh][iIndex] = new Vector2(u, v);
        }

        for (int i = 0; i < numMeshes; ++i)
        {
            GameObject meshObj = GameObject.Instantiate(m_prefPointMesh, transform.position, transform.rotation) as GameObject;
            Mesh mesh = new Mesh();

            mesh.vertices = points[i];
            mesh.uv = uvs[i];
            mesh.SetIndices(indices, MeshTopology.Points, 0);
            mesh.bounds = new Bounds(Vector3.zero, Vector3.one);

            meshObj.transform.parent = this.transform;
            meshObj.transform.localScale = Vector3.one;
            meshObj.hideFlags |= HideFlags.NotEditable;
            meshObj.GetComponent<MeshFilter>().mesh = mesh;
            meshObj.GetComponent<Renderer>().material = m_shaderMaterial;
        }
    }
開發者ID:ian-campbell-brown,項目名稱:SENG-ELEC-499,代碼行數:52,代碼來源:PointCloudVisualizer.cs

示例15: Start

    void Start()
    {
        var mesh        = new Mesh();

        var vertices    = MakeVertices();
        var indices     = MakeIndices();

        mesh.vertices   = vertices;
        mesh.SetIndices( indices, MeshTopology.Quads, 0 );
        mesh.name       = "TestMesh";

        m_meshFilter.mesh   = mesh;
    }
開發者ID:urahimono,項目名稱:UnityForStackOverflow,代碼行數:13,代碼來源:CSVMesh.cs


注:本文中的UnityEngine.Mesh.SetIndices方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。