home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Dream 48
/
Amiga_Dream_48.iso
/
Atari
/
c
/
libs
/
gemfast
/
gemfut15.lzh
/
AESUTRC2.C
< prev
next >
Wrap
C/C++ Source or Header
|
1989-08-26
|
2KB
|
76 lines
/**************************************************************************
*
* AESFAST PD utilties.
*
* Rectangle utilities 2...
* rc_intersect
*************************************************************************/
#include <gemfast.h>
/*-------------------------------------------------------------------------
* rc_intersect - Compute intersection of 2 GRECT rectangles.
* Returns TRUE if rectanlges have common area, FALSE if not.
*
* (This may not be the best algorithm for doing this, but it seems to
* work. I basically stole it from the GEMQ PD bindings and modified
* it a bit for performance. - Ian)
*-----------------------------------------------------------------------*/
int
rc_intersect(prect1, prect2)
register GRECT *prect1;
register GRECT *prect2;
{
register int w1, w2;
int lx, rx;
int ty, by;
/* calc right-side x as the lesser x of the two rectangles */
w1 = prect1->g_x + prect2->g_w;
w2 = prect2->g_x + prect2->g_w;
rx = (w1 < w2) ? w1 : w2;
/* calc bottom y as the lesser y of the two rectanlges */
w1 = prect1->g_y + prect1->g_h;
w2 = prect2->g_y + prect2->g_h;
by = (w1 < w2) ? w1 : w2;
/* calc left-side x as the greater x of the two rectangles */
w1 = prect1->g_x;
w2 = prect2->g_x;
lx = (w1 > w2) ? w1 : w2;
/* calc top y as the greater y of the two rectangles */
w1 = prect1->g_y;
w2 = prect2->g_y;
ty = (w1 > w2) ? w1 : w2;
/* store the calculated rectangle (converting back to GRECT-type w/h) */
prect2->g_x = lx;
prect2->g_y = ty;
prect2->g_w = rx - lx;
prect2->g_h = by - ty;
/*
* if the calculated width or height is negative, it indicates
* that there is no overlap in at least one dimension, and thus no
* overlap in the rectangles, so return FALSE. if neither value is
* negative, there is a common intersecting area, so return TRUE.
*/
if ( (prect2->g_w < 0) || (prect2->g_h < 0) ) {
return 0;
}
else {
return 1;
}
}