blob: 328ec7cccfd506516358f2dda63e3a468fe16fe3 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.
include <config.h>
include <gki.h>
# GKI_FILLAREA -- Output the fill area instruction.
#
# BOI GKI_FILLAREA L N P
#
# L(i) 4 + (N * 2)
# N(i) number of points defining the polygon to be filled
# P(Np) list of points (x,y pairs)
procedure gki_fillarea (fd, points, npts)
int fd # output file
short points[ARB] # polygon defining area to be filled
int npts # number of (x,y) points in polygon
int epa
short gki[GKI_FILLAREA_LEN]
data gki[1] /BOI/, gki[2] /GKI_FILLAREA/
include "gki.com"
begin
if (IS_INLINE(fd)) {
epa = gk_dd[GKI_FILLAREA]
if (epa != 0)
call zcall2 (epa, points, npts)
} else {
gki[GKI_FILLAREA_L] = GKI_FILLAREA_LEN + (npts * 2)
gki[GKI_FILLAREA_N] = npts
call write (gk_fd[fd], gki, GKI_FILLAREA_LEN * SZ_SHORT)
call write (gk_fd[fd], points, (npts * 2) * SZ_SHORT)
}
end
|