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


C# MeshFilter.GetComponent方法代碼示例

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


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

示例1: MeshToString

    public static string MeshToString(MeshFilter mf)
    {
        Mesh m = mf.sharedMesh;
        Material[] mats = mf.GetComponent<Renderer>().sharedMaterials;

        StringBuilder sb = new StringBuilder();

        sb.Append("g ").Append(mf.name).Append("\n");
        foreach(Vector3 v in m.vertices) {
            sb.Append(string.Format("v {0} {1} {2}\n",v.x,v.y,v.z));
        }
        sb.Append("\n");
        foreach(Vector3 v in m.normals) {
            sb.Append(string.Format("vn {0} {1} {2}\n",v.x,v.y,v.z));
        }
        sb.Append("\n");
        foreach(Vector3 v in m.uv) {
            sb.Append(string.Format("vt {0} {1}\n",v.x,v.y));
        }
        for (int material=0; material < m.subMeshCount; material ++) {
            sb.Append("\n");
            sb.Append("usemtl ").Append(mats[material].name).Append("\n");
            sb.Append("usemap ").Append(mats[material].name).Append("\n");

            int[] triangles = m.GetTriangles(material);
            for (int i=0;i<triangles.Length;i+=3) {
                sb.Append(string.Format("f {0}/{0}/{0} {1}/{1}/{1} {2}/{2}/{2}\n",
                    triangles[i]+1, triangles[i+1]+1, triangles[i+2]+1));
            }
        }

        return sb.ToString();
    }
開發者ID:Daburu,項目名稱:Daburu-Tools,代碼行數:33,代碼來源:ObjExporter.cs

示例2: EJMMesh

		public EJMMesh(MeshFilter component){
			isSkinned = false;
			_mFilter = component;
			mRenderer = component.GetComponent<Renderer> ();
			targettransform = component.transform;
			SetSharedMesh (_mFilter.sharedMesh);
			RefreshMatrix ();
		}
開發者ID:anteaterho,項目名稱:SpoutTestTemp,代碼行數:8,代碼來源:EJMMesh.cs

示例3: MeshToString

        public static string MeshToString(MeshFilter mf)
        {
            var m = mf.sharedMesh;

            var sb = new StringBuilder();

            sb.AppendLine("# Exported from PrimitivesPro, Unity3D asset");
            sb.AppendLine("# http://u3d.as/4gQ");
            sb.AppendLine("--------------------------------------------");
            sb.AppendLine();

            if (mf.GetComponent<Renderer>() && mf.GetComponent<Renderer>().sharedMaterial)
            {
                sb.Append("mtllib ").Append(mf.GetComponent<Renderer>().sharedMaterial.name + ".mtl").Append("\n");
            }

            sb.Append("g ").Append(mf.name).Append("\n");
            foreach (var v in m.vertices)
            {
                sb.Append(string.Format("v {0} {1} {2}\n", v.x, v.y, v.z));
            }
            sb.Append("\n");
            foreach (var v in m.normals)
            {
                sb.Append(string.Format("vn {0} {1} {2}\n", v.x, v.y, v.z));
            }
            sb.Append("\n");
            foreach (var v in m.uv)
            {
                sb.Append(string.Format("vt {0} {1}\n", v.x, v.y));
            }
            for (var material = 0; material < m.subMeshCount; material++)
            {
                sb.Append("\n");
                sb.Append("usemtl ").Append("default").Append("\n");

                int[] triangles = m.GetTriangles(material);
                for (int i = 0; i < triangles.Length; i += 3)
                {
                    sb.Append(string.Format("f {0}/{0}/{0} {1}/{1}/{1} {2}/{2}/{2}\n",
                                            triangles[i] + 1, triangles[i + 1] + 1, triangles[i + 2] + 1));
                }
            }
            return sb.ToString();
        }
開發者ID:jfeng94,項目名稱:Thesis,代碼行數:45,代碼來源:ObjExporter.cs

