Graphviz
2.41.20171026.1811
Main Page
Data Structures
Files
File List
Globals
lib
pathplan
inpoly.c
Go to the documentation of this file.
1
/* $Id$ $Revision$ */
2
/* vim:set shiftwidth=4 ts=8: */
3
4
/*************************************************************************
5
* Copyright (c) 2011 AT&T Intellectual Property
6
* All rights reserved. This program and the accompanying materials
7
* are made available under the terms of the Eclipse Public License v1.0
8
* which accompanies this distribution, and is available at
9
* http://www.eclipse.org/legal/epl-v10.html
10
*
11
* Contributors: See CVS logs. Details at http://www.graphviz.org/
12
*************************************************************************/
13
14
/*
15
* in_poly
16
*
17
* Test if a point is inside a polygon.
18
* The polygon must be convex with vertices in CW order.
19
*/
20
21
#include <stdlib.h>
22
#include "
vispath.h
"
23
#include "
pathutil.h
"
24
25
#ifdef DMALLOC
26
#include "dmalloc.h"
27
#endif
28
29
int
in_poly
(
Ppoly_t
poly,
Ppoint_t
q)
30
{
31
int
i, i1;
/* point index; i1 = i-1 mod n */
32
int
n;
33
Ppoint_t
*P;
34
35
P = poly.
ps
;
36
n = poly.
pn
;
37
for
(i = 0; i < n; i++) {
38
i1 = (i + n - 1) % n;
39
if
(
wind
(P[i1],P[i],q) == 1)
return
FALSE
;
40
}
41
return
TRUE
;
42
}
Ppoly_t::pn
int pn
Definition:
pathgeom.h:36
in_poly
int in_poly(Ppoly_t argpoly, Ppoint_t q)
Definition:
inpoly.c:29
pathutil.h
wind
int wind(Ppoint_t a, Ppoint_t b, Ppoint_t c)
Definition:
visibility.c:65
Ppoly_t::ps
Ppoint_t * ps
Definition:
pathgeom.h:35
Pxy_t
Definition:
pathgeom.h:26
vispath.h
FALSE
#define FALSE
Definition:
cgraph.h:35
Ppoly_t
Definition:
pathgeom.h:34
TRUE
#define TRUE
Definition:
cgraph.h:38
Generated by
1.8.5