/* Copyright (C) 2000, 2003 Free Software Foundation This file is part of libgcj. This software is copyrighted work licensed under the terms of the Libgcj License. Please consult the file "LIBGCJ_LICENSE" for details. */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include typedef java::awt::Rectangle AWTRect; typedef JArray AWTRectArray; typedef std::vector XRectVector; void gnu::gcj::xlib::GC::initStructure(GC* copyFrom) { Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::GC gc = (::GC) structure; if (gc == 0) { // If we haven't already created a GC, create one now ::Drawable drawableXID = target->getXID(); gc = XCreateGC(dpy, drawableXID, 0, 0); structure = reinterpret_cast(gc); if (gc == 0) throw new XException(JvNewStringLatin1("GC creation failed")); } if (copyFrom != 0) { ::GC fromGC = (::GC) copyFrom->structure; XCopyGC(dpy, fromGC, ~0, gc); // no fast fail } } void gnu::gcj::xlib::GC::disposeImpl() { gnu::gcj::RawData* lStructure = structure; Drawable* lTargetType = target; if ((lStructure == 0) || (lTargetType == 0)) return; structure = 0; target = 0; Display* display = lTargetType->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::GC gc = (::GC) lStructure; XFreeGC(dpy, gc); // no fast fail } void gnu::gcj::xlib::GC::setForeground(jlong pixel) { Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::GC gc = (::GC) structure; XSetForeground(dpy, gc, pixel); // no fast fail } void gnu::gcj::xlib::GC::setFont(Font* font) { Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::GC gc = (::GC) structure; XSetFont(dpy, gc, font->getXID()); // no fast fail } void gnu::gcj::xlib::GC::drawString(jstring text, jint x, jint y) { Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::Drawable drawableXID = target->getXID(); ::GC gc = (::GC) structure; jint length = text->length(); jchar* txt = JvGetStringChars(text); XChar2b xwchars[length]; // FIXME: Convert to the character set used in the font, which may // or may not be unicode. For now, treat everything as 16-bit and // use character codes directly, which should be OK for unicode or // 8-bit ascii fonts. for (int i=0; ibyte1 = (jc >> 8) & 0xff; xc->byte2 = jc & 0xff; } XDrawString16(dpy, drawableXID, gc, x, y, xwchars, length); } void gnu::gcj::xlib::GC::drawLine(jint x1, jint y1, jint x2, jint y2) { Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::Drawable drawableXID = target->getXID(); ::GC gc = (::GC) structure; XDrawLine(dpy, drawableXID, gc, x1, y1, x2, y2); // no fast fail } void gnu::gcj::xlib::GC::drawRectangle(jint x, jint y, jint w, jint h) { Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::Drawable drawableXID = target->getXID(); ::GC gc = (::GC) structure; XDrawRectangle(dpy, drawableXID, gc, x, y, w, h); // no fast fail } void gnu::gcj::xlib::GC::fillRectangle(jint x, jint y, jint w, jint h) { Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::Drawable drawableXID = target->getXID(); ::GC gc = (::GC) structure; XFillRectangle(dpy, drawableXID, gc, x, y, w, h); // no fast fail } void gnu::gcj::xlib::GC::drawArc(jint x, jint y, jint w, jint h,jint startAngle, jint arcAngle) { Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::Drawable drawableXID = target->getXID(); ::GC gc = (::GC) structure; XDrawArc(dpy, drawableXID, gc, x, y, w, h, startAngle * 64, arcAngle * 64); } void gnu::gcj::xlib::GC::fillArc(jint x, jint y, jint w, jint h,jint startAngle, jint arcAngle) { Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::Drawable drawableXID = target->getXID(); ::GC gc = (::GC) structure; XFillArc(dpy, drawableXID, gc, x, y, w, h, startAngle * 64, arcAngle * 64); } void gnu::gcj::xlib::GC::fillPolygon(jintArray xPoints, jintArray yPoints, jint nPoints, jint translateX, jint translateY) { Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::Drawable drawableXID = target->getXID(); ::GC gc = (::GC) structure; typedef ::XPoint xpoint; std::vector points(nPoints+1); for (int i=0; igetDisplay(); ::Display* dpy = (::Display*) (display->display); ::Drawable drawableXID = target->getXID(); XClearArea(dpy, drawableXID, x, y, w, h, exposures ? True : False); // no fast fail } void gnu::gcj::xlib::GC::putImage(XImage* image, jint srcX, jint srcY, jint destX, jint destY, jint width, jint height) { Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::Drawable drawableXID = target->getXID(); ::GC gc = (::GC) structure; ::XImage* ximage = (::XImage*) (image->structure); XPutImage(dpy, drawableXID, gc, ximage, srcX, srcY, destX, destY, width, height); // no fast fail } void gnu::gcj::xlib::GC::updateClip() { if (clip == 0) return; Display* display = target->getDisplay(); ::Display* dpy = (::Display*) (display->display); ::GC gc = (::GC) structure; XRectVector* xrectvector = (XRectVector*) (clip->xrects); int numRect = xrectvector->size(); int originX = 0; int originY = 0; int ordering = Unsorted; XSetClipRectangles(dpy, gc, originX, originY, &(xrectvector->front()), numRect, ordering); // no fast fail } void gnu::gcj::xlib::GC::copyArea (gnu::gcj::xlib::Drawable * source, jint srcX, jint srcY, jint destX, jint destY, jint width, jint height) { Display* display = target->getDisplay (); ::Display* dpy = (::Display*) (display->display); ::Drawable drawableXID = target->getXID (); ::GC gc = (::GC) structure; ::Drawable srcXID = source->getXID (); XCopyArea (dpy, srcXID, drawableXID, gc, srcX, srcY, width, height, destX, destY); }