示例4: MeshToFile

        public static void MeshToFile(MeshFilter mf, string rootPath, string filename, bool exportMaterial)
        {
            var objFile = rootPath + "/" + filename + ".obj";

            using (var sw = new StreamWriter(objFile))
            {
                sw.Write(MeshToString(mf));
            }

            if (mf.GetComponent<Renderer>() && mf.GetComponent<Renderer>().sharedMaterial)
            {
                var materialFile = rootPath + "/" + mf.GetComponent<Renderer>().sharedMaterial.name + ".mtl";

                using (var sw = new StreamWriter(materialFile))
                {
                    sw.Write(MaterialToFile(mf.GetComponent<Renderer>().sharedMaterial, materialFile, rootPath));
                }
            }
        }
開發者ID:jaroosh,項目名稱:Habitat,代碼行數:19,代碼來源:ObjExporter.cs

示例5: MeshToString

	public static string MeshToString(MeshFilter mf, Transform t) 
	{	
		Vector3 s 		= t.localScale;
		Vector3 p 		= t.localPosition;
		Quaternion r 	= t.localRotation;
		
		
		int numVertices = 0;
		Mesh m = mf.sharedMesh;
		if (!m)
		{
			return "####Error####";
		}
		Material[] mats = mf.GetComponent<Renderer>().sharedMaterials;
		
		StringBuilder sb = new StringBuilder();
		
		foreach(Vector3 vv in m.vertices)
		{
			Vector3 v = t.TransformPoint(vv);
			numVertices++;
			sb.Append(string.Format("v {0} {1} {2}\n",v.x,v.y,-v.z));
		}
		sb.Append("\n");
		foreach(Vector3 nn in m.normals) 
		{
			Vector3 v = r * nn;
			sb.Append(string.Format("vn {0} {1} {2}\n",-v.x,-v.y,v.z));
		}
		sb.Append("\n");
		foreach(Vector3 v in m.uv) 
		{
			sb.Append(string.Format("vt {0} {1}\n",v.x,v.y));
		}
		for (int material=0; material < m.subMeshCount; material ++) 
		{
			sb.Append("\n");
			sb.Append("usemtl ").Append(mats[material].name).Append("\n");
			sb.Append("usemap ").Append(mats[material].name).Append("\n");
			
			int[] triangles = m.GetTriangles(material);
			for (int i=0;i<triangles.Length;i+=3) {
				sb.Append(string.Format("f {0}/{0}/{0} {1}/{1}/{1} {2}/{2}/{2}\n", 
				                        triangles[i]+1+StartIndex, triangles[i+1]+1+StartIndex, triangles[i+2]+1+StartIndex));
			}
		}
		
		StartIndex += numVertices;
		return sb.ToString();
	}
開發者ID:JustJessTV,項目名稱:GitMergeTest,代碼行數:50,代碼來源:objExport.cs

示例6: MeshToString

    public static string MeshToString(Transform tr, MeshFilter mf, string prefName)
    {
        Mesh m = mf.mesh;
        Material[] mats = mf.GetComponent<Renderer>().sharedMaterials;

        //Debug.Log("subnesh count=" + m.subMeshCount.ToString());

        int vertexShift = vertexCounter;

        StringBuilder sb = new StringBuilder();

        sb.Append("g ").Append(prefName + mf.name).Append("\n");

        foreach (Vector3 v in m.vertices)
        {
            vertexCounter++;
            Matrix4x4 trMatrix = tr.localToWorldMatrix;
            Vector3 v2 = trMatrix.MultiplyPoint3x4(v);
            //Vector3 v2 = tr.TransformPoint(v);
            sb.Append(string.Format("v {0} {1} {2}\n", v2.x, v2.y, v2.z));
        }
        sb.Append("\n");
        foreach (Vector3 v in m.normals)
        {
            Matrix4x4 trMatrix = tr.localToWorldMatrix;
            Vector3 v2 = trMatrix.MultiplyPoint3x4(v);
            //Vector3 v2 = tr.TransformPoint(v);
            sb.Append(string.Format("vn {0} {1} {2}\n", v2.x, v2.y, v2.z));
        }
        sb.Append("\n");
        foreach (Vector3 v in m.uv)
        {
            sb.Append(string.Format("vt {0} {1}\n", v.x, v.y));
        }
        for (int material = 0; material < m.subMeshCount; material++)
        {
            sb.Append("\n");
            sb.Append("usemtl ").Append(prefName + mats[material].name).Append("\n");
            sb.Append("usemap ").Append(prefName + mats[material].name).Append("\n");

            int[] triangles = m.GetTriangles(material);
            for (int i = 0; i < triangles.Length; i += 3)
            {
                sb.Append(string.Format("f {0}/{0}/{0} {1}/{1}/{1} {2}/{2}/{2}\n",
                    triangles[i] + 1 + vertexShift, triangles[i + 1] + 1 + vertexShift, triangles[i + 2] + 1 + vertexShift));
            }
        }
        return sb.ToString();
    }
