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


C# Mesh.GetInstanceID方法代碼示例

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


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

示例1: DetectChange

        public static bool DetectChange(int id, Mesh mesh, Transform transform = null)
        {
            if (mesh == null)
                return false;

            if (detectChangeTable.ContainsKey(id))
            {
                MeshDataMirror mirror = detectChangeTable[id];

                bool change = false;
                if (transform != null) {
                    change =
                        mirror.position != transform.position ||
                        mirror.rotation != transform.rotation ||
                        mirror.scale != transform.GetScale();
                }

                if (!change) {
                    change =
                    mirror.meshInstanceID != mesh.GetInstanceID() ||
                    mirror.vertexCount != mesh.vertexCount ||
                    mirror.blendShapeCount != mesh.blendShapeCount ||
                    mirror.subMeshCount != mesh.subMeshCount ||
                        //mirror.triangleCount != mesh.triangles.Length ||
                        //mirror.tangentCount != mesh.tangents.Length ||
                        //mirror.uvCount != mesh.uv.Length ||
                    mirror.extents != mesh.bounds.extents;
                }

                return change;
            } else {
                MeshDataMirror mirror = new MeshDataMirror();
                mirror.meshInstanceID = mesh.GetInstanceID();
                mirror.vertexCount = mesh.vertexCount;
                mirror.blendShapeCount = mesh.blendShapeCount;
                mirror.subMeshCount = mesh.subMeshCount;
                //mirror.triangleCount = mesh.triangles.Length;
                //mirror.tangentCount = mesh.tangents.Length;
                //mirror.uvCount = mesh.uv.Length;
                mirror.extents = mesh.bounds.extents;

                if (transform != null) {
                    mirror.position = transform.position;
                    mirror.rotation = transform.rotation;
                    mirror.scale = transform.GetScale();
                }

                detectChangeTable.Add(id, mirror);
                return true;
            }
        }
開發者ID:WhiteRavensGame,項目名稱:JRPGTownPrototype,代碼行數:51,代碼來源:MeshDataChangeDetector.cs

示例2: BakeMesh

 public static SMesh BakeMesh(Transform transform, Mesh mesh, bool rendererEnabled, SVector3Array customVertices = null)
 {
     SMesh surrogate = new SMesh(transform, mesh.name, mesh.GetInstanceID(), transform.gameObject.activeInHierarchy && rendererEnabled);
     surrogate.header.type = SMesh.Type.full;
     CopyMeshData(mesh, surrogate, customVertices);
     return surrogate;
 }
開發者ID:WhiteRavensGame,項目名稱:JRPGTownPrototype,代碼行數:7,代碼來源:MeshGrabberHelper.cs

示例3: ExportMesh

        public void ExportMesh(Mesh mesh)
        {
            if (mesh == null) return;
            string path = AssetDatabase.GetAssetPath(mesh.GetInstanceID());
            if (String.IsNullOrEmpty(path)) return;
            if (exportedMeshes.Contains(path)) return;

            exportedMeshes.Add(path);
            //path = Path.Combine(@"C:\Projects\PressPlay\Tentacles\Unity\Assets\Level Building Blocks\Worlds\_worlds_imports\XNA", Path.GetFileName(path));
            string dest = Path.Combine(MeshDir, Path.GetFileName(path));

            try
            {
                File.Copy(path, dest, true);
            }
            catch (Exception ex)
            {
                Debug.Log("Could not copy mesh '" + path + "' for " + mesh.name + ". " + ex.Message, mesh);
                throw;
            }
        }
開發者ID:CodeHelix,項目名稱:FFWD,代碼行數:21,代碼來源:AssetHelper.cs

示例4: ClosestPoint

        /// <summary>
        /// Given a mesh, cycle through it and look for the nearest vertex. We'll use this
        /// as a starting point for figuring out the closest point
        /// </summary>
        /// <param name="rPoint"></param>
        /// <param name="rTransform"></param>
        /// <param name="rMesh"></param>
        /// <returns></returns>
        public static Vector3 ClosestPoint(Vector3 rPoint, float rRadius, Transform rTransform, Mesh rMesh)
        {
            MeshOctree lMeshOctree = null;

            int lID = rMesh.GetInstanceID();
            if (MeshOctrees.ContainsKey(lID))
            {
                lMeshOctree = MeshOctrees[lID];
            }
            else
            {
                lMeshOctree = new MeshOctree(rMesh);
                MeshOctrees.Add(lID, lMeshOctree);
            }

            //DebugTransform = rTransform;
            //DebugDraw.DrawSphereMesh(rPoint, 0.05f, Color.green, 1f);

            // Move the point to local space
            Vector3 lLocalPoint = rTransform.InverseTransformPoint(rPoint);

            // Now that we're in the root, find the closest point
            Vector3 lClosestPoint = MeshOctrees[lID].ClosestPoint(lLocalPoint, rRadius);

            if (lClosestPoint.x == float.MaxValue) { lClosestPoint = Vector3.zero; }

            // Move the point to world space
            if (lClosestPoint.sqrMagnitude != 0f)
            {
                lClosestPoint = rTransform.TransformPoint(lClosestPoint);
                //DebugDraw.DrawSphereMesh(lClosestPoint, 0.05f, Color.red, 1f);
            }

            // Return the world space point
            return lClosestPoint;
        }
