修改水
This commit is contained in:
@@ -6,6 +6,7 @@ namespace Obi{
|
||||
|
||||
public class ObiTerrainShapeTracker : ObiShapeTracker
|
||||
{
|
||||
private bool heightmapDataHasChanged = false;
|
||||
ObiHeightFieldHandle handle;
|
||||
|
||||
public ObiTerrainShapeTracker(ObiCollider source, TerrainCollider collider){
|
||||
@@ -19,7 +20,7 @@ namespace Obi{
|
||||
ObiColliderWorld.GetInstance().DestroyHeightField(handle);
|
||||
}
|
||||
|
||||
public override void UpdateIfNeeded ()
|
||||
public override bool UpdateIfNeeded ()
|
||||
{
|
||||
|
||||
TerrainCollider terrain = collider as TerrainCollider;
|
||||
@@ -41,11 +42,9 @@ namespace Obi{
|
||||
var shape = world.colliderShapes[index];
|
||||
shape.type = ColliderShape.ShapeType.Heightmap;
|
||||
shape.filter = source.Filter;
|
||||
shape.SetSign(source.Inverted);
|
||||
shape.isTrigger = terrain.isTrigger;
|
||||
shape.rigidbodyIndex = source.Rigidbody != null ? source.Rigidbody.Handle.index : -1;
|
||||
shape.flags = terrain.isTrigger ? 1 : 0;
|
||||
shape.rigidbodyIndex = source.Rigidbody != null ? source.Rigidbody.handle.index : -1;
|
||||
shape.materialIndex = source.CollisionMaterial != null ? source.CollisionMaterial.handle.index : -1;
|
||||
shape.forceZoneIndex = source.ForceZone != null ? source.ForceZone.Handle.index : -1;
|
||||
shape.contactOffset = source.Thickness;
|
||||
shape.dataIndex = handle.index;
|
||||
shape.size = terrain.terrainData.size;
|
||||
@@ -59,8 +58,10 @@ namespace Obi{
|
||||
|
||||
// update transform:
|
||||
var trfm = world.colliderTransforms[index];
|
||||
trfm.FromTransform3D(terrain.transform, source.Rigidbody as ObiRigidbody);
|
||||
trfm.FromTransform(terrain.transform);
|
||||
world.colliderTransforms[index] = trfm;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
public override void Destroy()
|
||||
|
||||
Reference in New Issue
Block a user