Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to determine whether a point (X,Y) is contained within an arc section of a circle (i.e. a Pie slice)?

Tags:

Imagine a circle. Imagine a pie. Imagine trying to return a bool that determines whether the provided parameters of X, Y are contained within one of those pie pieces.

What I know about the arc:

I have the CenterX, CenterY, Radius, StartingAngle, EndingAngle, StartingPoint (point on circumference), EndingPoint (point on circumference).

Given a coordinate of X,Y, I'd like to determine if this coordinate is contained anywhere within the pie slide.

like image 777
AlishahNovin Avatar asked Jun 07 '11 19:06

AlishahNovin


2 Answers

Check:

  1. The angle from the centerX,centerY through X,Y should be between start&endangle.
  2. The distance from centerX,centerY to X,Y should be less then the Radius

And you'll have your answer.

like image 101
Wrikken Avatar answered Sep 20 '22 13:09

Wrikken


I know this question is old but none of the answers consider the placement of the arc on the circle.

This algorithm considers that all angles are between 0 and 360, and the arcs are drawn in positive mathematical direction (counter-clockwise)

First you can transform to polar coordinates: radius (R) and angle (A). Note: use Atan2 function if available. wiki

R = sqrt ((X - CenterX)^2 + (Y - CenterY)^2)

A = atan2 (Y - CenterY, X - CenterX)

Now if R < Radius the point is inside the circle.

To check if the angle is between StartingAngle (S) and EndingAngle (E) you need to consider two possibilities:

1) if S < E then if S < A < E the point lies inside the slice

image 1

2) if S > E then there are 2 possible scenarios

image 2

  • if A > S

then the point lies inside the slice

image 3

  • if A < E

then the point lies inside the slice

image 4

In all other cases the point lies outside the slice.

like image 28
user7048690 Avatar answered Sep 21 '22 13:09

user7048690