diff --git a/OpenKh.Command.MapGen/Utils/FlattenCollisionBuilder.cs b/OpenKh.Command.MapGen/Utils/FlattenCollisionBuilder.cs index 42a0f5b19..a3d6a1ffa 100644 --- a/OpenKh.Command.MapGen/Utils/FlattenCollisionBuilder.cs +++ b/OpenKh.Command.MapGen/Utils/FlattenCollisionBuilder.cs @@ -56,7 +56,7 @@ Func getAttributeFrom var v3 = face.positionList[2]; var v4 = quad ? face.positionList[3] : Vector3.Zero; - collisionMesh.Collisions.Add(coct.Complete( + var collision = coct.Complete( new Collision { Vertex1 = helper.AllocateVertex(v1.X, -v1.Y, -v1.Z), // why -Y and -Z ? @@ -68,7 +68,16 @@ Func getAttributeFrom FloorLevel = face.matDef.floorLevel, }, inflate: 1 - )); + ); + + if (float.IsNaN(collision.Plane.D)) + { + // 3 points are on the same line (not a plane) + } + else + { + collisionMesh.Collisions.Add(collision); + } } if (collisionMesh.Collisions.Any()) diff --git a/OpenKh.Command.MapGen/Utils/HierarchicalCollisionBuilder.cs b/OpenKh.Command.MapGen/Utils/HierarchicalCollisionBuilder.cs index f950beb6b..02feadcbc 100644 --- a/OpenKh.Command.MapGen/Utils/HierarchicalCollisionBuilder.cs +++ b/OpenKh.Command.MapGen/Utils/HierarchicalCollisionBuilder.cs @@ -70,7 +70,7 @@ private WalkResult WalkTree(Node walkNode, BuildHelper helper) var v3 = face.positionList[2]; var v4 = quad ? face.positionList[3] : Vector3.Zero; - collisionMesh.Collisions.Add(coct.Complete( + var collision = coct.Complete( new Collision { Vertex1 = helper.AllocateVertex(v1.X, -v1.Y, -v1.Z), // why -Y and -Z ? @@ -82,7 +82,16 @@ private WalkResult WalkTree(Node walkNode, BuildHelper helper) FloorLevel = face.matDef.floorLevel, }, inflate: 1 - )); + ); + + if (float.IsNaN(collision.Plane.D)) + { + // 3 points are on the same line (not a plane) + } + else + { + collisionMesh.Collisions.Add(collision); + } } coct.Complete(collisionMesh); diff --git a/OpenKh.Tests.Commands/res/mapgen/multi-4bpp/multi-4bpp.coct.dump b/OpenKh.Tests.Commands/res/mapgen/multi-4bpp/multi-4bpp.coct.dump index eea2ecfbb..b0cbf343a 100644 --- a/OpenKh.Tests.Commands/res/mapgen/multi-4bpp/multi-4bpp.coct.dump +++ b/OpenKh.Tests.Commands/res/mapgen/multi-4bpp/multi-4bpp.coct.dump @@ -52,12 +52,6 @@ [Collision] BoundingBox=((110, -89, 790), (112, -18, 1166)); Plane={Normal:<1, 0, 0> D:-110.80987}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<110.80987, -18.574833, 1164.5176, 1>, <110.80987, -88.25589, 1164.5176, 1>, <110.80987, -88.25595, 791.2884, 1>, <110.80987, -18.574894, 791.2884, 1> [Collision] BoundingBox=((-263, -89, 1164), (112, -18, 1166)); Plane={Normal:<0, 0, 1> D:-1164.5176}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-262.41928, -18.574833, 1164.5176, 1>, <-262.41928, -88.25589, 1164.5176, 1>, <110.80987, -88.25589, 1164.5176, 1>, <110.80987, -18.574833, 1164.5176, 1> [Collision] BoundingBox=((-1514, 487, -1514), (1514, 489, 1514)); Plane={Normal:<0, 1, -1.6133453E-07> D:-487.63513}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-1513.2571, 487.6349, -1513.2571, 1>, <-1513.2571, 487.63538, 1513.2571, 1>, <1513.2571, 487.63538, 1513.2571, 1>, <1513.2571, 487.6349, -1513.2571, 1> - [Collision] BoundingBox=((-1514, 487, -1514), (1514, 489, -1512)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-1513.2571, 487.6349, -1513.2571, 1>, <1513.2571, 487.6349, -1513.2571, 1>, <1513.2571, 487.6349, -1513.2571, 1>, <-1513.2571, 487.6349, -1513.2571, 1> - [Collision] BoundingBox=((1512, 487, -1514), (1514, 489, 1514)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<1513.2571, 487.6349, -1513.2571, 1>, <1513.2571, 487.63538, 1513.2571, 1>, <1513.2571, 487.63538, 1513.2571, 1>, <1513.2571, 487.6349, -1513.2571, 1> - [Collision] BoundingBox=((-1514, 487, -1514), (-1512, 489, 1514)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-1513.2571, 487.63538, 1513.2571, 1>, <-1513.2571, 487.6349, -1513.2571, 1>, <-1513.2571, 487.6349, -1513.2571, 1>, <-1513.2571, 487.63538, 1513.2571, 1> - [Collision] BoundingBox=((-1514, 487, 1512), (1514, 489, 1514)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<1513.2571, 487.63538, 1513.2571, 1>, <-1513.2571, 487.63538, 1513.2571, 1>, <-1513.2571, 487.63538, 1513.2571, 1>, <1513.2571, 487.63538, 1513.2571, 1> - [Collision] BoundingBox=((-1514, 487, 1512), (1514, 489, 1514)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<1513.2571, 487.63538, 1513.2571, 1>, <-1513.2571, 487.63538, 1513.2571, 1>, <-1513.2571, 487.63538, 1513.2571, 1>, <1513.2571, 487.63538, 1513.2571, 1> - [Collision] BoundingBox=((1512, 487, -1514), (1514, 489, 1514)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<1513.2571, 487.6349, -1513.2571, 1>, <1513.2571, 487.63538, 1513.2571, 1>, <1513.2571, 487.63538, 1513.2571, 1>, <1513.2571, 487.6349, -1513.2571, 1> [Collision] BoundingBox=((-616, 258, -188), (-241, 260, 188)); Plane={Normal:<0, -1, 1.6353266E-07> D:259.45993}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-241.52211, 259.45996, 186.51791, 1>, <-614.7513, 259.45996, 186.51791, 1>, <-614.7513, 259.4599, -186.71124, 1>, <-241.52211, 259.4599, -186.71124, 1> [Collision] BoundingBox=((-217, -147, 323), (158, -145, 698)); Plane={Normal:<0, -1, 1.6353268E-07> D:-146.34552}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<157.16917, -146.34541, 697.10345, 1>, <-216.05998, -146.34541, 697.10345, 1>, <-216.05998, -146.34547, 323.87433, 1>, <157.16917, -146.34547, 323.87433, 1> [Collision] BoundingBox=((278, 360, -194), (653, 362, 181)); Plane={Normal:<0, -1, 1.6353266E-07> D:360.9327}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<651.7928, 360.93274, 179.9218, 1>, <278.5636, 360.93274, 179.9218, 1>, <278.5636, 360.93268, -193.30736, 1>, <651.7928, 360.93268, -193.30736, 1> diff --git a/OpenKh.Tests.Commands/res/mapgen/multi-8bpp/multi-8bpp.coct.dump b/OpenKh.Tests.Commands/res/mapgen/multi-8bpp/multi-8bpp.coct.dump index b890541c5..b93def5a1 100644 --- a/OpenKh.Tests.Commands/res/mapgen/multi-8bpp/multi-8bpp.coct.dump +++ b/OpenKh.Tests.Commands/res/mapgen/multi-8bpp/multi-8bpp.coct.dump @@ -52,12 +52,6 @@ [Collision] BoundingBox=((-112, -89, -1166), (-110, -18, -790)); Plane={Normal:<-1, 0, 0> D:-110.80987}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-110.80987, -18.574879, -1164.5176, 1>, <-110.80987, -88.255936, -1164.5176, 1>, <-110.80987, -88.255875, -791.2884, 1>, <-110.80987, -18.574818, -791.2884, 1> [Collision] BoundingBox=((-112, -89, -1166), (263, -18, -1164)); Plane={Normal:<0, -0, -1> D:-1164.5176}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<262.41928, -18.57491, -1164.5176, 1>, <262.41928, -88.25597, -1164.5176, 1>, <-110.80987, -88.255936, -1164.5176, 1>, <-110.80987, -18.574879, -1164.5176, 1> [Collision] BoundingBox=((-1514, 487, -1514), (1514, 489, 1514)); Plane={Normal:<8.066726E-08, 1, -1.6133453E-07> D:-487.63513}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<1513.2571, 487.63525, 1513.2571, 1>, <1513.2571, 487.63477, -1513.2571, 1>, <-1513.2571, 487.635, -1513.2571, 1>, <-1513.2571, 487.6355, 1513.2571, 1> - [Collision] BoundingBox=((-1514, 487, 1512), (1514, 489, 1514)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<1513.2571, 487.63525, 1513.2571, 1>, <-1513.2571, 487.6355, 1513.2571, 1>, <-1513.2571, 487.6355, 1513.2571, 1>, <1513.2571, 487.63525, 1513.2571, 1> - [Collision] BoundingBox=((-1514, 487, -1514), (-1512, 489, 1514)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-1513.2571, 487.6355, 1513.2571, 1>, <-1513.2571, 487.635, -1513.2571, 1>, <-1513.2571, 487.635, -1513.2571, 1>, <-1513.2571, 487.6355, 1513.2571, 1> - [Collision] BoundingBox=((1512, 487, -1514), (1514, 489, 1514)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<1513.2571, 487.63477, -1513.2571, 1>, <1513.2571, 487.63525, 1513.2571, 1>, <1513.2571, 487.63525, 1513.2571, 1>, <1513.2571, 487.63477, -1513.2571, 1> - [Collision] BoundingBox=((-1514, 487, -1514), (1514, 489, -1512)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-1513.2571, 487.635, -1513.2571, 1>, <1513.2571, 487.63477, -1513.2571, 1>, <1513.2571, 487.63477, -1513.2571, 1>, <-1513.2571, 487.635, -1513.2571, 1> - [Collision] BoundingBox=((-1514, 487, -1514), (1514, 489, -1512)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-1513.2571, 487.635, -1513.2571, 1>, <1513.2571, 487.63477, -1513.2571, 1>, <1513.2571, 487.63477, -1513.2571, 1>, <-1513.2571, 487.635, -1513.2571, 1> - [Collision] BoundingBox=((-1514, 487, -1514), (-1512, 489, 1514)); Plane={Normal: D:NaN}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-1513.2571, 487.6355, 1513.2571, 1>, <-1513.2571, 487.635, -1513.2571, 1>, <-1513.2571, 487.635, -1513.2571, 1>, <-1513.2571, 487.6355, 1513.2571, 1> [Collision] BoundingBox=((241, 258, -188), (616, 260, 188)); Plane={Normal:<-8.176632E-08, -1, 1.6353266E-07> D:259.45996}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<241.52211, 259.4599, -186.51791, 1>, <614.7513, 259.45987, -186.51791, 1>, <614.7513, 259.45993, 186.71124, 1>, <241.52211, 259.45996, 186.71124, 1> [Collision] BoundingBox=((-158, -147, -698), (217, -145, -323)); Plane={Normal:<-8.176633E-08, -1, 1.6353268E-07> D:-146.34537}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-157.16917, -146.34546, -697.10345, 1>, <216.05998, -146.34549, -697.10345, 1>, <216.05998, -146.34543, -323.87433, 1>, <-157.16917, -146.3454, -323.87433, 1> [Collision] BoundingBox=((-653, 360, -181), (-278, 362, 194)); Plane={Normal:<-8.176632E-08, -1, 1.6353266E-07> D:360.93265}; Ground=0; FloorLevel=0; Attributes=000003F1; Vertices=<-651.7928, 360.93268, -179.9218, 1>, <-278.5636, 360.93265, -179.9218, 1>, <-278.5636, 360.9327, 193.30736, 1>, <-651.7928, 360.93274, 193.30736, 1>