開發者ID:Angel07,項目名稱:SpineConstructor,代碼行數:49,代碼來源:ObjExporter.cs

示例7: MeshToString

 public static string MeshToString(MeshFilter mf)
 {
     Mesh sharedMesh = mf.sharedMesh;
     Material[] sharedMaterials = mf.GetComponent<Renderer>().sharedMaterials;
     StringBuilder stringBuilder = new StringBuilder();
     stringBuilder.Append("g ").Append(mf.name).Append("\n");
     Vector3[] vertices = sharedMesh.vertices;
     for (int i = 0; i < vertices.Length; i++)
     {
         Vector3 vector = vertices[i];
         stringBuilder.Append(string.Format("v {0} {1} {2}\n", -vector.x, vector.y, vector.z));
     }
     stringBuilder.Append("\n");
     Vector3[] normals = sharedMesh.normals;
     for (int j = 0; j < normals.Length; j++)
     {
         Vector3 vector2 = normals[j];
         stringBuilder.Append(string.Format("vn {0} {1} {2}\n", -vector2.x, vector2.y, vector2.z));
     }
     stringBuilder.Append("\n");
     Vector2[] uv = sharedMesh.uv;
     for (int k = 0; k < uv.Length; k++)
     {
         Vector3 vector3 = uv[k];
         stringBuilder.Append(string.Format("vt {0} {1}\n", vector3.x, vector3.y));
     }
     for (int l = 0; l < sharedMesh.subMeshCount; l++)
     {
         stringBuilder.Append("\n");
         stringBuilder.Append("usemtl ").Append(sharedMaterials[l].name).Append("\n");
         stringBuilder.Append("usemap ").Append(sharedMaterials[l].name).Append("\n");
         int[] triangles = sharedMesh.GetTriangles(l);
         for (int m = 0; m < triangles.Length; m += 3)
         {
             stringBuilder.Append(string.Format("f {0}/{0}/{0} {1}/{1}/{1} {2}/{2}/{2}\n", triangles[m + 2] + 1, triangles[m + 1] + 1, triangles[m] + 1));
         }
     }
     return stringBuilder.ToString();
 }
開發者ID:GameDiffs,項目名稱:TheForest,代碼行數:39,代碼來源:RTPObjExporter.cs

示例8: WriteMesh

    void WriteMesh(MeshFilter meshFilter, StreamWriter outFile, string indent)
    {
        string verticesFileName = mPath + meshFilter.name + ".vertices";
        string normalsFileName = mPath + meshFilter.name + ".normals";
        string uvsFileName = mPath + meshFilter.name + ".uvs";
        string indicesFileName = mPath + meshFilter.name + ".indices";

        WriteArrayToFile (verticesFileName, meshFilter.sharedMesh.vertices);
        WriteArrayToFile (normalsFileName, meshFilter.sharedMesh.normals);
        WriteArrayToFile (uvsFileName, meshFilter.sharedMesh.uv);
        WriteArrayToFile (indicesFileName, meshFilter.sharedMesh.triangles);

        outFile.WriteLine (indent + "<Mesh id=\"" + GetId (meshFilter.transform) + "\" parentId=\"" + GetId (meshFilter.transform.parent) + "\" vertices=\"" + verticesFileName + "\" normals=\"" + normalsFileName + "\" uvs=\"" + uvsFileName + "\" indices=\"" + indicesFileName + "\">");

        WriteTransform (meshFilter.transform, outFile, indent + indent);

        MeshRenderer meshRenderer = meshFilter.GetComponent<MeshRenderer> ();

        if (meshRenderer != null) {
            WriteMaterial (meshRenderer, outFile, indent + indent);
        }

        outFile.WriteLine (indent + "</Mesh>");
    }
