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;
}
}
怎么了?我想要连接所有的顶点。
之后我没有发现任何变化
mesh.RecalculateNormals();
mesh.RecalculateBounds();
看起来三角图出错了? 我试图在功能结束时更新三角形图,但没有效果。 我想我不明白网格渐变的一些基本原则并且犯了这个错误