home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
vsiftp.vmssoftware.com
/
VSIPUBLIC@vsiftp.vmssoftware.com.tar
/
FREEWARE
/
FREEWARE40.ZIP
/
moonclock
/
src
/
transform.c
< prev
next >
Wrap
Text File
|
1994-02-19
|
2KB
|
113 lines
/*
* transformed coordinate system objects for X
*/
# include <X11/Xlib.h>
# include "transform.h"
static XPoint *
TranslatePoints (points, n_points, t, mode)
TPoint *points;
int n_points;
Transform *t;
int mode;
{
XPoint *xpoints;
int i;
double xoff = 0.0, yoff = 0.0;
xpoints = (XPoint *) malloc (n_points * sizeof (*xpoints));
if (!xpoints)
return 0;
for (i = 0; i < n_points; i++) {
xpoints[i].x = Xx(points[i].x + xoff, points[i].y + yoff, t);
xpoints[i].y = Xy(points[i].x + xoff, points[i].y + yoff, t);
if (mode == CoordModePrevious) {
xoff += points[i].x;
yoff += points[i].y;
}
}
return xpoints;
}
TFillPolygon (dpy, d, gc, t, points, n_points, shape, mode)
register Display *dpy;
Drawable d;
GC gc;
Transform *t;
TPoint *points;
int n_points;
int shape;
int mode;
{
XPoint *xpoints;
xpoints = TranslatePoints (points, n_points, t, mode);
if (xpoints) {
XFillPolygon (dpy, d, gc, xpoints, n_points, shape,
CoordModeOrigin);
free (xpoints);
}
}
TDrawArc (dpy, d, gc, t, x, y, width, height, angle1, angle2)
register Display *dpy;
Drawable d;
GC gc;
Transform *t;
double x, y, width, height;
int angle1, angle2;
{
int xx, xy, xw, xh;
xx = Xx(x,y,t);
xy = Xy(x,y,t);
xw = Xwidth (width, height, t);
xh = Xheight (width, height, t);
if (xw < 0) {
xx += xw;
xw = -xw;
}
if (xh < 0) {
xy += xh;
xh = -xh;
}
XDrawArc (dpy, d, gc, xx, xy, xw, xh, angle1, angle2);
}
TFillArc (dpy, d, gc, t, x, y, width, height, angle1, angle2)
register Display *dpy;
Drawable d;
GC gc;
Transform *t;
double x, y, width, height;
int angle1, angle2;
{
int xx, xy, xw, xh;
xx = Xx(x,y,t);
xy = Xy(x,y,t);
xw = Xwidth (width, height, t);
xh = Xheight (width, height, t);
if (xw < 0) {
xx += xw;
xw = -xw;
}
if (xh < 0) {
xy += xh;
xh = -xh;
}
XFillArc (dpy, d, gc, xx, xy, xw, xh, angle1, angle2);
}
SetTransform (t, xx1, xx2, xy1, xy2, tx1, tx2, ty1, ty2)
Transform *t;
int xx1, xx2, xy1, xy2;
double tx1, tx2, ty1, ty2;
{
t->mx = ((double) xx2 - xx1) / (tx2 - tx1);
t->bx = ((double) xx1) - t->mx * tx1;
t->my = ((double) xy2 - xy1) / (ty2 - ty1);
t->by = ((double) xy1) - t->my * ty1;
}