開發者ID:pboechat,項目名稱:simpleraytracer,代碼行數:24,代碼來源:simpleraytracer.cs

示例9: MeshToString

    private static string MeshToString(MeshFilter mf, Dictionary<string, ObjMaterial> materialList)
    {
        Mesh m = mf.sharedMesh;
        Material[] mats = mf.GetComponent<Renderer>().sharedMaterials;

        StringBuilder sb = new StringBuilder();

        sb.Append("g ").Append(mf.name).Append("\n");
        foreach(Vector3 lv in m.vertices)
        {
            Vector3 wv = mf.transform.TransformPoint(lv);

            //This is sort of ugly - inverting x-component since we're in
            //a different coordinate system than "everyone" is "used to".
            sb.Append(string.Format("v {0} {1} {2}\n",-wv.x,wv.y,wv.z));
        }
        sb.Append("\n");

        foreach(Vector3 lv in m.normals)
        {
            Vector3 wv = mf.transform.TransformDirection(lv);

            sb.Append(string.Format("vn {0} {1} {2}\n",-wv.x,wv.y,wv.z));
        }
        sb.Append("\n");

        foreach(Vector3 v in m.uv)
        {
            sb.Append(string.Format("vt {0} {1}\n",v.x,v.y));
        }

        for (int material=0; material < m.subMeshCount; material ++) {
            sb.Append("\n");
            sb.Append("usemtl ").Append(mats[material].name).Append("\n");
            sb.Append("usemap ").Append(mats[material].name).Append("\n");

            //See if this material is already in the materiallist.
            try
            {
                ObjMaterial objMaterial = new ObjMaterial();

                objMaterial.name = mats[material].name;

                if (mats[material].mainTexture)
                    objMaterial.textureName = EditorUtility.GetAssetPath(mats[material].mainTexture);
                else
                    objMaterial.textureName = null;

                materialList.Add(objMaterial.name, objMaterial);
            }
            catch (ArgumentException)
            {
                //Already in the dictionary
            }

            int[] triangles = m.GetTriangles(material);
            for (int i=0;i<triangles.Length;i+=3)
            {
                //Because we inverted the x-component, we also needed to alter the triangle winding.
                sb.Append(string.Format("f {1}/{1}/{1} {0}/{0}/{0} {2}/{2}/{2}\n",
                                        triangles[i]+1 + vertexOffset, triangles[i+1]+1 + normalOffset, triangles[i+2]+1 + uvOffset));
            }
        }

        vertexOffset += m.vertices.Length;
        normalOffset += m.normals.Length;
        uvOffset += m.uv.Length;

        return sb.ToString();
    }
開發者ID:shinobushiva,項目名稱:Unity-Utils,代碼行數:70,代碼來源:EditorObjExporter.cs

示例10: GetWorldPositionFromGridCoordinate

    public static Vector3 GetWorldPositionFromGridCoordinate(MeshFilter planeMeshFilter, float x, float y, int width, int height)
    {
        var localPoint = GetLocalPositionFromGridCoordinate(planeMeshFilter, x, y, width, height);

        var transform = planeMeshFilter.GetComponent<Transform>();
        return transform.TransformPoint(localPoint);
    }
開發者ID:j0rg3n,項目名稱:capitalist-pigs-ngj11-game,代碼行數:7,代碼來源:MathUtil.cs

