Release 940405
[wine/gsoc-2012-control.git] / misc / rect.c
blobb5c0fc5acd7e5ecef70e62a432affaf082ee4162
1 /*
2 * Rectangle-related functions
4 * Copyright 1993 Alexandre Julliard
5 */
7 static char Copyright[] = "Copyright Alexandre Julliard, 1993";
9 #include "windows.h"
11 #define MIN(a,b) ((a) < (b) ? (a) : (b))
12 #define MAX(a,b) ((a) > (b) ? (a) : (b))
15 /***********************************************************************
16 * SetRect (USER.72)
18 void SetRect( LPRECT rect, short left, short top, short right, short bottom )
20 rect->left = left;
21 rect->right = right;
22 rect->top = top;
23 rect->bottom = bottom;
27 /***********************************************************************
28 * SetRectEmpty (USER.73)
30 void SetRectEmpty( LPRECT rect )
32 rect->left = rect->right = rect->top = rect->bottom = 0;
36 /***********************************************************************
37 * CopyRect (USER.74)
39 void CopyRect( LPRECT dest, LPRECT src )
41 *dest = *src;
45 /***********************************************************************
46 * IsRectEmpty (USER.75)
48 BOOL IsRectEmpty( LPRECT rect )
50 return ((rect->left == rect->right) || (rect->top == rect->bottom));
54 /***********************************************************************
55 * PtInRect (USER.76)
57 BOOL PtInRect( LPRECT rect, POINT pt )
59 return ((pt.x >= rect->left) && (pt.x < rect->right) &&
60 (pt.y >= rect->top) && (pt.y < rect->bottom));
64 /***********************************************************************
65 * OffsetRect (USER.77)
67 void OffsetRect( LPRECT rect, short x, short y )
69 rect->left += x;
70 rect->right += x;
71 rect->top += y;
72 rect->bottom += y;
76 /***********************************************************************
77 * InflateRect (USER.78)
79 void InflateRect( LPRECT rect, short x, short y )
81 rect->left -= x;
82 rect->top -= y;
83 rect->right += x;
84 rect->bottom += y;
88 /***********************************************************************
89 * IntersectRect (USER.79)
91 BOOL IntersectRect( LPRECT dest, LPRECT src1, LPRECT src2 )
93 if (IsRectEmpty(src1) || IsRectEmpty(src2) ||
94 (src1->left >= src2->right) || (src2->left >= src1->right) ||
95 (src1->top >= src2->bottom) || (src2->top >= src1->bottom))
97 SetRectEmpty( dest );
98 return FALSE;
100 dest->left = MAX( src1->left, src2->left );
101 dest->right = MIN( src1->right, src2->right );
102 dest->top = MAX( src1->top, src2->top );
103 dest->bottom = MIN( src1->bottom, src2->bottom );
104 return TRUE;
108 /***********************************************************************
109 * UnionRect (USER.80)
111 BOOL UnionRect( LPRECT dest, LPRECT src1, LPRECT src2 )
113 if (IsRectEmpty(src1))
115 if (IsRectEmpty(src2))
117 SetRectEmpty( dest );
118 return FALSE;
120 else *dest = *src2;
122 else
124 if (IsRectEmpty(src2)) *dest = *src1;
125 else
127 dest->left = MIN( src1->left, src2->left );
128 dest->right = MAX( src1->right, src2->right );
129 dest->top = MIN( src1->top, src2->top );
130 dest->bottom = MAX( src1->bottom, src2->bottom );
133 return TRUE;
137 /***********************************************************************
138 * EqualRect (USER.244)
140 BOOL EqualRect( LPRECT rect1, LPRECT rect2 )
142 return ((rect1->left == rect2->left) && (rect1->right == rect2->right) &&
143 (rect1->top == rect2->top) && (rect1->bottom == rect2->bottom));
147 /***********************************************************************
148 * SubtractRect (USER.373)
150 BOOL SubtractRect( LPRECT dest, LPRECT src1, LPRECT src2 )
152 RECT tmp;
154 if (IsRectEmpty( src1 ))
156 SetRectEmpty( dest );
157 return FALSE;
159 *dest = *src1;
160 if (IntersectRect( &tmp, src1, src2 ))
162 if (EqualRect( &tmp, dest ))
164 SetRectEmpty( dest );
165 return FALSE;
167 if ((tmp.top == dest->top) && (tmp.bottom == dest->bottom))
169 if (tmp.left == dest->left) dest->left = tmp.right;
170 else if (tmp.right == dest->right) dest->right = tmp.left;
172 else if ((tmp.left == dest->left) && (tmp.right == dest->right))
174 if (tmp.top == dest->top) dest->top = tmp.bottom;
175 else if (tmp.bottom == dest->bottom) dest->bottom = tmp.top;
178 return TRUE;