開發者ID:HowardIfeProjects,項目名稱:IsoPuzzle,代碼行數:44,代碼來源:MeshExt.cs

示例5: SaveMesh

        public string SaveMesh(Mesh mesh)
        {
            int id = mesh.GetInstanceID();
            string name = null;
            if (savecache.TryGetValue(id, out name))
            {
                return name;
            }
            using (System.IO.MemoryStream ms = new System.IO.MemoryStream())
            {
                BitHelper.WriteMesh(mesh, ms);
                byte[] bs = ms.ToArray();
                string sha1 = ResLibTool.ComputeHashString(bs);

                name = sha1 + ".mesh.bin";
                bufs[name] = bs;
            }
            savecache[id] = name;
            return name;
        }
開發者ID:lightszero,項目名稱:EgretUnity,代碼行數:20,代碼來源:nodeParser.cs

示例6: MeshToGeometry

        public static geometry MeshToGeometry(Mesh inputMesh)
        {
            string meshName = "Mesh-" + inputMesh.GetInstanceID();

            geometry outputGeometry = new geometry();
            mesh outputMesh = new mesh();

            outputGeometry.id = meshName + "-lib";
            outputGeometry.name = inputMesh.name + "-mesh";
            outputGeometry.Item = outputMesh;


            //vertex Positions
            List<source> sourceList = new List<source>();
            var inputVertices = inputMesh.vertices;
            if (inputVertices.Length == 0)
                return null;
            sourceList.Add(ArrayToSource(inputMesh.vertices, meshName + "-POSITION"));

            vertices vertexList = new vertices();
            vertexList.id = meshName + "-VERTEX";
            vertexList.input = new InputLocal[1];
            vertexList.input[0] = new InputLocal();
            vertexList.input[0].semantic = "POSITION";
            vertexList.input[0].source = "#" + sourceList[0].id;
            outputMesh.vertices = vertexList;

            List<InputLocalOffset> offsetList = new List<InputLocalOffset>();

            {
                InputLocalOffset offset = new InputLocalOffset();
                offset.semantic = "VERTEX";
                offset.offset = 0;
                offset.source = "#" + vertexList.id;
                offsetList.Add(offset);
            }

            var inputNormals = inputMesh.normals;
            if(inputNormals.Length > 0)
            {
                var array = ArrayToSource(inputNormals, meshName + "-Normal0");
                InputLocalOffset offset = new InputLocalOffset();
                offset.semantic = "NORMAL";
                offset.offset = (ulong)sourceList.Count;
                offset.source = "#" + array.id;
                sourceList.Add(array);
                offsetList.Add(offset);
            }
            var inputUV1s = inputMesh.uv;
            if (inputUV1s.Length > 0)
            {
                var array = ArrayToSource(inputUV1s, meshName + "-UV0");
                InputLocalOffset offset = new InputLocalOffset();
                offset.semantic = "TEXCOORD";
                offset.offset = (ulong)sourceList.Count;
                offset.source = "#" + array.id;
                offset.set = 0;
                offset.setSpecified = true;
                sourceList.Add(array);
                offsetList.Add(offset);
            }
            var inputUV2s = inputMesh.uv2;
            if (inputUV2s.Length > 0)
            {
                var array = ArrayToSource(inputUV2s, meshName + "-UV1");
                InputLocalOffset offset = new InputLocalOffset();
                offset.semantic = "TEXCOORD";
                offset.offset = (ulong)sourceList.Count;
                offset.source = "#" + array.id;
                offset.set = 1;
                offset.setSpecified = true;
                sourceList.Add(array);
                offsetList.Add(offset);
            }
            var inputColors = inputMesh.colors;
            if (inputColors.Length > 0)
            {
                var array = ArrayToSource(inputColors, meshName + "-VERTEX_COLOR0");
                InputLocalOffset offset = new InputLocalOffset();
                offset.semantic = "COLOR";
                offset.offset = (ulong)sourceList.Count;
                offset.source = "#" + array.id;
                offset.set = 0;
                offset.setSpecified = true;
                sourceList.Add(array);
                offsetList.Add(offset);
            }

            outputMesh.source = sourceList.ToArray();


            triangles triangleList = new triangles();
            triangleList.input = offsetList.ToArray();

            var inputTriangles = inputMesh.triangles;

            triangleList.count = (ulong)inputTriangles.Length / 3;

            if (triangleList.count == 0)
                return null;
//.........這裏部分代碼省略.........
開發者ID:Chronovore,項目名稱:armok-vision,代碼行數:101,代碼來源:MeshToCollada.cs

示例7: MeshToGeometry

 public static geometry MeshToGeometry(Mesh inputMesh, string id = null)
 {
     string name;
     if (string.IsNullOrEmpty(id))
         name = "Mesh-" + inputMesh.GetInstanceID();
     else
         name = id;
     return MeshToGeometry(new CPUMesh(inputMesh), name);
 }
開發者ID:JapaMala,項目名稱:armok-vision,代碼行數:9,代碼來源:MeshToCollada.cs


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