示例11: VoxelMeshToObjFile

    public static void VoxelMeshToObjFile(string filepath, MeshFilter mf)
    {
        // based on http://wiki.unity3d.com/index.php?title=ObjExporter
        using (StreamWriter writer = new StreamWriter(filepath))
        {
            Mesh m = mf.mesh;
            Material[] mats = mf.GetComponent<Renderer>().sharedMaterials;

            writer.Write("g ");
            writer.WriteLine(mf.name);
            foreach (Vector3 v in m.vertices)
            {
                writer.WriteLine("v {0} {1} {2}", v.x, v.y, v.z);
            }
            writer.WriteLine();
            foreach (Vector3 v in m.normals)
            {
                writer.WriteLine("vn {0} {1} {2}", v.x, v.y, v.z);
            }
            writer.WriteLine();
            foreach (Vector3 v in m.uv)
            {
                writer.WriteLine("vt {0} {1}", v.x, v.y);
            }
            for (int material = 0; material < m.subMeshCount; material++)
            {
                writer.WriteLine();
                writer.Write("usemtl ");
                writer.WriteLine(mats[material].name);
                writer.Write("usemap ");
                writer.WriteLine(mats[material].name);

                int[] triangles = m.GetTriangles(material);
                for (int i = 0; i < triangles.Length; i += 3)
                {
                    writer.WriteLine("f {0}/{0}/{0} {1}/{1}/{1} {2}/{2}/{2}",
                        triangles[i] + 1, triangles[i + 1] + 1, triangles[i + 2] + 1);
                }
            }
        }
    }
開發者ID:BluBambu,項目名稱:MultiVoxel,代碼行數:41,代碼來源:VoxelSerializer.cs

示例12: ProcessMesh

	public static void ProcessMesh(MeshFilter mf, Transform t)
	{
		int numVertices = 0;

		Mesh m = mf.mesh;
		if (!m)
		{
			meshString.Append("####Error####\n");
			return;
		}

		foreach (Vector3 vv in m.vertices)
		{
			Vector3 v = t.TransformPoint(vv);
			numVertices++;
			meshString.Append(string.Format("v {0} {1} {2}\n", v.x, v.y, -v.z));
		}
		meshString.Append("\n");
		foreach (Vector3 nn in m.normals)
		{
			Vector3 v = t.TransformDirection(nn);
			meshString.Append(string.Format("vn {0} {1} {2}\n", -v.x, -v.y, v.z));
		}
		meshString.Append("\n");
		foreach (Vector3 v in m.uv)
		{
			meshString.Append(string.Format("vt {0} {1}\n", v.x, v.y));
		}

		Material[] mats = mf.GetComponent<MeshRenderer>().materials;
		for (int material = 0; material < m.subMeshCount; material++)
		{
			Material mat = mats[material % mats.Length];
			string matName = mat.name.Replace(" (Instance)", "").Replace(' ', '_').Replace("__", "_");

			if (!materialList.ContainsKey(matName))
			{
				materialList.Add(matName, mat);
			}

			meshString.Append("\n");
			meshString.Append("usemtl ").Append(matName).Append("\n");
			meshString.Append("usemap ").Append(matName).Append("\n");

			int[] triangles = m.GetTriangles(material);
			for (int i = 0; i < triangles.Length; i += 3)
			{
				meshString.Append(string.Format("f {0}/{0}/{0} {1}/{1}/{1} {2}/{2}/{2}\n",
					triangles[i    ] + 1 + indexOffset, 
					triangles[i + 1] + 1 + indexOffset, 
					triangles[i + 2] + 1 + indexOffset));
			}
		}

		indexOffset += numVertices;
	}
開發者ID:stefanmarks,項目名稱:MotionServer_Clients,代碼行數:56,代碼來源:ObjExporter.cs

