/* $XConsortium: PsArea.c /main/2 1996/11/16 15:24:38 rws $ */ /* * (c) Copyright 1996 Hewlett-Packard Company * (c) Copyright 1996 International Business Machines Corp. * (c) Copyright 1996 Sun Microsystems, Inc. * (c) Copyright 1996 Novell, Inc. * (c) Copyright 1996 Digital Equipment Corp. * (c) Copyright 1996 Fujitsu Limited * (c) Copyright 1996 Hitachi, Ltd. * * Permission is hereby granted, free of charge, to any person obtaining * a copy of this software and associated documentation files (the * "Software"), to deal in the Software without restriction, including * without limitation the rights to use, copy, modify, merge, publish, * distribute, sublicense, and/or sell copies of the Software, and to * permit persons to whom the Software is furnished to do so, subject * to the following conditions: * * 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 COPYRIGHT HOLDERS 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. * * Except as contained in this notice, the names of the copyright holders * shall not be used in advertising or otherwise to promote the sale, use * or other dealings in this Software without prior written authorization * from said copyright holders. */ /******************************************************************* ** ** ********************************************************* ** * ** * File: PsArea.c ** * ** * Contents: Image and Area functions for the PS DDX driver ** * ** * Created By: Roger Helmendach (Liberty Systems) ** * ** * Copyright: Copyright 1996 X Consortium, Inc. ** * ** ********************************************************* ** ********************************************************************/ #include "Ps.h" #include "gcstruct.h" #include "windowstr.h" void PsPutScaledImage(DrawablePtr pDrawable, GCPtr pGC, int depth, int x, int y, int w, int h, int leftPad, int format, int imageRes, char *pImage) { if( pDrawable->type==DRAWABLE_PIXMAP ) { int size = PixmapBytePad(w, depth)*h; DisplayElmPtr elm; PixmapPtr pix = (PixmapPtr)pDrawable; PsPixmapPrivPtr priv = (PsPixmapPrivPtr)pix->devPrivate.ptr; DisplayListPtr disp; GCPtr gc; if ((gc = PsCreateAndCopyGC(pDrawable, pGC)) == NULL) return; disp = PsGetFreeDisplayBlock(priv); elm = &disp->elms[disp->nelms]; elm->type = PutImageCmd; elm->gc = gc; elm->c.image.depth = depth; elm->c.image.x = x; elm->c.image.y = y; elm->c.image.w = w; elm->c.image.h = h; elm->c.image.leftPad = leftPad; elm->c.image.format = format; elm->c.image.res = imageRes; elm->c.image.pData = (char *)xalloc(size); memcpy(elm->c.image.pData, pImage, size); disp->nelms += 1; } else { int i, j; int r, c; int swap; char *pt; PsOutPtr psOut; ColormapPtr cMap; int pageRes, sw, sh; if( PsUpdateDrawableGC(pGC, pDrawable, &psOut, &cMap)==FALSE ) return; if (!imageRes) { sw = w; sh = h; } else { pageRes = XpGetResolution(XpGetPrintContext(requestingClient)); sw = (float)w * (float)pageRes / (float)imageRes + 0.5; sh = (float)h * (float)pageRes / (float)imageRes + 0.5; } PsOut_Offset(psOut, pDrawable->x, pDrawable->y); pt = (char *)(&i); i = 1; if( pt[0]=='\001' ) swap = 1; else swap = 0; if( depth==24 ) { PsOut_BeginImage(psOut, 0, 0, x, y, w, h, sw, sh, 3); if( format==XYPixmap ) { int rowsiz = PixmapBytePad(w, depth); char *planes[3]; planes[0] = pImage; planes[1] = &pImage[rowsiz*h]; planes[2] = &pImage[rowsiz*h*2]; for( r=0 ; rbgPixel), PsGetPixelColor(cMap, pGC->fgPixel), x, y, w, h, sw, sh, 1); for( r=0 ; r>j)&1)<<(7-j)); } else iv_ = iv; c = iv_; PsOut_OutImageBytes(psOut, 1, &c); } } PsOut_EndImage(psOut); } } } error: return; } void PsPutImage(DrawablePtr pDrawable, GCPtr pGC, int depth, int x, int y, int w, int h, int leftPad, int format, char *pImage) { XpContextPtr pcon; if (requestingClient && (pcon = XpGetPrintContext(requestingClient))) PsPutScaledImage(pDrawable, pGC, depth, x, y, w, h, leftPad, format, pcon->imageRes, pImage); } RegionPtr PsCopyArea(DrawablePtr pSrc, DrawablePtr pDst, GCPtr pGC, int srcx, int srcy, int width, int height, int dstx, int dsty) { PixmapPtr src = (PixmapPtr)pSrc; PixmapPtr dst = (PixmapPtr)pDst; if( pSrc->type!=DRAWABLE_PIXMAP ) return NULL; if( pDst->type!=DRAWABLE_PIXMAP ) { PsOutPtr psOut; ColormapPtr cMap; if( PsUpdateDrawableGC(pGC, pDst, &psOut, &cMap)==FALSE ) return NULL; PsOut_Offset(psOut, pDst->x, pDst->y); PsOut_BeginFrame(psOut, dstx-srcx, dsty-srcy, dstx, dsty, width, height); PsReplayPixmap(src, pDst); PsOut_EndFrame(psOut); } else PsCopyDisplayList(src, dst, dstx-srcx, dsty-srcy, dstx, dsty, width, height); return NULL; } RegionPtr PsCopyPlane(DrawablePtr pSrc, DrawablePtr pDst, GCPtr pGC, int srcx, int srcy, int width, int height, int dstx, int dsty, unsigned long plane) { PixmapPtr src = (PixmapPtr)pSrc; PixmapPtr dst = (PixmapPtr)pDst; if( pSrc->type!=DRAWABLE_PIXMAP ) return NULL; if( pDst->type!=DRAWABLE_PIXMAP ) { PsOutPtr psOut; ColormapPtr cMap; if( PsUpdateDrawableGC(pGC, pDst, &psOut, &cMap)==FALSE ) return NULL; PsOut_Offset(psOut, pDst->x, pDst->y); PsOut_BeginFrame(psOut, dstx-srcx, dsty-srcy, dstx, dsty, width, height); PsReplayPixmap(src, pDst); PsOut_EndFrame(psOut); } else PsCopyDisplayList(src, dst, dstx-srcx, dsty-srcy, dstx, dsty, width, height); return NULL; }