This is a Java Program to check whether a point lies inside, outside or on the Polygon. Following is a simple idea to check whether a point is inside or outside.
1) Draw a horizontal line to the right of each point and extend it to infinity
2) Count the number of times the line intersects with polygon edges.
3) A point is inside the polygon if either count of intersections is odd or point lies on an edge of polygon. If none of the conditions is true, then point lies outside.
Here is the source code of the Java Program to Check Whether a Given Point is in a Given Polygon. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
//This is a java program to check whether a point lies in a polygon or not class Point { int x, y; Point() {} Point(int p, int q) { x = p; y = q; } } public class Position_Point_WRT_Polygon { public static boolean onSegment(Point p, Point q, Point r) { if (q.x <= Math.max(p.x, r.x) && q.x >= Math.min(p.x, r.x) && q.y <= Math.max(p.y, r.y) && q.y >= Math.min(p.y, r.y)) return true; return false; } public static int orientation(Point p, Point q, Point r) { int val = (q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y); if (val == 0) return 0; return (val > 0) ? 1 : 2; } public static boolean doIntersect(Point p1, Point q1, Point p2, Point q2) { int o1 = orientation(p1, q1, p2); int o2 = orientation(p1, q1, q2); int o3 = orientation(p2, q2, p1); int o4 = orientation(p2, q2, q1); if (o1 != o2 && o3 != o4) return true; if (o1 == 0 && onSegment(p1, p2, q1)) return true; if (o2 == 0 && onSegment(p1, q2, q1)) return true; if (o3 == 0 && onSegment(p2, p1, q2)) return true; if (o4 == 0 && onSegment(p2, q1, q2)) return true; return false; } public static boolean isInside(Point polygon[], int n, Point p) { int INF = 10000; if (n < 3) return false; Point extreme = new Point(INF, p.y); int count = 0, i = 0; do { int next = (i + 1) % n; if (doIntersect(polygon[i], polygon[next], p, extreme)) { if (orientation(polygon[i], p, polygon[next]) == 0) return onSegment(polygon[i], p, polygon[next]); count++; } i = next; } while (i != 0); return (count & 1) == 1 ? true : false; } public static void main(String args[]) { Point polygon1[] = { new Point(0, 0), new Point(10, 0), new Point(10, 10), new Point(0, 10) }; int n = 4; Point p = new Point(20, 20); System.out.println("Point P(" + p.x + ", " + p.y + ") lies inside polygon1: " + isInside(polygon1, n, p)); p = new Point(5, 5); System.out.println("Point P(" + p.x + ", " + p.y + ") lies inside polygon1: " + isInside(polygon1, n, p)); Point polygon2[] = { new Point(0, 0), new Point(5, 5), new Point(5, 0) }; n = 3; p = new Point(3, 3); System.out.println("Point P(" + p.x + ", " + p.y + ") lies inside polygon2: " + isInside(polygon2, n, p)); p = new Point(5, 1); System.out.println("Point P(" + p.x + ", " + p.y + ") lies inside polygon2: " + isInside(polygon2, n, p)); p = new Point(8, 1); System.out.println("Point P(" + p.x + ", " + p.y + ") lies inside polygon2: " + isInside(polygon2, n, p)); Point polygon3[] = { new Point(0, 0), new Point(10, 0), new Point(10, 10), new Point(0, 10), new Point(5, 5) }; n = 5; p = new Point(-1, 10); System.out.println("Point P(" + p.x + ", " + p.y + ") lies inside polygon3: " + isInside(polygon3, n, p)); } }
Output:
$ javac Position_Point_WRT_Polygon.java $ java Position_Point_WRT_Polygon Point P(20, 20) lies inside polygon1: false Point P(5, 5) lies inside polygon1: true Point P(3, 3) lies inside polygon2: true Point P(5, 1) lies inside polygon2: true Point P(8, 1) lies inside polygon2: false Point P(-1, 10) lies inside polygon3: false
Related posts:
Spring REST API + OAuth2 + Angular (using the Spring Security OAuth legacy stack)
Java Program to Implement Patricia Trie
Java Program to Implement Hash Trie
Java Program to Find Shortest Path Between All Vertices Using Floyd-Warshall’s Algorithm
Composition, Aggregation, and Association in Java
String Initialization in Java
The SpringJUnitConfig and SpringJUnitWebConfig Annotations in Spring 5
Array to String Conversions
Java Program to Implement Knapsack Algorithm
The Difference Between Collection.stream().forEach() and Collection.forEach()
Guide to ThreadLocalRandom in Java
Login For a Spring Web App – Error Handling and Localization
Custom Thread Pools In Java 8 Parallel Streams
Find the Registered Spring Security Filters
An Introduction to Java.util.Hashtable Class
Java Program to Test Using DFS Whether a Directed Graph is Strongly Connected or Not
Java Program to Implement Selection Sort
Spring Boot - Runners
The SpringJUnitConfig and SpringJUnitWebConfig Annotations in Spring 5
Quick Guide on Loading Initial Data with Spring Boot
Hướng dẫn Java Design Pattern – Service Locator
Java Program to implement Sparse Vector
Giới thiệu Aspect Oriented Programming (AOP)
Serve Static Resources with Spring
Java Program to Implement Graham Scan Algorithm to Find the Convex Hull
Custom HTTP Header with the HttpClient
Hướng dẫn Java Design Pattern – Iterator
Consumer trong Java 8
Receive email using IMAP
Spring – Injecting Collections
Java Program to Find Nearest Neighbor Using Linear Search
Spring Boot: Customize Whitelabel Error Page