2013-07-13 07:56:15 +08:00
|
|
|
/*
|
2014-01-18 09:37:09 +08:00
|
|
|
Copyright 2005-2014 Jay Sorg
|
2013-07-13 07:56:15 +08:00
|
|
|
|
|
|
|
Permission to use, copy, modify, distribute, and sell this software and its
|
|
|
|
documentation for any purpose is hereby granted without fee, provided that
|
|
|
|
the above copyright notice appear in all copies and that both that
|
|
|
|
copyright notice and this permission notice appear in supporting
|
|
|
|
documentation.
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
|
|
|
AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
|
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
2013-07-24 11:57:38 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
/* this should be before all X11 .h files */
|
|
|
|
#include <xorg-server.h>
|
|
|
|
|
|
|
|
/* all driver need this */
|
|
|
|
#include <xf86.h>
|
|
|
|
#include <xf86_OSproc.h>
|
|
|
|
|
2013-07-13 13:36:16 +08:00
|
|
|
#include "rdp.h"
|
|
|
|
#include "rdpDraw.h"
|
2014-01-25 02:00:52 +08:00
|
|
|
#include "rdpClientCon.h"
|
|
|
|
#include "rdpReg.h"
|
2013-07-13 13:36:16 +08:00
|
|
|
|
|
|
|
#define LOG_LEVEL 1
|
|
|
|
#define LLOGLN(_level, _args) \
|
|
|
|
do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0)
|
|
|
|
|
2014-01-25 02:00:52 +08:00
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
rdpFillPolygonPre(rdpPtr dev, rdpClientCon *clientCon,
|
|
|
|
int cd, RegionPtr clip_reg,
|
|
|
|
DrawablePtr pDrawable, GCPtr pGC,
|
|
|
|
int shape, int mode, int count,
|
|
|
|
DDXPointPtr pPts, BoxPtr box)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2013-07-13 13:36:16 +08:00
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
rdpFillPolygonOrg(DrawablePtr pDrawable, GCPtr pGC,
|
|
|
|
int shape, int mode, int count,
|
|
|
|
DDXPointPtr pPts)
|
|
|
|
{
|
2013-07-31 15:41:44 +08:00
|
|
|
GC_OP_VARS;
|
2013-07-13 13:36:16 +08:00
|
|
|
|
|
|
|
GC_OP_PROLOGUE(pGC);
|
|
|
|
pGC->ops->FillPolygon(pDrawable, pGC, shape, mode, count, pPts);
|
|
|
|
GC_OP_EPILOGUE(pGC);
|
|
|
|
}
|
|
|
|
|
2014-01-25 02:00:52 +08:00
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
rdpFillPolygonPost(rdpPtr dev, rdpClientCon *clientCon,
|
|
|
|
int cd, RegionPtr clip_reg,
|
|
|
|
DrawablePtr pDrawable, GCPtr pGC,
|
|
|
|
int shape, int mode, int count,
|
|
|
|
DDXPointPtr pPts, BoxPtr box)
|
|
|
|
{
|
|
|
|
RegionRec reg;
|
|
|
|
|
|
|
|
if (cd == XRDP_CD_NODRAW)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (!XRDP_DRAWABLE_IS_VISIBLE(dev, pDrawable))
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
rdpRegionInit(®, box, 0);
|
|
|
|
if (cd == XRDP_CD_CLIP)
|
|
|
|
{
|
|
|
|
rdpRegionIntersect(®, clip_reg, ®);
|
|
|
|
}
|
|
|
|
rdpClientConAddDirtyScreenReg(dev, clientCon, ®);
|
|
|
|
rdpRegionUninit(®);
|
|
|
|
}
|
|
|
|
|
2013-07-13 13:36:16 +08:00
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
rdpFillPolygon(DrawablePtr pDrawable, GCPtr pGC,
|
|
|
|
int shape, int mode, int count,
|
|
|
|
DDXPointPtr pPts)
|
|
|
|
{
|
2014-01-25 02:00:52 +08:00
|
|
|
rdpPtr dev;
|
|
|
|
rdpClientCon *clientCon;
|
|
|
|
RegionRec clip_reg;
|
|
|
|
int cd;
|
|
|
|
int maxx;
|
|
|
|
int maxy;
|
|
|
|
int minx;
|
|
|
|
int miny;
|
|
|
|
int index;
|
|
|
|
int x;
|
|
|
|
int y;
|
|
|
|
BoxRec box;
|
|
|
|
|
|
|
|
LLOGLN(10, ("rdpFillPolygon:"));
|
|
|
|
dev = rdpGetDevFromScreen(pGC->pScreen);
|
|
|
|
dev->counts.rdpFillPolygonCallCount++;
|
|
|
|
box.x1 = 0;
|
|
|
|
box.y1 = 0;
|
|
|
|
box.x2 = 0;
|
|
|
|
box.y2 = 0;
|
|
|
|
if (count > 0)
|
|
|
|
{
|
|
|
|
maxx = pPts[0].x;
|
|
|
|
maxy = pPts[0].y;
|
|
|
|
minx = maxx;
|
|
|
|
miny = maxy;
|
|
|
|
for (index = 1; index < count; index++)
|
|
|
|
{
|
|
|
|
x = pPts[index].x;
|
|
|
|
y = pPts[index].y;
|
|
|
|
maxx = RDPMAX(x, maxx);
|
|
|
|
minx = RDPMIN(x, minx);
|
|
|
|
maxy = RDPMAX(y, maxy);
|
|
|
|
miny = RDPMIN(y, miny);
|
|
|
|
}
|
|
|
|
box.x1 = pDrawable->x + minx;
|
|
|
|
box.y1 = pDrawable->y + miny;
|
|
|
|
box.x2 = pDrawable->x + maxx + 1;
|
|
|
|
box.y2 = pDrawable->y + maxy + 1;
|
|
|
|
}
|
|
|
|
rdpRegionInit(&clip_reg, NullBox, 0);
|
|
|
|
cd = rdpDrawGetClip(dev, &clip_reg, pDrawable, pGC);
|
|
|
|
LLOGLN(10, ("rdpFillPolygon: cd %d", cd));
|
|
|
|
clientCon = dev->clientConHead;
|
|
|
|
while (clientCon != NULL)
|
|
|
|
{
|
|
|
|
rdpFillPolygonPre(dev, clientCon, cd, &clip_reg, pDrawable, pGC,
|
|
|
|
shape, mode, count, pPts, &box);
|
|
|
|
clientCon = clientCon->next;
|
|
|
|
}
|
2013-07-13 13:36:16 +08:00
|
|
|
/* do original call */
|
|
|
|
rdpFillPolygonOrg(pDrawable, pGC, shape, mode, count, pPts);
|
2014-01-25 02:00:52 +08:00
|
|
|
clientCon = dev->clientConHead;
|
|
|
|
while (clientCon != NULL)
|
|
|
|
{
|
|
|
|
rdpFillPolygonPost(dev, clientCon, cd, &clip_reg, pDrawable, pGC,
|
|
|
|
shape, mode, count, pPts, &box);
|
|
|
|
clientCon = clientCon->next;
|
|
|
|
}
|
|
|
|
rdpRegionUninit(&clip_reg);
|
2013-07-13 13:36:16 +08:00
|
|
|
}
|