mipolyrect.c revision 05b261ec
105b261ecSmrg/***********************************************************
205b261ecSmrg
305b261ecSmrgCopyright 1987, 1998  The Open Group
405b261ecSmrg
505b261ecSmrgPermission to use, copy, modify, distribute, and sell this software and its
605b261ecSmrgdocumentation for any purpose is hereby granted without fee, provided that
705b261ecSmrgthe above copyright notice appear in all copies and that both that
805b261ecSmrgcopyright notice and this permission notice appear in supporting
905b261ecSmrgdocumentation.
1005b261ecSmrg
1105b261ecSmrgThe above copyright notice and this permission notice shall be included in
1205b261ecSmrgall copies or substantial portions of the Software.
1305b261ecSmrg
1405b261ecSmrgTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
1505b261ecSmrgIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
1605b261ecSmrgFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
1705b261ecSmrgOPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
1805b261ecSmrgAN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
1905b261ecSmrgCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
2005b261ecSmrg
2105b261ecSmrgExcept as contained in this notice, the name of The Open Group shall not be
2205b261ecSmrgused in advertising or otherwise to promote the sale, use or other dealings
2305b261ecSmrgin this Software without prior written authorization from The Open Group.
2405b261ecSmrg
2505b261ecSmrg
2605b261ecSmrgCopyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts.
2705b261ecSmrg
2805b261ecSmrg                        All Rights Reserved
2905b261ecSmrg
3005b261ecSmrgPermission to use, copy, modify, and distribute this software and its
3105b261ecSmrgdocumentation for any purpose and without fee is hereby granted,
3205b261ecSmrgprovided that the above copyright notice appear in all copies and that
3305b261ecSmrgboth that copyright notice and this permission notice appear in
3405b261ecSmrgsupporting documentation, and that the name of Digital not be
3505b261ecSmrgused in advertising or publicity pertaining to distribution of the
3605b261ecSmrgsoftware without specific, written prior permission.
3705b261ecSmrg
3805b261ecSmrgDIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
3905b261ecSmrgALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
4005b261ecSmrgDIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
4105b261ecSmrgANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
4205b261ecSmrgWHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
4305b261ecSmrgARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
4405b261ecSmrgSOFTWARE.
4505b261ecSmrg
4605b261ecSmrg******************************************************************/
4705b261ecSmrg#ifdef HAVE_DIX_CONFIG_H
4805b261ecSmrg#include <dix-config.h>
4905b261ecSmrg#endif
5005b261ecSmrg
5105b261ecSmrg#include <X11/X.h>
5205b261ecSmrg#include <X11/Xprotostr.h>
5305b261ecSmrg#include "regionstr.h"
5405b261ecSmrg#include "gcstruct.h"
5505b261ecSmrg#include "pixmap.h"
5605b261ecSmrg#include "mi.h"
5705b261ecSmrg
5805b261ecSmrg_X_EXPORT void
5905b261ecSmrgmiPolyRectangle(pDraw, pGC, nrects, pRects)
6005b261ecSmrg    DrawablePtr	pDraw;
6105b261ecSmrg    GCPtr	pGC;
6205b261ecSmrg    int		nrects;
6305b261ecSmrg    xRectangle	*pRects;
6405b261ecSmrg{
6505b261ecSmrg    int i;
6605b261ecSmrg    xRectangle *pR = pRects;
6705b261ecSmrg    DDXPointRec rect[5];
6805b261ecSmrg    int	    bound_tmp;
6905b261ecSmrg
7005b261ecSmrg#define MINBOUND(dst,eqn)	bound_tmp = eqn; \
7105b261ecSmrg				if (bound_tmp < -32768) \
7205b261ecSmrg				    bound_tmp = -32768; \
7305b261ecSmrg				dst = bound_tmp;
7405b261ecSmrg
7505b261ecSmrg#define MAXBOUND(dst,eqn)	bound_tmp = eqn; \
7605b261ecSmrg				if (bound_tmp > 32767) \
7705b261ecSmrg				    bound_tmp = 32767; \
7805b261ecSmrg				dst = bound_tmp;
7905b261ecSmrg
8005b261ecSmrg#define MAXUBOUND(dst,eqn)	bound_tmp = eqn; \
8105b261ecSmrg				if (bound_tmp > 65535) \
8205b261ecSmrg				    bound_tmp = 65535; \
8305b261ecSmrg				dst = bound_tmp;
8405b261ecSmrg
8505b261ecSmrg    if (pGC->lineStyle == LineSolid && pGC->joinStyle == JoinMiter &&
8605b261ecSmrg	pGC->lineWidth != 0)
8705b261ecSmrg    {
8805b261ecSmrg	xRectangle  *tmp, *t;
8905b261ecSmrg	int	    ntmp;
9005b261ecSmrg	int	    offset1, offset2, offset3;
9105b261ecSmrg	int	    x, y, width, height;
9205b261ecSmrg
9305b261ecSmrg	ntmp = (nrects << 2);
9405b261ecSmrg	offset2 = pGC->lineWidth;
9505b261ecSmrg	offset1 = offset2 >> 1;
9605b261ecSmrg	offset3 = offset2 - offset1;
9705b261ecSmrg	tmp = (xRectangle *) ALLOCATE_LOCAL(ntmp * sizeof (xRectangle));
9805b261ecSmrg	if (!tmp)
9905b261ecSmrg	    return;
10005b261ecSmrg	t = tmp;
10105b261ecSmrg	for (i = 0; i < nrects; i++)
10205b261ecSmrg	{
10305b261ecSmrg	    x = pR->x;
10405b261ecSmrg	    y = pR->y;
10505b261ecSmrg	    width = pR->width;
10605b261ecSmrg	    height = pR->height;
10705b261ecSmrg	    pR++;
10805b261ecSmrg	    if (width == 0 && height == 0)
10905b261ecSmrg	    {
11005b261ecSmrg		rect[0].x = x;
11105b261ecSmrg		rect[0].y = y;
11205b261ecSmrg		rect[1].x = x;
11305b261ecSmrg		rect[1].y = y;
11405b261ecSmrg		(*pGC->ops->Polylines)(pDraw, pGC, CoordModeOrigin, 2, rect);
11505b261ecSmrg	    }
11605b261ecSmrg	    else if (height < offset2 || width < offset1)
11705b261ecSmrg	    {
11805b261ecSmrg		if (height == 0)
11905b261ecSmrg		{
12005b261ecSmrg		    t->x = x;
12105b261ecSmrg		    t->width = width;
12205b261ecSmrg		}
12305b261ecSmrg		else
12405b261ecSmrg		{
12505b261ecSmrg		    MINBOUND (t->x, x - offset1)
12605b261ecSmrg		    MAXUBOUND (t->width, width + offset2)
12705b261ecSmrg		}
12805b261ecSmrg		if (width == 0)
12905b261ecSmrg		{
13005b261ecSmrg		    t->y = y;
13105b261ecSmrg		    t->height = height;
13205b261ecSmrg		}
13305b261ecSmrg		else
13405b261ecSmrg		{
13505b261ecSmrg		    MINBOUND (t->y, y - offset1)
13605b261ecSmrg		    MAXUBOUND (t->height, height + offset2)
13705b261ecSmrg		}
13805b261ecSmrg		t++;
13905b261ecSmrg	    }
14005b261ecSmrg	    else
14105b261ecSmrg	    {
14205b261ecSmrg		MINBOUND(t->x, x - offset1)
14305b261ecSmrg		MINBOUND(t->y, y - offset1)
14405b261ecSmrg		MAXUBOUND(t->width, width + offset2)
14505b261ecSmrg	    	t->height = offset2;
14605b261ecSmrg	    	t++;
14705b261ecSmrg	    	MINBOUND(t->x, x - offset1)
14805b261ecSmrg	    	MAXBOUND(t->y, y + offset3);
14905b261ecSmrg	    	t->width = offset2;
15005b261ecSmrg	    	t->height = height - offset2;
15105b261ecSmrg	    	t++;
15205b261ecSmrg	    	MAXBOUND(t->x, x + width - offset1);
15305b261ecSmrg	    	MAXBOUND(t->y, y + offset3)
15405b261ecSmrg	    	t->width = offset2;
15505b261ecSmrg	    	t->height = height - offset2;
15605b261ecSmrg	    	t++;
15705b261ecSmrg	    	MINBOUND(t->x, x - offset1)
15805b261ecSmrg	    	MAXBOUND(t->y, y + height - offset1)
15905b261ecSmrg	    	MAXUBOUND(t->width, width + offset2)
16005b261ecSmrg	    	t->height = offset2;
16105b261ecSmrg	    	t++;
16205b261ecSmrg	    }
16305b261ecSmrg	}
16405b261ecSmrg	(*pGC->ops->PolyFillRect) (pDraw, pGC, t - tmp, tmp);
16505b261ecSmrg	DEALLOCATE_LOCAL ((pointer) tmp);
16605b261ecSmrg    }
16705b261ecSmrg    else
16805b261ecSmrg    {
16905b261ecSmrg
17005b261ecSmrg    	for (i=0; i<nrects; i++)
17105b261ecSmrg    	{
17205b261ecSmrg	    rect[0].x = pR->x;
17305b261ecSmrg	    rect[0].y = pR->y;
17405b261ecSmrg
17505b261ecSmrg	    MAXBOUND(rect[1].x, pR->x + (int) pR->width)
17605b261ecSmrg	    rect[1].y = rect[0].y;
17705b261ecSmrg
17805b261ecSmrg	    rect[2].x = rect[1].x;
17905b261ecSmrg	    MAXBOUND(rect[2].y, pR->y + (int) pR->height);
18005b261ecSmrg
18105b261ecSmrg	    rect[3].x = rect[0].x;
18205b261ecSmrg	    rect[3].y = rect[2].y;
18305b261ecSmrg
18405b261ecSmrg	    rect[4].x = rect[0].x;
18505b261ecSmrg	    rect[4].y = rect[0].y;
18605b261ecSmrg
18705b261ecSmrg            (*pGC->ops->Polylines)(pDraw, pGC, CoordModeOrigin, 5, rect);
18805b261ecSmrg	    pR++;
18905b261ecSmrg    	}
19005b261ecSmrg    }
19105b261ecSmrg}
192