为什么程序生成的网格顶点没有连接?

时间:2016-12-30 15:02:23

标签: c# unity3d mesh procedural-generation

 using UnityEngine;
 using System.Collections;
 using System.Collections.Generic;

 public class MeshDeformer : MonoBehaviour
 {
     public MeshFilter meshFilter;
     private Mesh mesh;
     public GameObject nearest, contactPoint;
     MeshCollider meshCollider;


     void Start()
     {
         meshFilter = GetComponent<MeshFilter>();
         mesh = meshFilter.mesh;

         meshCollider = GetComponent<MeshCollider>();

     }



     void OnCollisionEnter(Collision col)
     {

         deformMesh(col);

     }
     void deformMesh(Collision collision)
     {
         bool[] isProcessed = new bool[mesh.vertexCount];
         Vector3[] tempVerticies = new Vector3[mesh.vertexCount];
         tempVerticies = mesh.vertices;
         ContactPoint[] contacts = collision.contacts;

         string collidingVertexes = "";

         foreach (ContactPoint c in contacts)
         {

             Vector3 localpoint = contactPoint.transform.InverseTransformPoint(c.point);


             int nearestVertexId = getNearestVertexId(localpoint);

             if (!isProcessed[nearestVertexId])
             {
                 isProcessed[nearestVertexId] = true;

                 collidingVertexes += nearestVertexId + ";";

                 tempVerticies[nearestVertexId] += contactPoint.transform.InverseTransformDirection(collision.relativeVelocity.normalized)/50;



             }
         }

         Debug.Log("Colliding vertexId: "+ collidingVertexes);
         mesh.vertices = tempVerticies;
         mesh.RecalculateNormals();
         mesh.RecalculateBounds();
         meshFilter.sharedMesh = mesh;
         meshCollider.sharedMesh = null;
         meshCollider.sharedMesh = mesh;
     }

     int getNearestVertexId(Vector3 point)
     {

         float min = Mathf.Infinity;

         int minId = -1;

         for (int i = 0; i < mesh.vertexCount; i++)
         {
             float dist = (point - mesh.vertices[i]).magnitude;

             if (dist < min)
             {
                 min = dist;
                 minId = i;
             }

         }

         return minId;
     }


 }

enter image description here

怎么了?我想要连接所有的顶点。

之后我没有发现任何变化
mesh.RecalculateNormals();
mesh.RecalculateBounds();

看起来三角图出错了? 我试图在功能结束时更新三角形图,但没有效果。 我想我不明白网格渐变的一些基本原则并且犯了这个错误

0 个答案:

没有答案