diff options
Diffstat (limited to 'tqtinterface/qt4/src/kernel/tqpaintdevice_x11.cpp')
-rw-r--r-- | tqtinterface/qt4/src/kernel/tqpaintdevice_x11.cpp | 1751 |
1 files changed, 0 insertions, 1751 deletions
diff --git a/tqtinterface/qt4/src/kernel/tqpaintdevice_x11.cpp b/tqtinterface/qt4/src/kernel/tqpaintdevice_x11.cpp deleted file mode 100644 index de0695f..0000000 --- a/tqtinterface/qt4/src/kernel/tqpaintdevice_x11.cpp +++ /dev/null @@ -1,1751 +0,0 @@ -/**************************************************************************** -** -** Implementation of TQPaintDevice class for X11 -** -** Created : 940721 -** -** Copyright (C) 2010 Timothy Pearson and (C) 1992-2008 Trolltech ASA. -** -** This file is part of the kernel module of the TQt GUI Toolkit. -** -** This file may be used under the terms of the GNU General -** Public License versions 2.0 or 3.0 as published by the Free -** Software Foundation and appearing in the files LICENSE.GPL2 -** and LICENSE.GPL3 included in the packaging of this file. -** Alternatively you may (at your option) use any later version -** of the GNU General Public License if such license has been -** publicly approved by Trolltech ASA (or its successors, if any) -** and the KDE Free TQt Foundation. -** -** Please review the following information to ensure GNU General -** Public Licensing requirements will be met: -** http://trolltech.com/products/qt/licenses/licensing/opensource/. -** If you are unsure which license is appropriate for your use, please -** review the following information: -** http://trolltech.com/products/qt/licenses/licensing/licensingoverview -** or contact the sales department at sales@trolltech.com. -** -** This file may be used under the terms of the Q Public License as -** defined by Trolltech ASA and appearing in the file LICENSE.TQPL -** included in the packaging of this file. Licensees holding valid TQt -** Commercial licenses may use this file in accordance with the TQt -** Commercial License Agreement provided with the Software. -** -** This file is provided "AS IS" with NO WARRANTY OF ANY KIND, -** INCLUDING THE WARRANTIES OF DESIGN, MERCHANTABILITY AND FITNESS FOR -** A PARTICULAR PURPOSE. Trolltech reserves all rights not granted -** herein. -** -**********************************************************************/ - -#include "tqpaintdevice.h" -#include "tqpaintdevicemetrics.h" -#include "tqpainter.h" -#include "tqwidget.h" -#include "tqbitmap.h" -#include "tqapplication.h" -#include "tqt_x11_p.h" - -#ifdef USE_QT4 - -// -// Some global variables - these are initialized by TQColor::initialize() -// - -Display *TQPaintDevice::x_appdisplay = 0; -int TQPaintDevice::x_appscreen; - -int TQPaintDevice::x_appdepth; -int TQPaintDevice::x_appcells; -TQt::HANDLE TQPaintDevice::x_approotwindow; -TQt::HANDLE TQPaintDevice::x_appcolormap; -bool TQPaintDevice::x_appdefcolormap; -void *TQPaintDevice::x_appvisual; -bool TQPaintDevice::x_appdefvisual; - -// ### in 4.0, remove the above, and use the below -int *TQPaintDevice::x_appdepth_arr; -int *TQPaintDevice::x_appcells_arr; -TQt::HANDLE *TQPaintDevice::x_approotwindow_arr; -TQt::HANDLE *TQPaintDevice::x_appcolormap_arr; -bool *TQPaintDevice::x_appdefcolormap_arr; -void **TQPaintDevice::x_appvisual_arr; -bool *TQPaintDevice::x_appdefvisual_arr; - -/*! - Constructs a paint tqdevice with internal flags \a devflags. This - constructor can be invoked only from TQPaintDevice subclasses. -*/ - -TQPaintDevice::TQPaintDevice( uint devflags ) -{ - if ( !tqApp ) { // global constructor -#if defined(TQT_CHECK_STATE) - qFatal( "TQPaintDevice: Must construct a TQApplication before a " - "TQPaintDevice" ); -#endif - return; - } - - // [FIXME] - printf("[WARNING] TQPaintDevice::TQPaintDevice( uint devflags ) unimplemented\n\r"); -// devFlags = devflags; -// painters = 0; -// hd = 0; -// rendhd = 0; -// x11Data = 0; -} - -/*! - Returns the window system handle of the paint tqdevice, for - low-level access. Using this function is not portable. - - The HANDLE type varies with platform; see \c tqpaintdevice.h and - \c tqwindowdefs.h for details. - - \sa x11Display() -*/ -TQt::HANDLE TQPaintDevice::handle() const -{ -// return hd; - - // [FIXME] - printf("[WARNING] TQPaintDevice::handle() const unimplemented\n\r"); - return 0; -} - -/*! - Returns the window system handle of the paint tqdevice for XRender - support. Use of this function is not portable. This function will - return 0 if XRender support is not compiled into TQt, if the - XRender extension is not supported on the X11 display, or if the - handle could not be created. -*/ -TQt::HANDLE TQPaintDevice::x11RenderHandle() const -{ -// #ifndef TQT_NO_XFTFREETYPE -// return rendhd ? XftDrawPicture( (XftDraw *) rendhd ) : 0; -// #else -// return 0; -// #endif // TQT_NO_XFTFREETYPE - - // [FIXME] - printf("[WARNING] TQPaintDevice::x11RenderHandle() const unimplemented\n\r"); - return 0; -} - -/*! - \relates QPaintDevice - - Returns the QX11Info structure for the \a pd paint device. 0 is - returned if it can't be obtained. -*/ -const Q_GUI_EXPORT QX11Info *qt_x11Info(const QPaintDevice *pd) -{ - if (!pd) return 0; - if (pd->devType() == QInternal::Widget) - return &static_cast<const QWidget *>(pd)->x11Info(); - else if (pd->devType() == QInternal::Pixmap) - return &static_cast<const QPixmap *>(pd)->x11Info(); - return 0; -} - -Display *TQPaintDevice::x11Display() const -{ - const QX11Info *info = qt_x11Info(this); - if (info) - return info->display(); - return QX11Info::display(); -} - -int TQPaintDevice::x11Screen() const -{ - const QX11Info *info = qt_x11Info(this); - if (info) - return info->screen(); - return QX11Info::appScreen(); -} - -void *TQPaintDevice::x11Visual() const -{ - const QX11Info *info = qt_x11Info(this); - if (info) - return info->visual(); - return QX11Info::appVisual(); -} - -int TQPaintDevice::x11Depth() const -{ - const QX11Info *info = qt_x11Info(this); - if (info) - return info->depth(); - return QX11Info::appDepth(); -} - -int TQPaintDevice::x11Cells() const -{ - const QX11Info *info = qt_x11Info(this); - if (info) - return info->cells(); - return QX11Info::appCells(); -} - -Qt::HANDLE TQPaintDevice::x11Colormap() const -{ - const QX11Info *info = qt_x11Info(this); - if (info) - return info->colormap(); - return QX11Info::appColormap(); -} - -bool TQPaintDevice::x11DefaultColormap() const -{ - const QX11Info *info = qt_x11Info(this); - if (info) - return info->defaultColormap(); - return QX11Info::appDefaultColormap(); -} - -bool TQPaintDevice::x11DefaultVisual() const -{ - const QX11Info *info = qt_x11Info(this); - if (info) - return info->defaultVisual(); - return QX11Info::appDefaultVisual(); -} - -void TQPaintDevice::x11SetAppDpiX(int dpi, int screen) -{ - QX11Info::setAppDpiX(dpi, screen); -} - -void TQPaintDevice::x11SetAppDpiY(int dpi, int screen) -{ - QX11Info::setAppDpiY(dpi, screen); -} - -int TQPaintDevice::x11AppDpiX(int screen) -{ - return QX11Info::appDpiX(screen); -} - -int TQPaintDevice::x11AppDpiY(int screen) -{ - return QX11Info::appDpiY(screen); -} - -/*! - \relates TQPaintDevice - - Copies a block of pixels from \a src to \a dst, perhaps merging - each pixel according to the \link TQt::RasterOp raster operation \endlink - \a rop. \a sx, \a sy - is the top-left pixel in \a src (0, 0) by default, \a dx, \a dy is - the top-left position in \a dst and \a sw, \a sh is the size of - the copied block (all of \a src by default). - - The most common values for \a rop are CopyROP and XorROP; the \l - TQt::RasterOp documentation defines all the possible values. - - If \a ignoreMask is FALSE (the default) and \a src is a - masked TQPixmap, the entire blit is masked by \a{src}->mask(). - - If \a src, \a dst, \a sw or \a sh is 0, bitBlt() does nothing. If - \a sw or \a sh is negative bitBlt() copies starting at \a sx (and - respectively, \a sy) and ending at the right end (respectively, - bottom) of \a src. - - \a src must be a TQWidget or TQPixmap. You cannot blit from a - TQPrinter, for example. bitBlt() does nothing if you attempt to - blit from an unsupported tqdevice. - - bitBlt() does nothing if \a src has a greater depth than \e dst. - If you need to for example, draw a 24-bit pixmap on an 8-bit - widget, you must use drawPixmap(). -*/ - -void bitBlt( TQPaintDevice *dst, int dx, int dy, - const TQPaintDevice *src, int sx, int sy, int sw, int sh, - TQt::RasterOp rop, bool ignoreMask ) -{ -// [FIXME] Implement this for Qt4! -printf("[WARNING] bitBlt( TQPaintDevice *dst, int dx, int dy, const TQPaintDevice *src, int sx, int sy, int sw, int sh, TQt::RasterOp rop, bool ignoreMask ) unimplemented\n\r"); - -// if ( !src || !dst ) { -// #if defined(TQT_CHECK_NULL) -// TQ_ASSERT( src != 0 ); -// TQ_ASSERT( dst != 0 ); -// #endif -// return; -// } -// if ( !src->handle() || src->isExtDev() ) -// return; -// -// TQPaintDevice *pdev = TQPainter::redirect( dst ); -// if ( pdev ) -// dst = pdev; -// -// int ts = src->devType(); // from tqdevice type -// int td = dst->devType(); // to tqdevice type -// Display *dpy = src->x11Display(); -// -// if ( sw <= 0 ) { // special width -// if ( sw < 0 ) -// sw = src->metric( TQPaintDeviceMetrics::PdmWidth ) - sx; -// else -// return; -// } -// if ( sh <= 0 ) { // special height -// if ( sh < 0 ) -// sh = src->metric( TQPaintDeviceMetrics::PdmHeight ) - sy; -// else -// return; -// } -// -// if ( dst->paintingActive() && dst->isExtDev() ) { -// TQPixmap *pm; // output to picture/printer -// bool tmp_pm = TRUE; -// if ( ts == TQInternal::Pixmap ) { -// pm = (TQPixmap*)src; -// if ( sx != 0 || sy != 0 || -// sw != pm->width() || sh != pm->height() || ignoreMask ) { -// TQPixmap *tmp = new TQPixmap( sw, sh, pm->depth() ); -// bitBlt( tmp, 0, 0, pm, sx, sy, sw, sh, TQt::CopyROP, TRUE ); -// if ( pm->mask() && !ignoreMask ) { -// TQBitmap mask( sw, sh ); -// bitBlt( &mask, 0, 0, pm->mask(), sx, sy, sw, sh, -// TQt::CopyROP, TRUE ); -// tmp->setMask( mask ); -// } -// pm = tmp; -// } else { -// tmp_pm = FALSE; -// } -// } else if ( ts == TQInternal::Widget ) {// bitBlt to temp pixmap -// pm = new TQPixmap( sw, sh ); -// TQ_CHECK_PTR( pm ); -// bitBlt( pm, 0, 0, src, sx, sy, sw, sh ); -// } else { -// #if defined(TQT_CHECK_RANGE) -// qWarning( "bitBlt: Cannot bitBlt from tqdevice" ); -// #endif -// return; -// } -// TQPDevCmdParam param[3]; -// TQRect r(dx, dy, pm->width(), pm->height()); -// param[0].rect = &r; -// param[1].pixmap = pm; -// dst->cmd( TQPaintDevice::PdcDrawPixmap, 0, param ); -// if ( tmp_pm ) -// delete pm; -// return; -// } -// -// switch ( ts ) { -// case TQInternal::Widget: -// case TQInternal::Pixmap: -// case TQInternal::System: // OK, can blt from these -// break; -// default: -// #if defined(TQT_CHECK_RANGE) -// qWarning( "bitBlt: Cannot bitBlt from tqdevice type %x", ts ); -// #endif -// return; -// } -// switch ( td ) { -// case TQInternal::Widget: -// case TQInternal::Pixmap: -// case TQInternal::System: // OK, can blt to these -// break; -// default: -// #if defined(TQT_CHECK_RANGE) -// qWarning( "bitBlt: Cannot bitBlt to tqdevice type %x", td ); -// #endif -// return; -// } -// -// static const short ropCodes[] = { // ROP translation table -// GXcopy, GXor, GXxor, GXandInverted, -// GXcopyInverted, GXorInverted, GXequiv, GXand, -// GXinvert, GXclear, GXset, GXnoop, -// GXandReverse, GXorReverse, GXnand, GXnor -// }; -// if ( rop > TQt::LastROP ) { -// #if defined(TQT_CHECK_RANGE) -// qWarning( "bitBlt: Invalid ROP code" ); -// #endif -// return; -// } -// -// if ( dst->handle() == 0 ) { -// #if defined(TQT_CHECK_NULL) -// qWarning( "bitBlt: Cannot bitBlt to tqdevice" ); -// #endif -// return; -// } -// -// bool mono_src; -// bool mono_dst; -// bool include_inferiors = FALSE; -// bool graphics_exposure = FALSE; -// TQPixmap *src_pm; -// TQBitmap *mask; -// -// if ( ts == TQInternal::Pixmap ) { -// src_pm = (TQPixmap*)src; -// if ( src_pm->x11Screen() != dst->x11Screen() ) -// src_pm->x11SetScreen( dst->x11Screen() ); -// mono_src = src_pm->depth() == 1; -// mask = ignoreMask ? 0 : src_pm->data->mask; -// } else { -// src_pm = 0; -// mono_src = FALSE; -// mask = 0; -// include_inferiors = ((TQWidget*)src)->testWFlags(TQt::WPaintUnclipped); -// graphics_exposure = td == TQInternal::Widget; -// } -// if ( td == TQInternal::Pixmap ) { -// if ( dst->x11Screen() != src->x11Screen() ) -// ((TQPixmap*)dst)->x11SetScreen( src->x11Screen() ); -// mono_dst = ((TQPixmap*)dst)->depth() == 1; -// ((TQPixmap*)dst)->detach(); // changes shared pixmap -// } else { -// mono_dst = FALSE; -// include_inferiors = include_inferiors || -// ((TQWidget*)dst)->testWFlags(TQt::WPaintUnclipped); -// } -// -// if ( mono_dst && !mono_src ) { // dest is 1-bit pixmap, source is not -// #if defined(TQT_CHECK_RANGE) -// qWarning( "bitBlt: Incompatible destination pixmap" ); -// #endif -// return; -// } -// -// #ifndef TQT_NO_XRENDER -// if (src_pm && !mono_src && src_pm->data->alphapm && !ignoreMask ) { -// // use RENDER to do the blit -// TQPixmap *alpha = src_pm->data->alphapm; -// if (src->x11RenderHandle() && -// alpha->x11RenderHandle() && -// dst->x11RenderHandle()) { -// XRenderPictureAttributes pattr; -// ulong picmask = 0; -// if (include_inferiors) { -// pattr.subwindow_mode = IncludeInferiors; -// picmask |= CPSubwindowMode; -// } -// if (graphics_exposure) { -// pattr.graphics_exposures = TRUE; -// picmask |= CPGraphicsExposure; -// } -// if (picmask) -// XRenderChangePicture(dpy, dst->x11RenderHandle(), picmask, &pattr); -// XRenderComposite(dpy, PictOpOver, src->x11RenderHandle(), -// alpha->x11RenderHandle(), dst->x11RenderHandle(), -// sx, sy, sx, sy, dx, dy, sw, sh); -// // restore attributes -// pattr.subwindow_mode = ClipByChildren; -// pattr.graphics_exposures = FALSE; -// if (picmask) -// XRenderChangePicture(dpy, dst->x11RenderHandle(), picmask, &pattr); -// return; -// } -// } -// #endif -// -// GC gc; -// -// if ( mask && !mono_src ) { // fast masked blt -// bool temp_gc = FALSE; -// if ( mask->data->maskgc ) { -// gc = (GC)mask->data->maskgc; // we have a premade mask GC -// } else { -// if ( FALSE && src_pm->optimization() == TQPixmap::NormalOptim ) { // #### cache disabled -// // Compete for the global cache -// gc = cache_mask_gc( dpy, dst->handle(), -// mask->data->ser_no, -// mask->handle() ); -// } else { -// // Create a new mask GC. If BestOptim, we store the mask GC -// // with the mask (not at the pixmap). This way, many pixmaps -// // which have a common mask will be optimized at no extra cost. -// gc = XCreateGC( dpy, dst->handle(), 0, 0 ); -// XSetGraphicsExposures( dpy, gc, False ); -// XSetClipMask( dpy, gc, mask->handle() ); -// if ( src_pm->optimization() == TQPixmap::BestOptim ) { -// mask->data->maskgc = gc; -// } else { -// temp_gc = TRUE; -// } -// } -// } -// XSetClipOrigin( dpy, gc, dx-sx, dy-sy ); -// if ( rop != TQt::CopyROP ) // use non-default ROP code -// XSetFunction( dpy, gc, ropCodes[rop] ); -// if ( include_inferiors ) { -// XSetSubwindowMode( dpy, gc, IncludeInferiors ); -// XCopyArea( dpy, src->handle(), dst->handle(), gc, sx, sy, sw, sh, -// dx, dy ); -// XSetSubwindowMode( dpy, gc, ClipByChildren ); -// } else { -// XCopyArea( dpy, src->handle(), dst->handle(), gc, sx, sy, sw, sh, -// dx, dy ); -// } -// -// if ( temp_gc ) // delete temporary GC -// XFreeGC( dpy, gc ); -// else if ( rop != TQt::CopyROP ) // restore ROP -// XSetFunction( dpy, gc, GXcopy ); -// return; -// } -// -// gc = qt_xget_temp_gc( dst->x11Screen(), mono_dst ); // get a reusable GC -// -// if ( rop != TQt::CopyROP ) // use non-default ROP code -// XSetFunction( dpy, gc, ropCodes[rop] ); -// -// if ( mono_src && mono_dst && src == dst ) { // dst and src are the same bitmap -// XCopyArea( dpy, src->handle(), dst->handle(), gc, sx, sy, sw, sh, dx, dy ); -// } else if ( mono_src ) { // src is bitmap -// XGCValues gcvals; -// ulong valmask = GCBackground | GCForeground | GCFillStyle | -// GCStipple | GCTileStipXOrigin | GCTileStipYOrigin; -// if ( td == TQInternal::Widget ) { // set GC colors -// TQWidget *w = (TQWidget *)dst; -// gcvals.background = w->backgroundColor().pixel( dst->x11Screen() ); -// gcvals.foreground = w->foregroundColor().pixel( dst->x11Screen() ); -// if ( include_inferiors ) { -// valmask |= GCSubwindowMode; -// gcvals.subwindow_mode = IncludeInferiors; -// } -// } else if ( mono_dst ) { -// gcvals.background = 0; -// gcvals.foreground = 1; -// } else { -// gcvals.background = TQt::white.pixel( dst->x11Screen() ); -// gcvals.foreground = TQt::black.pixel( dst->x11Screen() ); -// } -// -// gcvals.fill_style = FillOpaqueStippled; -// gcvals.stipple = src->handle(); -// gcvals.ts_x_origin = dx - sx; -// gcvals.ts_y_origin = dy - sy; -// -// bool clipmask = FALSE; -// if ( mask ) { -// if ( ((TQPixmap*)src)->data->selfmask ) { -// gcvals.fill_style = FillStippled; -// } else { -// XSetClipMask( dpy, gc, mask->handle() ); -// XSetClipOrigin( dpy, gc, dx-sx, dy-sy ); -// clipmask = TRUE; -// } -// } -// -// XChangeGC( dpy, gc, valmask, &gcvals ); -// XFillRectangle( dpy,dst->handle(), gc, dx, dy, sw, sh ); -// -// valmask = GCFillStyle | GCTileStipXOrigin | GCTileStipYOrigin; -// gcvals.fill_style = FillSolid; -// gcvals.ts_x_origin = 0; -// gcvals.ts_y_origin = 0; -// if ( include_inferiors ) { -// valmask |= GCSubwindowMode; -// gcvals.subwindow_mode = ClipByChildren; -// } -// XChangeGC( dpy, gc, valmask, &gcvals ); -// -// if ( clipmask ) { -// XSetClipOrigin( dpy, gc, 0, 0 ); -// XSetClipMask( dpy, gc, None ); -// } -// -// } else { // src is pixmap/widget -// -// if ( graphics_exposure ) // widget to widget -// XSetGraphicsExposures( dpy, gc, True ); -// if ( include_inferiors ) { -// XSetSubwindowMode( dpy, gc, IncludeInferiors ); -// XCopyArea( dpy, src->handle(), dst->handle(), gc, sx, sy, sw, sh, -// dx, dy ); -// XSetSubwindowMode( dpy, gc, ClipByChildren ); -// } else { -// XCopyArea( dpy, src->handle(), dst->handle(), gc, sx, sy, sw, sh, -// dx, dy ); -// } -// if ( graphics_exposure ) // reset graphics exposure -// XSetGraphicsExposures( dpy, gc, False ); -// } -// -// if ( rop != TQt::CopyROP ) // restore ROP -// XSetFunction( dpy, gc, GXcopy ); -} - -/*! - Internal virtual function that interprets drawing commands from - the painter. - - Implemented by subclasses that have no direct support for drawing - graphics (external paint tqdevices, for example, TQPicture). -*/ - -bool TQPaintDevice::cmd( int, TQPainter *, TQPDevCmdParam * ) -{ -#if defined(TQT_CHECK_STATE) - qWarning( "TQPaintDevice::cmd: Device has no command interface" ); -#endif - return FALSE; -} - -// Reimplemented QPaintEngine methods -// These need to call their equivalent Qt3 cmd methods -bool TQPaintDeviceEngineTranslator::begin(QPaintDevice* qpd) { - printf("[WARNING] TQPaintDeviceEngineTranslator::begin() unimplemented\n\r"); -} - -bool TQPaintDeviceEngineTranslator::end() { - printf("[WARNING] TQPaintDeviceEngineTranslator::end() unimplemented\n\r"); -} - -void TQPaintDeviceEngineTranslator::updateState(const QPaintEngineState& qpes) { - printf("[WARNING] TQPaintDeviceEngineTranslator::updateState() unimplemented\n\r"); -} - -void TQPaintDeviceEngineTranslator::drawPixmap(const QRectF& rect1, const QPixmap& pixmap, const QRectF& rect2) { - printf("[WARNING] TQPaintDeviceEngineTranslator::drawPixmap() unimplemented\n\r"); -} - -QPaintEngine::Type TQPaintDeviceEngineTranslator::type() const { - printf("[WARNING] TQPaintDeviceEngineTranslator::type() unimplemented\n\r"); - return QPaintEngine::X11; -} - -#else // USE_QT4 - -/*! - \class TQPaintDevice tqpaintdevice.h - \brief The TQPaintDevice class is the base class of objects that - can be painted. - - \ingroup graphics - \ingroup images - - A paint tqdevice is an abstraction of a two-dimensional space that - can be drawn using a TQPainter. The drawing capabilities are - implemented by the subclasses TQWidget, TQPixmap, TQPicture and - TQPrinter. - - The default coordinate system of a paint tqdevice has its origin - located at the top-left position. X increases to the right and Y - increases downward. The unit is one pixel. There are several ways - to set up a user-defined coordinate system using the painter, for - example, using TQPainter::setWorldMatrix(). - - Example (draw on a paint tqdevice): - \code - void MyWidget::paintEvent( TQPaintEvent * ) - { - TQPainter p; // our painter - p.begin( this ); // start painting the widget - p.setPen( red ); // red outline - p.setBrush( yellow ); // yellow fill - p.drawEllipse( 10, 20, 100,100 ); // 100x100 ellipse at position (10, 20) - p.end(); // painting done - } - \endcode - - The bit block transfer is an extremely useful operation for - copying pixels from one paint tqdevice to another (or to itself). It - is implemented as the global function bitBlt(). - - Example (scroll widget contents 10 pixels to the right): - \code - bitBlt( myWidget, 10, 0, myWidget ); - \endcode - - \warning TQt requires that a TQApplication object exists before - any paint tqdevices can be created. Paint tqdevices access window - system resources, and these resources are not initialized before - an application object is created. -*/ - - -// -// Some global variables - these are initialized by TQColor::initialize() -// - -Display *TQPaintDevice::x_appdisplay = 0; -int TQPaintDevice::x_appscreen; - -int TQPaintDevice::x_appdepth; -int TQPaintDevice::x_appcells; -TQt::HANDLE TQPaintDevice::x_approotwindow; -TQt::HANDLE TQPaintDevice::x_appcolormap; -bool TQPaintDevice::x_appdefcolormap; -void *TQPaintDevice::x_appvisual; -bool TQPaintDevice::x_appdefvisual; - -// ### in 4.0, remove the above, and use the below -int *TQPaintDevice::x_appdepth_arr; -int *TQPaintDevice::x_appcells_arr; -TQt::HANDLE *TQPaintDevice::x_approotwindow_arr; -TQt::HANDLE *TQPaintDevice::x_appcolormap_arr; -bool *TQPaintDevice::x_appdefcolormap_arr; -void **TQPaintDevice::x_appvisual_arr; -bool *TQPaintDevice::x_appdefvisual_arr; - -/*! - \enum TQPaintDevice::PDevCmd - \internal -*/ - -/*! - Constructs a paint tqdevice with internal flags \a devflags. This - constructor can be invoked only from TQPaintDevice subclasses. -*/ - -TQPaintDevice::TQPaintDevice( uint devflags ) -{ - if ( !tqApp ) { // global constructor -#if defined(TQT_CHECK_STATE) - qFatal( "TQPaintDevice: Must construct a TQApplication before a " - "TQPaintDevice" ); -#endif - return; - } - devFlags = devflags; - painters = 0; - hd = 0; - rendhd = 0; - x11Data = 0; -} - -/*! - Destroys the paint tqdevice and frees window system resources. -*/ - -TQPaintDevice::~TQPaintDevice() -{ -#if defined(TQT_CHECK_STATE) - if ( paintingActive() ) - qWarning( "TQPaintDevice: Cannot destroy paint tqdevice that is being " - "painted" ); -#endif - if ( x11Data && x11Data->deref() ) { - delete x11Data; - x11Data = 0; - } -} - - -/* - \internal - Makes a shallow copy of the X11-specific data of \a fromDevice, if it is not - null. Otherwise this function sets it to null. -*/ - -void TQPaintDevice::copyX11Data( const TQPaintDevice *fromDevice ) -{ - setX11Data( fromDevice ? fromDevice->x11Data : 0 ); -} - -/* - \internal - Makes a deep copy of the X11-specific data of \a fromDevice, if it is not - null. Otherwise this function sets it to null. -*/ - -void TQPaintDevice::cloneX11Data( const TQPaintDevice *fromDevice ) -{ - if ( fromDevice && fromDevice->x11Data ) { - TQPaintDeviceX11Data *d = new TQPaintDeviceX11Data; - *d = *fromDevice->x11Data; - d->count = 0; - setX11Data( d ); - } else { - setX11Data( 0 ); - } -} - -/* - \internal - Makes a shallow copy of the X11-specific data \a d and assigns it to this - class. This function increments the reference code of \a d. -*/ - -void TQPaintDevice::setX11Data( const TQPaintDeviceX11Data* d ) -{ - if ( x11Data && x11Data->deref() ) - delete x11Data; - x11Data = (TQPaintDeviceX11Data*)d; - if ( x11Data ) - x11Data->ref(); -} - - -/* - \internal - If \a def is FALSE, returns a deep copy of the x11Data, or 0 if x11Data is 0. - If \a def is TRUE, makes a TQPaintDeviceX11Data struct filled with the default - values. - - In either case the caller is responsible for deleting the returned - struct. But notice that the struct is a shared class, so other - classes might also have a reference to it. The reference count of - the returned TQPaintDeviceX11Data* is 0. -*/ - -TQPaintDeviceX11Data* TQPaintDevice::getX11Data( bool def ) const -{ - TQPaintDeviceX11Data* res = 0; - if ( def ) { - res = new TQPaintDeviceX11Data; - res->x_display = x11AppDisplay(); - res->x_screen = x11AppScreen(); - res->x_depth = x11AppDepth(); - res->x_cells = x11AppCells(); - res->x_colormap = x11Colormap(); - res->x_defcolormap = x11AppDefaultColormap(); - res->x_visual = x11AppVisual(); - res->x_defvisual = x11AppDefaultVisual(); - res->deref(); - } else if ( x11Data ) { - res = new TQPaintDeviceX11Data; - *res = *x11Data; - res->count = 0; - } - return res; -} - - -/*! - \fn int TQPaintDevice::devType() const - - \internal - - Returns the tqdevice type identifier, which is \c TQInternal::Widget - if the tqdevice is a TQWidget, \c TQInternal::Pixmap if it's a - TQPixmap, \c TQInternal::Printer if it's a TQPrinter, \c - TQInternal::Picture if it's a TQPicture or \c - TQInternal::UndefinedDevice in other cases (which should never - happen). -*/ - -/*! - \fn bool TQPaintDevice::isExtDev() const - - Returns TRUE if the tqdevice is an external paint tqdevice; otherwise - returns FALSE. - - External paint tqdevices cannot be bitBlt()'ed from. TQPicture and - TQPrinter are external paint tqdevices. -*/ - -/*! - Returns the window system handle of the paint tqdevice, for - low-level access. Using this function is not portable. - - The HANDLE type varies with platform; see \c tqpaintdevice.h and - \c tqwindowdefs.h for details. - - \sa x11Display() -*/ -TQt::HANDLE TQPaintDevice::handle() const -{ - return hd; -} - -/*! - Returns the window system handle of the paint tqdevice for XRender - support. Use of this function is not portable. This function will - return 0 if XRender support is not compiled into TQt, if the - XRender extension is not supported on the X11 display, or if the - handle could not be created. -*/ -TQt::HANDLE TQPaintDevice::x11RenderHandle() const -{ -#ifndef TQT_NO_XFTFREETYPE - return rendhd ? XftDrawPicture( (XftDraw *) rendhd ) : 0; -#else - return 0; -#endif // TQT_NO_XFTFREETYPE -} - - -/*! - \fn Display *TQPaintDevice::x11AppDisplay() - - Returns a pointer to the X display global to the application (X11 - only). Using this function is not portable. - - \sa handle() -*/ - -/*! - \fn int TQPaintDevice::x11AppScreen() - - Returns the screen number on the X display global to the - application (X11 only). Using this function is not portable. -*/ - -/*! - \overload - \fn int TQPaintDevice::x11AppDepth() - - Returns the depth for the default screen of the X display global - to the application (X11 only). Using this function is not - portable. - - \sa TQPixmap::defaultDepth() -*/ - -/*! - \fn int TQPaintDevice::x11AppCells() - - Returns the number of entries in the colormap for the default - screen of the X display global to the application (X11 - only). Using this function is not portable. - - \sa x11Colormap() -*/ - -/*! - \fn HANDLE TQPaintDevice::x11AppRootWindow() - - Returns the root window for the default screen of the X display - global to the applicatoin (X11 only). Using this function is not - portable. -*/ - -/*! - \fn HANDLE TQPaintDevice::x11AppColormap() - - Returns the colormap for the default screen of the X display - global to the application (X11 only). Using this function is not - portable. - - \sa x11Cells() -*/ - -/*! - \fn bool TQPaintDevice::x11AppDefaultColormap () - - Returns the default colormap for the default screen of the X - display global to the application (X11 only). Using this function - is not portable. - - \sa x11Cells() -*/ - -/*! - \fn void* TQPaintDevice::x11AppVisual () - - Returns the Visual for the default screen of the X display global - to the application (X11 only). Using this function is not - portable. -*/ - -/*! - \fn bool TQPaintDevice::x11AppDefaultVisual () - - Returns TRUE if the Visual used is the default for the default - screen of the X display global to the application (X11 only); - otherwise returns FALSE. Using this function is not portable. -*/ - -/*! - \fn int TQPaintDevice::x11AppDepth( int screen ) - - Returns the depth for screen \a screen of the X display global to - the application (X11 only). Using this function is not portable. - - \sa TQPixmap::defaultDepth() -*/ - -/*! - \overload - \fn int TQPaintDevice::x11AppCells( int screen ) - - Returns the number of entries in the colormap for screen \a screen - of the X display global to the application (X11 only). Using this - function is not portable. - - \sa x11Colormap() -*/ - -/*! - \overload - \fn HANDLE TQPaintDevice::x11AppRootWindow( int screen ) - - Returns the root window for screen \a screen of the X display - global to the applicatoin (X11 only). Using this function is not - portable. -*/ - -/*! - \overload - \fn HANDLE TQPaintDevice::x11AppColormap( int screen ) - - Returns the colormap for screen \a screen of the X display global - to the application (X11 only). Using this function is not - portable. - - \sa x11Cells() -*/ - -/*! - \overload - \fn bool TQPaintDevice::x11AppDefaultColormap( int screen ) - - Returns the default colormap for screen \a screen of the X display - global to the application (X11 only). Using this function is not - portable. - - \sa x11Cells() -*/ - -/*! - \overload - \fn void* TQPaintDevice::x11AppVisual( int screen ) - - Returns the Visual for screen \a screen of the X display global to - the application (X11 only). Using this function is not portable. -*/ - -/*! - \overload - \fn bool TQPaintDevice::x11AppDefaultVisual( int screen ) - - Returns TRUE if the Visual used is the default for screen - \a screen of the X display global to the application (X11 only); - otherwise returns FALSE. Using this function is not portable. -*/ - - -/*! - \fn Display *TQPaintDevice::x11Display() const - - Returns a pointer to the X display for the paint tqdevice (X11 - only). Using this function is not portable. - - \sa handle() -*/ - -/*! - \fn int TQPaintDevice::x11Screen () const - - Returns the screen number on the X display for the paint tqdevice - (X11 only). Using this function is not portable. -*/ - -/*! - \fn int TQPaintDevice::x11Depth () const - - Returns the depth of the X display for the paint tqdevice (X11 - only). Using this function is not portable. - - \sa TQPixmap::defaultDepth() -*/ - -/*! - \fn int TQPaintDevice::x11Cells () const - - Returns the number of entries in the colormap of the X display for - the paint tqdevice (X11 only). Using this function is not portable. - - \sa x11Colormap() -*/ - -/*! - \fn HANDLE TQPaintDevice::x11Colormap () const - - Returns the colormap of the X display for the paint tqdevice (X11 - only). Using this function is not portable. - - \sa x11Cells() -*/ - -/*! - \fn bool TQPaintDevice::x11DefaultColormap () const - - Returns the default colormap of the X display for the paint tqdevice - (X11 only). Using this function is not portable. - - \sa x11Cells() -*/ - -/*! - \fn void* TQPaintDevice::x11Visual () const - - Returns the Visual of the X display for the paint tqdevice (X11 - only). Using this function is not portable. -*/ - -/*! - \fn bool TQPaintDevice::x11DefaultVisual () const - - Returns the default Visual of the X display for the paint tqdevice - (X11 only). Using this function is not portable. -*/ - -static int *dpisX=0, *dpisY=0; -static void create_dpis() -{ - if ( dpisX ) - return; - - Display *dpy = TQPaintDevice::x11AppDisplay(); - if ( ! dpy ) - return; - - int i, screens = ScreenCount( dpy ); - dpisX = new int[ screens ]; - dpisY = new int[ screens ]; - TQ_CHECK_PTR( dpisX ); - TQ_CHECK_PTR( dpisY ); - for ( i = 0; i < screens; i++ ) { - if (DisplayWidthMM(dpy,i) < 1) - dpisX[ i ] = 75; // default the dpi to 75. - else - dpisX[ i ] = (DisplayWidth(dpy,i) * 254 + DisplayWidthMM(dpy,i)*5) - / (DisplayWidthMM(dpy,i)*10); - if (DisplayHeightMM(dpy,i) < 1) - dpisY[ i ] = 75; // default the dpi to 75. - else - dpisY[ i ] = (DisplayHeight(dpy,i) * 254 + DisplayHeightMM(dpy,i)*5) - / (DisplayHeightMM(dpy,i)*10); - } -} - -/*! - Sets the value returned by x11AppDpiX() to \a dpi for screen - \a screen. The default is determined by the display configuration. - Changing this value will alter the scaling of fonts and many other - metrics and is not recommended. Using this function is not - portable. - - \sa x11SetAppDpiY() -*/ -void TQPaintDevice::x11SetAppDpiX(int dpi, int screen) -{ - create_dpis(); - if ( ! dpisX ) - return; - if ( screen < 0 ) - screen = TQPaintDevice::x11AppScreen(); - if ( screen > ScreenCount( TQPaintDevice::x11AppDisplay() ) ) - return; - dpisX[ screen ] = dpi; -} - -/*! - \overload - - Sets the value returned by x11AppDpiX() to \a dpi for the default - screen. The default is determined by the display configuration. - Changing this value will alter the scaling of fonts and many other - metrics and is not recommended. Using this function is not - portable. - -*/ -// ### REMOVE 4.0 -void TQPaintDevice::x11SetAppDpiX( int dpi ) -{ - TQPaintDevice::x11SetAppDpiX( dpi, -1 ); -} - -/*! - Sets the value returned by x11AppDpiY() to \a dpi for screen - \a screen. The default is determined by the display configuration. - Changing this value will alter the scaling of fonts and many other - metrics and is not recommended. Using this function is not - portable. - - \sa x11SetAppDpiX() -*/ -void TQPaintDevice::x11SetAppDpiY(int dpi, int screen) -{ - create_dpis(); - if ( ! dpisY ) - return; - if ( screen < 0 ) - screen = TQPaintDevice::x11AppScreen(); - if ( screen > ScreenCount( TQPaintDevice::x11AppDisplay() ) ) - return; - dpisY[ screen ] = dpi; -} - -/*! - \overload - - Sets the value returned by x11AppDpiY() to \a dpi for the default - screen. The default is determined by the display configuration. - Changing this value will alter the scaling of fonts and many other - metrics and is not recommended. Using this function is not - portable. -*/ -// ### REMOVE 4.0 -void TQPaintDevice::x11SetAppDpiY( int dpi ) -{ - TQPaintDevice::x11SetAppDpiY( dpi, -1 ); -} - -/*! - Returns the horizontal DPI of the X display (X11 only) for screen - \a screen. Using this function is not portable. See - TQPaintDeviceMetrics for portable access to related information. - Using this function is not portable. - - \sa x11AppDpiY(), x11SetAppDpiX(), TQPaintDeviceMetrics::logicalDpiX() -*/ -int TQPaintDevice::x11AppDpiX(int screen) -{ - create_dpis(); - if ( ! dpisX ) - return 0; - if ( screen < 0 ) - screen = TQPaintDevice::x11AppScreen(); - if ( screen > ScreenCount( TQPaintDevice::x11AppDisplay() ) ) - return 0; - return dpisX[ screen ]; -} - -/*! - \overload - - Returns the horizontal DPI of the X display (X11 only) for the - default screen. Using this function is not portable. See - TQPaintDeviceMetrics for portable access to related information. - Using this function is not portable. -*/ -int TQPaintDevice::x11AppDpiX() -{ - return TQPaintDevice::x11AppDpiX( -1 ); -} - -/*! - Returns the vertical DPI of the X11 display (X11 only) for screen - \a screen. Using this function is not portable. See - TQPaintDeviceMetrics for portable access to related information. - Using this function is not portable. - - \sa x11AppDpiX(), x11SetAppDpiY(), TQPaintDeviceMetrics::logicalDpiY() -*/ -int TQPaintDevice::x11AppDpiY( int screen ) -{ - create_dpis(); - if ( ! dpisY ) - return 0; - if ( screen < 0 ) - screen = TQPaintDevice::x11AppScreen(); - if ( screen > ScreenCount( TQPaintDevice::x11AppDisplay() ) ) - return 0; - return dpisY[ screen ]; -} - -/*! - \overload - - Returns the vertical DPI of the X11 display (X11 only) for the - default screen. Using this function is not portable. See - TQPaintDeviceMetrics for portable access to related information. - Using this function is not portable. - - \sa x11AppDpiX(), x11SetAppDpiY(), TQPaintDeviceMetrics::logicalDpiY() -*/ -int TQPaintDevice::x11AppDpiY() -{ - return TQPaintDevice::x11AppDpiY( -1 ); -} - -/*! - \fn bool TQPaintDevice::paintingActive() const - - Returns TRUE if the tqdevice is being painted, i.e. someone has - called TQPainter::begin() but not yet called TQPainter::end() for - this tqdevice; otherwise returns FALSE. - - \sa TQPainter::isActive() -*/ - -/*! - Internal virtual function that interprets drawing commands from - the painter. - - Implemented by subclasses that have no direct support for drawing - graphics (external paint tqdevices, for example, TQPicture). -*/ - -bool TQPaintDevice::cmd( int, TQPainter *, TQPDevCmdParam * ) -{ -#if defined(TQT_CHECK_STATE) - qWarning( "TQPaintDevice::cmd: Device has no command interface" ); -#endif - return FALSE; -} - -/*! - \internal - - Internal virtual function that returns paint tqdevice metrics. - - Please use the TQPaintDeviceMetrics class instead. -*/ - -int TQPaintDevice::metric( int ) const -{ -#if defined(TQT_CHECK_STATE) - qWarning( "TQPaintDevice::metrics: Device has no metric information" ); -#endif - return 0; -} - -/*! - \internal - - Internal virtual function. Reserved for future use. - - Please use the TQFontMetrics class instead. -*/ - -int TQPaintDevice::fontMet( TQFont *, int, const char *, int ) const -{ - return 0; -} - -/*! - \internal - - Internal virtual function. Reserved for future use. - - Please use the TQFontInfo class instead. -*/ - -int TQPaintDevice::fontInf( TQFont *, int ) const -{ - return 0; -} - - -// -// Internal functions for simple GC caching for blt'ing masked pixmaps. -// This cache is used when the pixmap optimization is set to Normal -// and the pixmap size doesn't exceed 128x128. -// - -static bool init_mask_gc = FALSE; -static const int max_mask_gcs = 11; // suitable for hashing - -struct mask_gc { - GC gc; - int mask_no; -}; - -static mask_gc gc_vec[max_mask_gcs]; - - -static void cleanup_mask_gc() -{ - Display *dpy = TQPaintDevice::x11AppDisplay(); - init_mask_gc = FALSE; - for ( int i=0; i<max_mask_gcs; i++ ) { - if ( gc_vec[i].gc ) - XFreeGC( dpy, gc_vec[i].gc ); - } -} - -static GC cache_mask_gc( Display *dpy, Drawable hd, int mask_no, Pixmap mask ) -{ - if ( !init_mask_gc ) { // first time initialization - init_mask_gc = TRUE; - qAddPostRoutine( cleanup_mask_gc ); - for ( int i=0; i<max_mask_gcs; i++ ) - gc_vec[i].gc = 0; - } - mask_gc *p = &gc_vec[mask_no % max_mask_gcs]; - if ( !p->gc || p->mask_no != mask_no ) { // not a perfect match - if ( !p->gc ) { // no GC - p->gc = XCreateGC( dpy, hd, 0, 0 ); - XSetGraphicsExposures( dpy, p->gc, False ); - } - XSetClipMask( dpy, p->gc, mask ); - p->mask_no = mask_no; - } - return p->gc; -} - - -/*! - \relates TQPaintDevice - - Copies a block of pixels from \a src to \a dst, perhaps merging - each pixel according to the \link TQt::RasterOp raster operation \endlink - \a rop. \a sx, \a sy - is the top-left pixel in \a src (0, 0) by default, \a dx, \a dy is - the top-left position in \a dst and \a sw, \a sh is the size of - the copied block (all of \a src by default). - - The most common values for \a rop are CopyROP and XorROP; the \l - TQt::RasterOp documentation defines all the possible values. - - If \a ignoreMask is FALSE (the default) and \a src is a - masked TQPixmap, the entire blit is masked by \a{src}->mask(). - - If \a src, \a dst, \a sw or \a sh is 0, bitBlt() does nothing. If - \a sw or \a sh is negative bitBlt() copies starting at \a sx (and - respectively, \a sy) and ending at the right end (respectively, - bottom) of \a src. - - \a src must be a TQWidget or TQPixmap. You cannot blit from a - TQPrinter, for example. bitBlt() does nothing if you attempt to - blit from an unsupported tqdevice. - - bitBlt() does nothing if \a src has a greater depth than \e dst. - If you need to for example, draw a 24-bit pixmap on an 8-bit - widget, you must use drawPixmap(). -*/ - -void bitBlt( TQPaintDevice *dst, int dx, int dy, - const TQPaintDevice *src, int sx, int sy, int sw, int sh, - TQt::RasterOp rop, bool ignoreMask ) -{ - if ( !src || !dst ) { -#if defined(TQT_CHECK_NULL) - TQ_ASSERT( src != 0 ); - TQ_ASSERT( dst != 0 ); -#endif - return; - } - if ( !src->handle() || src->isExtDev() ) - return; - - TQPaintDevice *pdev = TQPainter::redirect( dst ); - if ( pdev ) - dst = pdev; - - int ts = src->devType(); // from tqdevice type - int td = dst->devType(); // to tqdevice type - Display *dpy = src->x11Display(); - - if ( sw <= 0 ) { // special width - if ( sw < 0 ) - sw = src->metric( TQPaintDeviceMetrics::PdmWidth ) - sx; - else - return; - } - if ( sh <= 0 ) { // special height - if ( sh < 0 ) - sh = src->metric( TQPaintDeviceMetrics::PdmHeight ) - sy; - else - return; - } - - if ( dst->paintingActive() && dst->isExtDev() ) { - TQPixmap *pm; // output to picture/printer - bool tmp_pm = TRUE; - if ( ts == TQInternal::Pixmap ) { - pm = (TQPixmap*)src; - if ( sx != 0 || sy != 0 || - sw != pm->width() || sh != pm->height() || ignoreMask ) { - TQPixmap *tmp = new TQPixmap( sw, sh, pm->depth() ); - bitBlt( tmp, 0, 0, pm, sx, sy, sw, sh, TQt::CopyROP, TRUE ); - if ( pm->mask() && !ignoreMask ) { - TQBitmap mask( sw, sh ); - bitBlt( &mask, 0, 0, pm->mask(), sx, sy, sw, sh, - TQt::CopyROP, TRUE ); - tmp->setMask( mask ); - } - pm = tmp; - } else { - tmp_pm = FALSE; - } - } else if ( ts == TQInternal::Widget ) {// bitBlt to temp pixmap - pm = new TQPixmap( sw, sh ); - TQ_CHECK_PTR( pm ); - bitBlt( pm, 0, 0, src, sx, sy, sw, sh ); - } else { -#if defined(TQT_CHECK_RANGE) - qWarning( "bitBlt: Cannot bitBlt from tqdevice" ); -#endif - return; - } - TQPDevCmdParam param[3]; - TQRect r(dx, dy, pm->width(), pm->height()); - param[0].rect = &r; - param[1].pixmap = pm; - dst->cmd( TQPaintDevice::PdcDrawPixmap, 0, param ); - if ( tmp_pm ) - delete pm; - return; - } - - switch ( ts ) { - case TQInternal::Widget: - case TQInternal::Pixmap: - case TQInternal::System: // OK, can blt from these - break; - default: -#if defined(TQT_CHECK_RANGE) - qWarning( "bitBlt: Cannot bitBlt from tqdevice type %x", ts ); -#endif - return; - } - switch ( td ) { - case TQInternal::Widget: - case TQInternal::Pixmap: - case TQInternal::System: // OK, can blt to these - break; - default: -#if defined(TQT_CHECK_RANGE) - qWarning( "bitBlt: Cannot bitBlt to tqdevice type %x", td ); -#endif - return; - } - - static const short ropCodes[] = { // ROP translation table - GXcopy, GXor, GXxor, GXandInverted, - GXcopyInverted, GXorInverted, GXequiv, GXand, - GXinvert, GXclear, GXset, GXnoop, - GXandReverse, GXorReverse, GXnand, GXnor - }; - if ( rop > TQt::LastROP ) { -#if defined(TQT_CHECK_RANGE) - qWarning( "bitBlt: Invalid ROP code" ); -#endif - return; - } - - if ( dst->handle() == 0 ) { -#if defined(TQT_CHECK_NULL) - qWarning( "bitBlt: Cannot bitBlt to tqdevice" ); -#endif - return; - } - - bool mono_src; - bool mono_dst; - bool include_inferiors = FALSE; - bool graphics_exposure = FALSE; - TQPixmap *src_pm; - TQBitmap *mask; - - if ( ts == TQInternal::Pixmap ) { - src_pm = (TQPixmap*)src; - if ( src_pm->x11Screen() != dst->x11Screen() ) - src_pm->x11SetScreen( dst->x11Screen() ); - mono_src = src_pm->depth() == 1; - mask = ignoreMask ? 0 : src_pm->data->mask; - } else { - src_pm = 0; - mono_src = FALSE; - mask = 0; - include_inferiors = ((TQWidget*)src)->testWFlags(TQt::WPaintUnclipped); - graphics_exposure = td == TQInternal::Widget; - } - if ( td == TQInternal::Pixmap ) { - if ( dst->x11Screen() != src->x11Screen() ) - ((TQPixmap*)dst)->x11SetScreen( src->x11Screen() ); - mono_dst = ((TQPixmap*)dst)->depth() == 1; - ((TQPixmap*)dst)->detach(); // changes shared pixmap - } else { - mono_dst = FALSE; - include_inferiors = include_inferiors || - ((TQWidget*)dst)->testWFlags(TQt::WPaintUnclipped); - } - - if ( mono_dst && !mono_src ) { // dest is 1-bit pixmap, source is not -#if defined(TQT_CHECK_RANGE) - qWarning( "bitBlt: Incompatible destination pixmap" ); -#endif - return; - } - -#ifndef TQT_NO_XRENDER - if (src_pm && !mono_src && src_pm->data->alphapm && !ignoreMask ) { - // use RENDER to do the blit - TQPixmap *alpha = src_pm->data->alphapm; - if (src->x11RenderHandle() && - alpha->x11RenderHandle() && - dst->x11RenderHandle()) { - XRenderPictureAttributes pattr; - ulong picmask = 0; - if (include_inferiors) { - pattr.subwindow_mode = IncludeInferiors; - picmask |= CPSubwindowMode; - } - if (graphics_exposure) { - pattr.graphics_exposures = TRUE; - picmask |= CPGraphicsExposure; - } - if (picmask) - XRenderChangePicture(dpy, dst->x11RenderHandle(), picmask, &pattr); - XRenderComposite(dpy, PictOpOver, src->x11RenderHandle(), - alpha->x11RenderHandle(), dst->x11RenderHandle(), - sx, sy, sx, sy, dx, dy, sw, sh); - // restore attributes - pattr.subwindow_mode = ClipByChildren; - pattr.graphics_exposures = FALSE; - if (picmask) - XRenderChangePicture(dpy, dst->x11RenderHandle(), picmask, &pattr); - return; - } - } -#endif - - GC gc; - - if ( mask && !mono_src ) { // fast masked blt - bool temp_gc = FALSE; - if ( mask->data->maskgc ) { - gc = (GC)mask->data->maskgc; // we have a premade mask GC - } else { - if ( FALSE && src_pm->optimization() == TQPixmap::NormalOptim ) { // #### cache disabled - // Compete for the global cache - gc = cache_mask_gc( dpy, dst->handle(), - mask->data->ser_no, - mask->handle() ); - } else { - // Create a new mask GC. If BestOptim, we store the mask GC - // with the mask (not at the pixmap). This way, many pixmaps - // which have a common mask will be optimized at no extra cost. - gc = XCreateGC( dpy, dst->handle(), 0, 0 ); - XSetGraphicsExposures( dpy, gc, False ); - XSetClipMask( dpy, gc, mask->handle() ); - if ( src_pm->optimization() == TQPixmap::BestOptim ) { - mask->data->maskgc = gc; - } else { - temp_gc = TRUE; - } - } - } - XSetClipOrigin( dpy, gc, dx-sx, dy-sy ); - if ( rop != TQt::CopyROP ) // use non-default ROP code - XSetFunction( dpy, gc, ropCodes[rop] ); - if ( include_inferiors ) { - XSetSubwindowMode( dpy, gc, IncludeInferiors ); - XCopyArea( dpy, src->handle(), dst->handle(), gc, sx, sy, sw, sh, - dx, dy ); - XSetSubwindowMode( dpy, gc, ClipByChildren ); - } else { - XCopyArea( dpy, src->handle(), dst->handle(), gc, sx, sy, sw, sh, - dx, dy ); - } - - if ( temp_gc ) // delete temporary GC - XFreeGC( dpy, gc ); - else if ( rop != TQt::CopyROP ) // restore ROP - XSetFunction( dpy, gc, GXcopy ); - return; - } - - gc = qt_xget_temp_gc( dst->x11Screen(), mono_dst ); // get a reusable GC - - if ( rop != TQt::CopyROP ) // use non-default ROP code - XSetFunction( dpy, gc, ropCodes[rop] ); - - if ( mono_src && mono_dst && src == dst ) { // dst and src are the same bitmap - XCopyArea( dpy, src->handle(), dst->handle(), gc, sx, sy, sw, sh, dx, dy ); - } else if ( mono_src ) { // src is bitmap - XGCValues gcvals; - ulong valmask = GCBackground | GCForeground | GCFillStyle | - GCStipple | GCTileStipXOrigin | GCTileStipYOrigin; - if ( td == TQInternal::Widget ) { // set GC colors - TQWidget *w = (TQWidget *)dst; - gcvals.background = w->backgroundColor().pixel( dst->x11Screen() ); - gcvals.foreground = w->foregroundColor().pixel( dst->x11Screen() ); - if ( include_inferiors ) { - valmask |= GCSubwindowMode; - gcvals.subwindow_mode = IncludeInferiors; - } - } else if ( mono_dst ) { - gcvals.background = 0; - gcvals.foreground = 1; - } else { - gcvals.background = TQt::white.pixel( dst->x11Screen() ); - gcvals.foreground = TQt::black.pixel( dst->x11Screen() ); - } - - gcvals.fill_style = FillOpaqueStippled; - gcvals.stipple = src->handle(); - gcvals.ts_x_origin = dx - sx; - gcvals.ts_y_origin = dy - sy; - - bool clipmask = FALSE; - if ( mask ) { - if ( ((TQPixmap*)src)->data->selfmask ) { - gcvals.fill_style = FillStippled; - } else { - XSetClipMask( dpy, gc, mask->handle() ); - XSetClipOrigin( dpy, gc, dx-sx, dy-sy ); - clipmask = TRUE; - } - } - - XChangeGC( dpy, gc, valmask, &gcvals ); - XFillRectangle( dpy,dst->handle(), gc, dx, dy, sw, sh ); - - valmask = GCFillStyle | GCTileStipXOrigin | GCTileStipYOrigin; - gcvals.fill_style = FillSolid; - gcvals.ts_x_origin = 0; - gcvals.ts_y_origin = 0; - if ( include_inferiors ) { - valmask |= GCSubwindowMode; - gcvals.subwindow_mode = ClipByChildren; - } - XChangeGC( dpy, gc, valmask, &gcvals ); - - if ( clipmask ) { - XSetClipOrigin( dpy, gc, 0, 0 ); - XSetClipMask( dpy, gc, None ); - } - - } else { // src is pixmap/widget - - if ( graphics_exposure ) // widget to widget - XSetGraphicsExposures( dpy, gc, True ); - if ( include_inferiors ) { - XSetSubwindowMode( dpy, gc, IncludeInferiors ); - XCopyArea( dpy, src->handle(), dst->handle(), gc, sx, sy, sw, sh, - dx, dy ); - XSetSubwindowMode( dpy, gc, ClipByChildren ); - } else { - XCopyArea( dpy, src->handle(), dst->handle(), gc, sx, sy, sw, sh, - dx, dy ); - } - if ( graphics_exposure ) // reset graphics exposure - XSetGraphicsExposures( dpy, gc, False ); - } - - if ( rop != TQt::CopyROP ) // restore ROP - XSetFunction( dpy, gc, GXcopy ); -} - - -/*! - \relates TQPaintDevice - - \overload void bitBlt( TQPaintDevice *dst, const TQPoint &dp, const TQPaintDevice *src, const TQRect &sr, RasterOp rop ) - - Overloaded bitBlt() with the destination point \a dp and source - rectangle \a sr. -*/ - - -/*! - \internal -*/ -// makes it possible to add a setResolution as we have in TQPrinter for all -// painttqdevices without breaking bin compatibility. -void TQPaintDevice::setResolution( int ) -{ -} - -/*!\internal -*/ -int TQPaintDevice::resolution() const -{ - return metric( TQPaintDeviceMetrics::PdmDpiY ); -} - -#endif // USE_QT4
\ No newline at end of file |