示例13: MeshToString

	private static string MeshToString(MeshFilter mf, Dictionary<string, ObjMaterial> materialList) 
	{
		Mesh m = mf.sharedMesh;
		Material[] mats = mf.GetComponent<Renderer>().sharedMaterials;

		StringBuilder sb = new StringBuilder();

		sb.Append("g ").Append(mf.name).Append("\n");
		
		foreach(Vector3 lv in m.vertices) 
		{
			Vector3 wv = lv;
				
			// this is not how to convert from left to right handed coordinates
			//This is sort of ugly - inverting x-component since we're in
			//a different coordinate system than "everyone" is "used to".
			sb.Append(string.Format("v {0} {1} {2}\n",-wv.x,wv.y,wv.z));
		}

		sb.Append("\n");

		foreach(Vector3 lv in m.normals) 
		{
			Vector3 wv = lv;

			sb.Append(string.Format("vn {0} {1} {2}\n",-wv.x,wv.y,wv.z));
		}

		sb.Append("\n");

		foreach(Vector3 v in m.uv) 
		{
			sb.Append(string.Format("vt {0} {1}\n",v.x,v.y));
		}

		for (int i = 0; i < m.subMeshCount; i ++)
		{
			sb.Append("\n");
			sb.Append("g ").Append(mats[i].name).Append("\n");
			sb.Append("usemtl ").Append(mats[i].name).Append("\n");
			sb.Append("usemap ").Append(mats[i].name).Append("\n");

			ObjMaterial objMaterial = new ObjMaterial();

			objMaterial.name = mats[i].name;

			if (mats[i].mainTexture)
				objMaterial.textureName = UnityEditor.AssetDatabase.GetAssetPath(mats[i].mainTexture);
			else 
				objMaterial.textureName = null;

			materialList.Add(objMaterial.name, objMaterial);

			int[] tri = m.GetTriangles(i);
			for (int n = 0; n < tri.Length; n += 3) 
			{
				//Because we inverted the x-component, we also needed to alter the triangle winding.
				sb.Append(string.Format("f {1}/{1}/{1} {0}/{0}/{0} {2}/{2}/{2}\n", 
				tri[n]+1 + vertexOffset, tri[n+1]+1 + normalOffset, tri[n+2]+1 + uvOffset));
			}
		}

		vertexOffset += m.vertices.Length;
		normalOffset += m.normals.Length;
		uvOffset += m.uv.Length;

		return sb.ToString();
	}
開發者ID:itubeasts,項目名稱:I-eaT-U,代碼行數:68,代碼來源:EditorObjExporter.cs

示例14: buildMesh

		public void buildMesh (Vector3 position)
		{	
			VoxelDrawMesh draw = new VoxelDrawMesh ();
			Debug.Log (real_.Count + "count");
			foreach (KeyValuePair<VectorInt3, VoxelShadowHandler> kv in this.real_) {
				VectorInt4 v = draw.addRect (Vector3.up, kv.Key + new VectorInt3(0, 0, -1) , VoxelShadowHandler.GetUV(kv.Value.real), VoxelShadowHandler.GetUV(kv.Value.ghost), Color.black);
			}

			_mesh = draw.crateMeshFilter ("Shadow", _material);
			if (_offset != null) {
				_mesh.gameObject.transform.SetParent (this._offset.transform);
			} else {
				_mesh.gameObject.transform.SetParent (this.transform);		
			}
			
			_mesh.gameObject.transform.localPosition = Vector3.zero;
			_mesh.gameObject.transform.localScale = Vector3.one;
			_mesh.gameObject.transform.localRotation = Quaternion.Euler (Vector3.zero);
			
			_mesh.gameObject.SetActive (true);
			Renderer renderer = _mesh.GetComponent<Renderer> ();
			renderer.material = this._material;
			showMesh (position);
		}
開發者ID:CzDreamer,項目名稱:eat,代碼行數:24,代碼來源:VoxelShadow.cs

示例15: MeshContainer

 public MeshContainer(MeshFilter meshFilter)
 {
     Mesh = meshFilter.mesh;
     transform = meshFilter.GetComponent<Transform>();
     isAnimated = false;
 }
開發者ID:ZepLI,項目名稱:U3D,代碼行數:6,代碼來源:MeshContainer.cs


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