-
-
Notifications
You must be signed in to change notification settings - Fork 21.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Geometry2D.IsPointInPolygon incorrectly reports point inside of polygon #82305
Comments
Please provide the code in GDScript as well, the code isn't too complicated to convert, but most people who investigate issues do not have a mono version available, and since you know what it is supposed to do you are best suited to make that version so no one else introduces new errors |
Unfortunately, due to differences in floating point arithmetic, I wasn't able to get a repro using my vertex generation on GDScript. However, I was able to reproduce the issue by porting all my vertexes over into a GDScript. Here is the project: |
The cause seems to be same as in #70823, specifically intersections of the from-point-ray with the polygon edges are counted incorrectly (#70823 (comment)). I'll look into fixing this. |
If it is related to that issue, then maybe the fix I did can help. #74699 |
@0xafbf I've noticed your PR before your comment, got in on my radar. Regarding relation to this specific issue I think about simplifying |
I faced this one today although it is different. I am comparing latitude/longitude coordinates and sometimes the difference between positions is in the range of millionths of a unit. this means that it would tell me that I was in the border of the polygon when I really wasn't diff --git a/core/math/geometry_2d.h b/core/math/geometry_2d.h
index 097aad9cd5..732781db4b 100644
--- a/core/math/geometry_2d.h
+++ b/core/math/geometry_2d.h
@@ -369,7 +369,7 @@ public:
Vector2 res;
if (segment_intersects_segment(v1, v2, p_point, further_away, &res)) {
intersections++;
- if (res.is_equal_approx(p_point)) {
+ if (res == p_point) {
// Point is in one of the polygon edges.
return true;
} Overall I think the use of "approximately equal" in functions and comparisons should be discouraged because otherwise we'll keep finding things like these. |
Godot version
4.1.1-stable [bd6af8e]
System information
Godot v4.1.1.stable.mono (bd6af8e) - Ubuntu 22.04.3 LTS 22.04 - Vulkan (Forward+) - dedicated NVIDIA GeForce RTX 4080 () - AMD Ryzen 9 5900X 12-Core Processor (24 Threads)
Issue description
Geometry2D.IsPointInPolygon incorrectly reports a point lies inside of a polygon, when it clearly lies outside of it.
Here is the perimeter of the polygon:
Here I have printed out the result of Geometry2D.IsPointInPolygon() for all points within a range:
As you can see, there is a rogue pixel in the top left quadrant.
Steps to reproduce
I've created the following repro. Simply attach this script to a Node2D and it will fail with: "Error found in Geometry2D.IsPointInPolygon". Note: I'm generating all the vertices (there are around 250), but I can also provide a text file with each individual vertex if necessary.
The text was updated successfully, but these errors were encountered: