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:
Java Program to Implement Red Black Tree
Tìm hiểu về Web Service
Java Program to Implement Sieve Of Atkin
Spring REST with a Zuul Proxy
Guide to BufferedReader
Guide to java.util.concurrent.BlockingQueue
Java Program to Implement SimpeBindings API
Spring Boot - Enabling HTTPS
Java Program to Implement Network Flow Problem
Xử lý ngoại lệ đối với trường hợp ghi đè phương thức trong java
Spring Web Annotations
Convert a Map to an Array, List or Set in Java
Java Program to Describe the Representation of Graph using Adjacency List
Spring Boot - Build Systems
Java Program to Implement Fisher-Yates Algorithm for Array Shuffling
Java Program to Implement Binomial Tree
Lớp HashMap trong Java
Java Program to find the number of occurrences of a given number using Binary Search approach
Spring WebFlux Filters
Weak References in Java
Creating a Custom Starter with Spring Boot
Guide to Java 8 groupingBy Collector
Java Program to Implement Stack
Java Program to Implement the Binary Counting Method to Generate Subsets of a Set
Java Program to Implement Shoelace Algorithm
Command-Line Arguments in Java
Java Program to Generate Random Partition out of a Given Set of Numbers or Characters
DynamoDB in a Spring Boot Application Using Spring Data
Java Program to Implement Triply Linked List
Guide to java.util.Formatter
Allow user:password in URL
Serialization và Deserialization trong java