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:
Hướng dẫn Java Design Pattern – Adapter
Primitive Type Streams in Java 8
Hướng dẫn Java Design Pattern – Memento
Java Program to Implement HashTable API
Một số tính năng mới về xử lý ngoại lệ trong Java 7
Java Program to Implement K Way Merge Algorithm
Java Program to Implement Horner Algorithm
Encode/Decode to/from Base64
Java Program to Encode a Message Using Playfair Cipher
Java Program to Perform Deletion in a BST
Java Program to Implement Dijkstra’s Algorithm using Queue
Serverless Functions with Spring Cloud Function
Consumer trong Java 8
Java Program to Implement Sorted Doubly Linked List
The SpringJUnitConfig and SpringJUnitWebConfig Annotations in Spring 5
Java IO vs NIO
Redirect to Different Pages after Login with Spring Security
Quick Guide to Spring Bean Scopes
Jackson – Change Name of Field
Java – File to Reader
Java Program to Find the Mode in a Data Set
The Difference Between map() and flatMap()
Java Program to Implement the Program Used in grep/egrep/fgrep
Chuyển đổi từ HashMap sang ArrayList
Guide to the Synchronized Keyword in Java
Custom Error Pages with Spring MVC
Registration with Spring Security – Password Encoding
Java Program to Check Whether an Undirected Graph Contains a Eulerian Cycle
Java Program to Perform Right Rotation on a Binary Search Tree
Explain about URL and HTTPS protocol
Logging a Reactive Sequence
Java Program to Find Transitive Closure of a Graph