Graphviz
13.0.0~dev.20250121.0651
Loading...
Searching...
No Matches
makecw.c
Go to the documentation of this file.
1
/*************************************************************************
2
* Copyright (c) 2011 AT&T Intellectual Property
3
* All rights reserved. This program and the accompanying materials
4
* are made available under the terms of the Eclipse Public License v1.0
5
* which accompanies this distribution, and is available at
6
* https://www.eclipse.org/legal/epl-v10.html
7
*
8
* Contributors: Details at https://graphviz.org
9
*************************************************************************/
10
11
/*
12
* Force the vertices of a polygon to be in CW order.
13
*
14
* Works for polygons with concavities.
15
* Does not work for twisted polygons.
16
*
17
* ellson@graphviz.org October 2nd, 1996
18
*/
19
20
#include "
makecw.h
"
21
#include <
pathplan/pathutil.h
>
22
#include <stddef.h>
23
24
void
make_CW
(
Ppoly_t
*
poly
)
25
{
26
Ppoint_t
*P;
27
Ppoint_t
tP;
28
double
area = 0.0;
29
30
P =
poly
->ps;
31
const
size_t
n =
poly
->pn;
32
/* points or lines don't have a rotation */
33
if
(n > 2) {
34
/* check CW or CCW by computing (twice the) area of poly */
35
for
(
size_t
i = 1; i < n - 1; i++) {
36
area +=
area2
(P[0], P[i + 1], P[i]);
37
}
38
/* if the area is -ve then the rotation needs to be reversed */
39
/* the starting point is left unchanged */
40
if
(area < 0.0) {
41
for
(
size_t
i = 1, j = n - 1; i < 1 + n / 2; i++, j--) {
42
tP = P[i];
43
P[i] = P[j];
44
P[j] = tP;
45
}
46
}
47
}
48
}
make_CW
void make_CW(Ppoly_t *poly)
Definition
makecw.c:24
makecw.h
pathutil.h
area2
PATHUTIL_API COORD area2(Ppoint_t, Ppoint_t, Ppoint_t)
Definition
visibility.c:44
Ppoly_t
Definition
pathgeom.h:45
Pxy_t
Definition
pathgeom.h:37
poly_s
Definition
tclpathplan.c:49
tclpkg
tclpathplan
makecw.c
Generated by
1.9.8