diff --git a/modules/imgproc/src/geometry.cpp b/modules/imgproc/src/geometry.cpp index cf9cb072b7..66df61104d 100644 --- a/modules/imgproc/src/geometry.cpp +++ b/modules/imgproc/src/geometry.cpp @@ -119,7 +119,6 @@ double cv::pointPolygonTest( InputArray _contour, Point2f pt, bool measureDist ) for( i = 0; i < total; i++ ) { - int dist; v0 = v; v = cnt[i]; @@ -133,7 +132,8 @@ double cv::pointPolygonTest( InputArray _contour, Point2f pt, bool measureDist ) continue; } - dist = (ip.y - v0.y)*(v.x - v0.x) - (ip.x - v0.x)*(v.y - v0.y); + int64 dist = static_cast(ip.y - v0.y)*(v.x - v0.x) + - static_cast(ip.x - v0.x)*(v.y - v0.y); if( dist == 0 ) return 0; if( v.y < v0.y ) diff --git a/modules/imgproc/test/test_contours.cpp b/modules/imgproc/test/test_contours.cpp index d5c4e44275..d7d5128beb 100644 --- a/modules/imgproc/test/test_contours.cpp +++ b/modules/imgproc/test/test_contours.cpp @@ -485,4 +485,18 @@ TEST(Imgproc_FindContours, border) ASSERT_TRUE(norm(img - img_draw_contours, NORM_INF) == 0.0); } +TEST(Imgproc_PointPolygonTest, regression_10222) +{ + vector contour; + contour.push_back(Point(0, 0)); + contour.push_back(Point(0, 100000)); + contour.push_back(Point(100000, 100000)); + contour.push_back(Point(100000, 50000)); + contour.push_back(Point(100000, 0)); + + const Point2f point(40000, 40000); + const double result = cv::pointPolygonTest(contour, point, false); + EXPECT_GT(result, 0) << "Desired result: point is inside polygon - actual result: point is not inside polygon"; +} + /* End of file. */