summaryrefslogtreecommitdiffstats
path: root/tqtinterface/qt4/src/kernel/tqwidget_x11.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tqtinterface/qt4/src/kernel/tqwidget_x11.cpp')
-rw-r--r--tqtinterface/qt4/src/kernel/tqwidget_x11.cpp3438
1 files changed, 0 insertions, 3438 deletions
diff --git a/tqtinterface/qt4/src/kernel/tqwidget_x11.cpp b/tqtinterface/qt4/src/kernel/tqwidget_x11.cpp
deleted file mode 100644
index 532a372..0000000
--- a/tqtinterface/qt4/src/kernel/tqwidget_x11.cpp
+++ /dev/null
@@ -1,3438 +0,0 @@
-/****************************************************************************
-**
-** Implementation of TQWidget and TQWindow classes for X11
-**
-** Created : 931031
-**
-** 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 [email protected].
-**
-** 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 "tqapplication.h"
-#include "tqapplication_p.h"
-#include "tqnamespace.h"
-#include "tqpaintdevicemetrics.h"
-#include "tqpainter.h"
-#include "tqbitmap.h"
-#include "tqobjectlist.h"
-#include "tqlayout.h"
-#include "tqtextcodec.h"
-#include "tqdatetime.h"
-#include "tqcursor.h"
-#include "tqt_x11_p.h"
-#include <stdlib.h>
-
-#ifdef USE_QT4
-
-// defined in qapplication_x11.cpp
-extern Atom qt_wm_state;
-extern Atom qt_wm_change_state;
-extern Atom qt_wm_delete_window;
-extern Atom qt_wm_take_focus;
-extern Atom qt_wm_client_leader;
-extern Atom qt_window_role;
-extern Atom qt_sm_client_id;
-extern Atom qt_utf8_string;
-extern Atom qt_net_wm_context_help;
-extern Atom qt_net_wm_ping;
-extern Atom qt_xa_motif_wm_hints;
-extern Atom qt_net_wm_name;
-extern Atom qt_net_wm_icon_name;
-extern Atom qt_net_wm_state;
-extern Atom qt_net_wm_state_modal;
-extern Atom qt_net_wm_state_max_v;
-extern Atom qt_net_wm_state_max_h;
-extern Atom qt_net_wm_state_fullscreen;
-extern Atom qt_net_wm_state_above;
-extern Atom qt_net_wm_state_stays_on_top;
-extern Atom qt_net_wm_window_type;
-extern Atom qt_net_wm_window_type_normal;
-extern Atom qt_net_wm_window_type_dialog;
-extern Atom qt_net_wm_window_type_toolbar;
-extern Atom qt_net_wm_window_type_menu;
-extern Atom qt_net_wm_window_type_utility;
-extern Atom qt_net_wm_window_type_splash;
-extern Atom qt_net_wm_window_type_override;
-extern Atom qt_net_wm_window_type_dropdown_menu;
-extern Atom qt_net_wm_window_type_popup_menu;
-extern Atom qt_net_wm_window_type_combo;
-extern Atom qt_net_wm_window_type_dnd;
-extern Atom qt_net_wm_window_type_tooltip;
-extern Atom qt_net_wm_pid;
-extern Atom qt_net_wm_user_time;
-extern Atom qt_enlightenment_desktop;
-extern Atom qt_net_virtual_roots;
-extern bool qt_broken_wm;
-
-// defined in qapplication_x11.cpp
-extern bool qt_net_supports(Atom);
-extern unsigned long *qt_net_virtual_root_list;
-
-TQ_EXPORT void qt_wait_for_window_manager( TQWidget* w )
-{
- TQApplication::flushX();
- XEvent ev;
- TQTime t;
- t.start();
- while ( !XCheckTypedWindowEvent( w->x11Display(), w->winId(), ReparentNotify, &ev ) ) {
- if ( XCheckTypedWindowEvent( w->x11Display(), w->winId(), MapNotify, &ev ) )
- break;
- if ( t.elapsed() > 500 )
- return; // give up, no event available
- tqApp->syncX(); // non-busy wait
- }
- tqApp->x11ProcessEvent( &ev );
- if ( XCheckTypedWindowEvent( w->x11Display(), w->winId(), ConfigureNotify, &ev ) )
- tqApp->x11ProcessEvent( &ev );
-}
-
-static void qt_net_change_wm_state(const TQWidget* w, bool set, Atom one, Atom two = 0)
-{
- if (w->isShown()) {
- // managed by WM
- XEvent e;
- e.xclient.type = ClientMessage;
- e.xclient.message_type = qt_net_wm_state;
- e.xclient.display = const_cast<TQWidget*>(w)->x11Display();
- e.xclient.window = w->winId();
- e.xclient.format = 32;
- e.xclient.data.l[ 0 ] = set ? 1 : 0;
- e.xclient.data.l[ 1 ] = one;
- e.xclient.data.l[ 2 ] = two;
- e.xclient.data.l[ 3 ] = 0;
- e.xclient.data.l[ 4 ] = 0;
- XSendEvent(const_cast<TQWidget*>(w)->x11Display(), RootWindow(const_cast<TQWidget*>(w)->x11Display(), const_cast<TQWidget*>(w)->x11Screen()),
- False, (SubstructureNotifyMask|SubstructureRedirectMask), &e);
- } else {
- Atom ret;
- int format = 0, status;
- unsigned char *data = 0;
- unsigned long nitems = 0, after = 0;
- Atom *old_states = 0;
- status = XGetWindowProperty(const_cast<TQWidget*>(w)->x11Display(), w->winId(),
- qt_net_wm_state, 0, 1024, False,
- XA_ATOM, &ret, &format, &nitems,
- &after, &data);
- if (status == Success && ret == XA_ATOM && format == 32 && nitems > 0)
- old_states = (Atom *) data;
- else
- nitems = 0;
-
- Atom *new_states = new Atom[nitems + 2];
- int i, j = 0;
- for (i = 0; i < (int)nitems; ++i) {
- if (old_states[i] && old_states[i] != one && old_states[i] != two)
- new_states[j++] = old_states[i];
- }
-
- if (set) {
- if (one) new_states[j++] = one;
- if (two) new_states[j++] = two;
- }
-
- if (j)
- XChangeProperty(const_cast<TQWidget*>(w)->x11Display(), w->winId(), qt_net_wm_state, XA_ATOM, 32,
- PropModeReplace, (uchar *) new_states, j);
- else
- XDeleteProperty(const_cast<TQWidget*>(w)->x11Display(), w->winId(), qt_net_wm_state);
-
- delete [] new_states;
- if (data) XFree(data);
- }
-}
-
-void TQWidget::setMask( const QRegion region )
-{
- QWidget::setMask(region);
-}
-
-void TQWidget::setMask( const QBitmap bitmap )
-{
- // Work around a bug in Qt4.x (including Qt4.7) where setting any pixel in either
- // the bottom row or rightmost column of a QBitmap to Qt::color0 (i.e., transparent)
- // will cause the entire mask to beome opaque
- TQBitmap fixedBitmap = bitmap;
- fixedBitmap.resize(bitmap.width()+1, bitmap.height()+1);
- TQPainter fixerUpper(&fixedBitmap);
- fixerUpper.setBrush(Qt::color1);
- fixerUpper.setBackgroundMode(Qt::TransparentMode);
- fixerUpper.drawLine(0, fixedBitmap.height()-1, fixedBitmap.width()-1, fixedBitmap.height()-1);
- fixerUpper.drawLine(fixedBitmap.width()-1, 0, fixedBitmap.width()-1, fixedBitmap.height()-1);
- fixerUpper.end();
- QWidget::setMask(fixedBitmap.QBitmap::mask());
-}
-
-/*!
- When a widget gets focus, it should call setMicroFocusHint() with
- some appropriate position and size, \a x, \a y, \a width and \a
- height. This has no \e visual effect, it just provides hints to
- any system-specific input handling tools.
-
- The \a text argument should be TRUE if this is a position for text
- input.
-
- In the Windows version of TQt, this method sets the system caret,
- which is used for user Accessibility focus handling. If \a text
- is TRUE, it also sets the IME composition window in Far East Asian
- language input systems.
-
- In the X11 version of TQt, if \a text is TRUE, this method sets the
- XIM "spot" point for complex language input handling.
-
- The font \a f is a rendering hint to the currently active input method.
- If \a f is 0 the widget's font is used.
-
- \sa microFocusHint()
-*/
-void TQWidget::setMicroFocusHint(int x, int y, int width, int height,
- bool text, TQFont *f )
-{
-// #ifndef TQT_NO_XIM
-// if ( text ) {
-// TQWidget* tlw = tqtopLevelWidget();
-// TQTLWExtra *topdata = tlw->topData();
-//
-// // trigger input context creation if it hasn't happened already
-// createInputContext();
-// TQInputContext *qic = (TQInputContext *) topdata->xic;
-//
-// if ( qt_xim && qic ) {
-// TQPoint p( x, y );
-// TQPoint p2 = mapTo( tqtopLevelWidget(), TQPoint( 0, 0 ) );
-// p = mapTo( tqtopLevelWidget(), p);
-// qic->setXFontSet( f ? *f : fnt );
-// qic->setComposePosition(p.x(), p.y() + height);
-// qic->setComposeArea(p2.x(), p2.y(), this->width(), this->height());
-// }
-// }
-// #endif
-
- if ( TQRect( x, y, width, height ) != microFocusHint() ) {
- createExtra();
- extraData()->micro_focus_hint.setRect( x, y, width, height );
- }
-}
-
-// void TQWidget::createInputContext()
-// {
-// TQWidget *tlw = tqtopLevelWidget();
-// TQTLWExtra *topdata = tlw->topData();
-//
-// #ifndef TQT_NO_XIM
-// if (qt_xim) {
-// if (! topdata->xic) {
-// TQInputContext *qic = new TQInputContext(tlw);
-// topdata->xic = (void *) qic;
-// }
-// } else
-// #endif // TQT_NO_XIM
-// {
-// // qDebug("TQWidget::createInputContext: no xim");
-// topdata->xic = 0;
-// }
-// }
-
-/*!
- \overload void TQWidget::drawText( const TQPoint &pos, const TQString& str )
-
- Draws the string \a str at position \a pos.
-*/
-
-/*!
- Draws the string \a str at position \a(x, y).
-
- The \a y position is the base line position of the text. The text
- is drawn using the default font and the default foreground color.
-
- This function is provided for convenience. You will generally get
- more flexible results and often higher speed by using a a \link
- TQPainter painter\endlink instead.
-
- \sa setFont(), foregroundColor(), TQPainter::drawText()
-*/
-
-void TQWidget::drawText( int x, int y, const TQString &str )
-{
- if ( testWState(WState_Visible) ) {
- TQPainter paint;
- paint.begin( this );
- paint.drawText( x, y, str );
- paint.end();
- }
-}
-
-void TQWidget::createInputContext()
-{
-#if 0
-// #if !defined(TQT_NO_IM_EXTENSIONS)
- if( !isInputMethodEnabled() || TQApplication::closingDown() )
- return;
-// #endif
-
- TQWidget *icWidget = icHolderWidget();
-#ifndef TQT_NO_IM
-#if !defined(TQT_NO_IM_EXTENSIONS)
- TQInputContext **qicp = &icWidget->ic;
-#else
- TQInputContext **qicp = (TQInputContext **)&icWidget->topData()->xic;
-#endif
-
- if ( ! *qicp ) {
- // an input context of the default input method is generated.
- TQInputContext *qic = TQInputContextFactory::create( TQApplication::defaultInputMethod(), icWidget );
-
- *qicp = qic;
- if ( qic ) {
- TQObject::connect( TQT_TQOBJECT(qic), TQT_SIGNAL(imEventGenerated(TQObject *,TQIMEvent *)),
- tqApp, TQT_SLOT(postIMEvent(TQObject *,TQIMEvent *)) );
- TQObject::connect( TQT_TQOBJECT(qic), TQT_SIGNAL(deletionRequested()),
- icWidget, TQT_SLOT(destroyInputContext()) );
- }
- }
-#endif // TQT_NO_IM
-#else
- printf("[WARNING] TQWidget::createInputContext() UNIMPLEMENTED\n\r"); fflush(stdout);
-#endif
-}
-
-/*!
- This function returns the TQInputContext instance for this widget.
- This instance is used for text input to this widget, etc.
- It is simply the accessor function.
-*/
-TQInputContext *TQWidget::getInputContext()
-{
-#if 0
- TQInputContext *qic = 0;
-
-// #if !defined(TQT_NO_IM_EXTENSIONS)
- if ( isInputMethodEnabled() ) {
-#if !defined(TQT_NO_IM_EXTENSIONS)
- qic = icHolderWidget()->ic;
-#else
-// {
- // icHolderWidget is always tqtopLevelWidget
- TQTLWExtra *topdata = icHolderWidget()->topData();
- qic = (TQInputContext *)topdata->xic;
-#endif
- }
-
- return qic;
-#else
- printf("[WARNING] TQWidget::getInputContext() UNIMPLEMENTED\n\r"); fflush(stdout);
- return 0;
-#endif
-}
-
-/*!
- This function returns the widget holding the TQInputContext
- instance for this widget. The instance is used for text input to
- this widget, switching input method, etc.
-
- By default, this function delegates the role of returning input
- context holder widget to TQApplication::locateICHolderWidget().
-
- This definition enables application developer to change the
- mapping of widgets to TQInputContext instance simply by overriding
- TQApplication::locateICHolderWidget().
-
- \sa TQApplication::locateICHolderWidget()
-*/
-TQWidget *TQWidget::icHolderWidget()
-{
-#if 0
- return tqApp->locateICHolderWidget(this);
-#else
- printf("[WARNING] TQWidget::icHolderWidget() UNIMPLEMENTED\n\r"); fflush(stdout);
- return 0;
-#endif
-}
-
-void TQWidget::sendMouseEventToInputContext( int x, TQEvent::Type type, TQt::ButtonState button, TQt::ButtonState state ) {
-#if 0
-#ifndef TQT_NO_IM
- // trigger input context creation if it hasn't happened already
- createInputContext();
-
- TQInputContext *qic = getInputContext();
- if ( qic ) {
- // may be causing reset() in some input methods
- qic->mouseHandler( x, type, button, state );
- }
-#endif // TQT_NO_IM
-#else
- printf("[WARNING] TQWidget::sendMouseEventToInputContext() UNIMPLEMENTED\n\r"); fflush(stdout);
-#endif
-}
-
-void TQWidget::x11SetWindowTransient( TQWidget* parent )
-{
- XSetTransientForHint( x11Display(), winId(), parent->winId());
-}
-
-// Sets the EWMH (netwm) window type. Needed as a separate function
-// because create() may be too soon in some cases.
-void TQWidget::x11SetWindowType( X11WindowType type )
-{
- // NET window types
- long net_wintypes[7] = { 0, 0, 0, 0, 0, 0, 0 };
- int curr_wintype = 0;
- if( testWFlags(WType_Desktop))
- return;
- if( type == X11WindowTypeSelect ) {
- if ( testWFlags(WStyle_Splash)) {
- if (qt_net_supports(qt_net_wm_window_type_splash)) {
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_splash;
- }
- } else if (inherits(TQTOOLBAR_OBJECT_NAME_STRING)) {
- // toolbar netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_toolbar;
- } else if (testWFlags(WStyle_Customize) && testWFlags(WStyle_Tool)) {
- // utility netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_utility;
- } else if (testWFlags(WType_Dialog)) {
- // dialog netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_dialog;
- }
- } else if( type == X11WindowTypeCombo ) {
- // combo netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_combo;
- } else if( type == X11WindowTypeDND ) {
- // dnd netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_dnd;
- } else if( type == X11WindowTypeDropdown ) {
- // dropdown netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_dropdown_menu;
- } else if( type == X11WindowTypePopup ) {
- // popup netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_popup_menu;
- } else if( type == X11WindowTypeMenu ) {
- // menu netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_menu;
- } else if( type == X11WindowTypeTooltip ) {
- // tooltip netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_tooltip;
- }
-
- // normal netwm type - default
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_normal;
- // set _NET_WM_WINDOW_TYPE
- if (curr_wintype > 0)
- XChangeProperty(x11Display(), winId(), qt_net_wm_window_type, XA_ATOM, 32, PropModeReplace,
- (unsigned char *) net_wintypes, curr_wintype);
- else
- XDeleteProperty(x11Display(), winId(), qt_net_wm_window_type);
-}
-
-#else // USE_QT4
-
-// NOT REVISED
-
-// defined in qapplication_x11.cpp
-extern Window qt_x11_wm_client_leader;
-extern void qt_x11_create_wm_client_leader();
-
-// defined in qapplication_x11.cpp
-void qt_insert_sip( TQWidget*, int, int );
-int qt_sip_count( TQWidget* );
-bool qt_wstate_iconified( WId );
-void qt_updated_rootinfo();
-
-#ifndef TQT_NO_IM
-#include "tqinputcontext.h"
-#include "tqinputcontextfactory.h"
-#endif
-
-// Paint event clipping magic
-extern void qt_set_paintevent_clipping( TQPaintDevice* dev, const TQRegion& region);
-extern void qt_clear_paintevent_clipping();
-
-extern bool qt_dnd_enable( TQWidget* w, bool on );
-extern bool qt_nograb();
-
-// defined in qapplication_x11.cpp
-extern void qt_deferred_map_add( TQWidget* );
-extern void qt_deferred_map_take( TQWidget* );
-extern bool qt_deferred_map_contains(TQWidget *);
-
-static TQWidget *mouseGrb = 0;
-static TQWidget *keyboardGrb = 0;
-
-#ifndef TQT_NO_XSYNC
-extern Atom qt_net_wm_sync_request_counter;
-extern Atom qt_net_wm_sync_request;
-extern bool qt_use_xsync;
-#endif
-
-// defined in qfont_x11.cpp
-extern bool qt_has_xft;
-
-int qt_x11_create_desktop_on_screen = -1;
-
-/*****************************************************************************
- TQWidget member functions
- *****************************************************************************/
-
-// defined in qapplication_x11.cpp
-extern Atom qt_wm_state;
-extern Atom qt_wm_change_state;
-extern Atom qt_wm_delete_window;
-extern Atom qt_wm_take_focus;
-extern Atom qt_wm_client_leader;
-extern Atom qt_window_role;
-extern Atom qt_sm_client_id;
-extern Atom qt_utf8_string;
-extern Atom qt_net_wm_context_help;
-extern Atom qt_net_wm_ping;
-extern Atom qt_xa_motif_wm_hints;
-extern Atom qt_net_wm_name;
-extern Atom qt_net_wm_icon_name;
-extern Atom qt_net_wm_state;
-extern Atom qt_net_wm_state_modal;
-extern Atom qt_net_wm_state_max_v;
-extern Atom qt_net_wm_state_max_h;
-extern Atom qt_net_wm_state_fullscreen;
-extern Atom qt_net_wm_state_above;
-extern Atom qt_net_wm_state_stays_on_top;
-extern Atom qt_net_wm_window_type;
-extern Atom qt_net_wm_window_type_normal;
-extern Atom qt_net_wm_window_type_dialog;
-extern Atom qt_net_wm_window_type_toolbar;
-extern Atom qt_net_wm_window_type_menu;
-extern Atom qt_net_wm_window_type_utility;
-extern Atom qt_net_wm_window_type_splash;
-extern Atom qt_net_wm_window_type_override;
-extern Atom qt_net_wm_pid;
-extern Atom qt_net_wm_user_time;
-extern Atom qt_enlightenment_desktop;
-extern Atom qt_net_virtual_roots;
-extern bool qt_broken_wm;
-
-// defined in qapplication_x11.cpp
-extern bool qt_net_supports(Atom);
-extern unsigned long *qt_net_virtual_root_list;
-
-#if defined (TQT_TABLET_SUPPORT)
-extern XDevice *devStylus;
-extern XDevice *devEraser;
-extern XEventClass event_list_stylus[7];
-extern XEventClass event_list_eraser[7];
-extern int qt_curr_events_stylus;
-extern int qt_curr_events_eraser;
-#endif
-
-const uint stdWidgetEventMask = // X event mask
- (uint)(
- KeyPressMask | KeyReleaseMask |
- ButtonPressMask | ButtonReleaseMask |
- KeymapStateMask |
- ButtonMotionMask |
- EnterWindowMask | LeaveWindowMask |
- FocusChangeMask |
- ExposureMask |
- PropertyChangeMask |
- StructureNotifyMask
- );
-
-const uint stdDesktopEventMask = // X event mask
- (uint)(
- KeymapStateMask |
- EnterWindowMask | LeaveWindowMask |
- PropertyChangeMask
- );
-
-
-/*
- The qt_ functions below are implemented in qwidgetcreate_x11.cpp.
-*/
-
-Window qt_XCreateWindow( const TQWidget *creator,
- Display *display, Window parent,
- int x, int y, uint w, uint h,
- int borderwidth, int depth,
- uint windowclass, Visual *visual,
- ulong valuemask, XSetWindowAttributes *attributes );
-Window qt_XCreateSimpleWindow( const TQWidget *creator,
- Display *display, Window parent,
- int x, int y, uint w, uint h, int borderwidth,
- ulong border, ulong background );
-void qt_XDestroyWindow( const TQWidget *destroyer,
- Display *display, Window window );
-
-TQ_EXPORT void qt_x11_enforce_cursor( TQWidget * w )
-{
- if ( w->testWState( TQt::WState_OwnCursor ) ) {
- TQCursor * oc = TQApplication::overrideCursor();
- if ( oc ) {
- XDefineCursor( w->x11Display(), w->winId(), oc->handle() );
- } else if ( w->isEnabled() ) {
- XDefineCursor( w->x11Display(), w->winId(), w->cursor().handle() );
- } else {
- // enforce the windows behavior of clearing the cursor on
- // disabled widgets
- XDefineCursor( w->x11Display(), w->winId(), None );
- }
- } else {
- XDefineCursor( w->x11Display(), w->winId(), None );
- }
-}
-
-TQ_EXPORT void qt_wait_for_window_manager( TQWidget* w )
-{
- TQApplication::flushX();
- XEvent ev;
- TQTime t;
- t.start();
- while ( !XCheckTypedWindowEvent( w->x11Display(), w->winId(), ReparentNotify, &ev ) ) {
- if ( XCheckTypedWindowEvent( w->x11Display(), w->winId(), MapNotify, &ev ) )
- break;
- if ( t.elapsed() > 500 )
- return; // give up, no event available
- tqApp->syncX(); // non-busy wait
- }
- tqApp->x11ProcessEvent( &ev );
- if ( XCheckTypedWindowEvent( w->x11Display(), w->winId(), ConfigureNotify, &ev ) )
- tqApp->x11ProcessEvent( &ev );
-}
-
-static void qt_net_change_wm_state(const TQWidget* w, bool set, Atom one, Atom two = 0)
-{
- if (w->isShown()) {
- // managed by WM
- XEvent e;
- e.xclient.type = ClientMessage;
- e.xclient.message_type = qt_net_wm_state;
- e.xclient.display = w->x11Display();
- e.xclient.window = w->winId();
- e.xclient.format = 32;
- e.xclient.data.l[ 0 ] = set ? 1 : 0;
- e.xclient.data.l[ 1 ] = one;
- e.xclient.data.l[ 2 ] = two;
- e.xclient.data.l[ 3 ] = 0;
- e.xclient.data.l[ 4 ] = 0;
- XSendEvent(w->x11Display(), RootWindow(w->x11Display(), w->x11Screen()),
- False, (SubstructureNotifyMask|SubstructureRedirectMask), &e);
- } else {
- Atom ret;
- int format = 0, status;
- unsigned char *data = 0;
- unsigned long nitems = 0, after = 0;
- Atom *old_states = 0;
- status = XGetWindowProperty(w->x11Display(), w->winId(),
- qt_net_wm_state, 0, 1024, False,
- XA_ATOM, &ret, &format, &nitems,
- &after, &data);
- if (status == Success && ret == XA_ATOM && format == 32 && nitems > 0)
- old_states = (Atom *) data;
- else
- nitems = 0;
-
- Atom *new_states = new Atom[nitems + 2];
- int i, j = 0;
- for (i = 0; i < (int)nitems; ++i) {
- if (old_states[i] && old_states[i] != one && old_states[i] != two)
- new_states[j++] = old_states[i];
- }
-
- if (set) {
- if (one) new_states[j++] = one;
- if (two) new_states[j++] = two;
- }
-
- if (j)
- XChangeProperty(w->x11Display(), w->winId(), qt_net_wm_state, XA_ATOM, 32,
- PropModeReplace, (uchar *) new_states, j);
- else
- XDeleteProperty(w->x11Display(), w->winId(), qt_net_wm_state);
-
- delete [] new_states;
- if (data) XFree(data);
- }
-}
-
-/*!
- Creates a new widget window if \a window is 0, otherwise sets the
- widget's window to \a window.
-
- Initializes the window (sets the tqgeometry etc.) if \a
- initializeWindow is TRUE. If \a initializeWindow is FALSE, no
- initialization is performed. This parameter only makes sense if \a
- window is a valid window.
-
- Destroys the old window if \a destroyOldWindow is TRUE. If \a
- destroyOldWindow is FALSE, you are responsible for destroying the
- window yourself (using platform native code).
-
- The TQWidget constructor calls create(0,TRUE,TRUE) to create a
- window for this widget.
-*/
-
-void TQWidget::create( WId window, bool initializeWindow, bool destroyOldWindow)
-{
- if ( testWState(WState_Created) && window == 0 )
- return;
-
- // set created flag
- setWState( WState_Created );
-
- bool popup = testWFlags(WType_Popup);
- bool dialog = testWFlags(WType_Dialog);
- bool desktop = testWFlags(WType_Desktop);
-
- // top-level widget
- if ( !parentWidget() || parentWidget()->isDesktop() )
- setWFlags( WType_TopLevel );
-
- // these are top-level, too
- if ( dialog || popup || desktop || testWFlags(WStyle_Splash))
- setWFlags( WType_TopLevel );
-
- // a popup stays on top
- if ( popup )
- setWFlags(WStyle_StaysOnTop);
-
- bool topLevel = testWFlags(WType_TopLevel);
- Window parentw, destroyw = 0;
- WId id;
-
- // always initialize
- if ( !window )
- initializeWindow = TRUE;
-
- if ( desktop &&
- qt_x11_create_desktop_on_screen >= 0 &&
- qt_x11_create_desktop_on_screen != x11Screen() ) {
- // desktop on a certain screen other than the default requested
- TQPaintDeviceX11Data* xd = getX11Data( TRUE );
- xd->x_screen = qt_x11_create_desktop_on_screen;
- xd->x_depth = TQPaintDevice::x11AppDepth( xd->x_screen );
- xd->x_cells = TQPaintDevice::x11AppCells( xd->x_screen );
- xd->x_colormap = TQPaintDevice::x11AppColormap( xd->x_screen );
- xd->x_defcolormap = TQPaintDevice::x11AppDefaultColormap( xd->x_screen );
- xd->x_visual = TQPaintDevice::x11AppVisual( xd->x_screen );
- xd->x_defvisual = TQPaintDevice::x11AppDefaultVisual( xd->x_screen );
- setX11Data( xd );
- } else if ( parentWidget() && parentWidget()->x11Screen() != x11Screen() ) {
- // if we have a parent widget, move to its screen if necessary
- TQPaintDeviceX11Data* xd = getX11Data( TRUE );
- xd->x_screen = parentWidget()->x11Screen();
- xd->x_depth = TQPaintDevice::x11AppDepth( xd->x_screen );
- xd->x_cells = TQPaintDevice::x11AppCells( xd->x_screen );
- xd->x_colormap = TQPaintDevice::x11AppColormap( xd->x_screen );
- xd->x_defcolormap = TQPaintDevice::x11AppDefaultColormap( xd->x_screen );
- xd->x_visual = TQPaintDevice::x11AppVisual( xd->x_screen );
- xd->x_defvisual = TQPaintDevice::x11AppDefaultVisual( xd->x_screen );
- setX11Data( xd );
- }
-
- //get display, screen number, root window and desktop tqgeometry for
- //the current screen
- Display *dpy = x11Display();
- int scr = x11Screen();
- Window root_win = RootWindow( dpy, scr );
- int sw = DisplayWidth(dpy,scr);
- int sh = DisplayHeight(dpy,scr);
-
- if ( desktop ) { // desktop widget
- dialog = popup = FALSE; // force these flags off
- crect.setRect( 0, 0, sw, sh );
- } else if ( topLevel ) { // calc pos/size from screen
- crect.setRect( sw/4, 3*sh/10, sw/2, 4*sh/10 );
- } else { // child widget
- crect.setRect( 0, 0, 100, 30 );
- }
-
- parentw = topLevel ? root_win : parentWidget()->winId();
-
- XSetWindowAttributes wsa;
-
- if ( window ) { // override the old window
- if ( destroyOldWindow )
- destroyw = winid;
- id = window;
- setWinId( window );
- XWindowAttributes a;
- XGetWindowAttributes( dpy, window, &a );
- crect.setRect( a.x, a.y, a.width, a.height );
-
- if ( a.map_state == IsUnmapped )
- clearWState( WState_Visible );
- else
- setWState( WState_Visible );
-
- TQPaintDeviceX11Data* xd = getX11Data( TRUE );
-
- // find which screen the window is on...
- xd->x_screen = TQPaintDevice::x11AppScreen(); // by default, use the default :)
- int i;
- for ( i = 0; i < ScreenCount( dpy ); i++ ) {
- if ( RootWindow( dpy, i ) == a.root ) {
- xd->x_screen = i;
- break;
- }
- }
-
- xd->x_depth = a.depth;
- xd->x_cells = DisplayCells( dpy, xd->x_screen );
- xd->x_visual = a.visual;
- xd->x_defvisual = ( XVisualIDFromVisual( a.visual ) ==
- XVisualIDFromVisual( (Visual*)x11AppVisual(x11Screen()) ) );
- xd->x_colormap = a.colormap;
- xd->x_defcolormap = ( a.colormap == x11AppColormap( x11Screen() ) );
- setX11Data( xd );
- } else if ( desktop ) { // desktop widget
- id = (WId)parentw; // id = root window
- TQWidget *otherDesktop = find( id ); // is there another desktop?
- if ( otherDesktop && otherDesktop->testWFlags(WPaintDesktop) ) {
- otherDesktop->setWinId( 0 ); // remove id from widget mapper
- setWinId( id ); // make sure otherDesktop is
- otherDesktop->setWinId( id ); // found first
- } else {
- setWinId( id );
- }
- } else {
- if ( x11DefaultVisual() && x11DefaultColormap() ) {
- id = (WId)qt_XCreateSimpleWindow( this, dpy, parentw,
- crect.left(), crect.top(),
- crect.width(), crect.height(),
- 0,
- black.pixel(x11Screen()),
- bg_col.pixel(x11Screen()) );
- } else {
- wsa.background_pixel = bg_col.pixel(x11Screen());
- wsa.border_pixel = black.pixel(x11Screen());
- wsa.colormap = (Colormap)x11Colormap();
- id = (WId)qt_XCreateWindow( this, dpy, parentw,
- crect.left(), crect.top(),
- crect.width(), crect.height(),
- 0, x11Depth(), InputOutput,
- (Visual*)x11Visual(),
- CWBackPixel|CWBorderPixel|CWColormap,
- &wsa );
- }
-
- setWinId( id ); // set widget id/handle + hd
- }
-
-#ifndef TQT_NO_XFTFREETYPE
- if (rendhd) {
- XftDrawDestroy( (XftDraw *) rendhd );
- rendhd = 0;
- }
-
- if ( qt_has_xft )
- rendhd = (HANDLE) XftDrawCreate( dpy, id, (Visual *) x11Visual(),
- x11Colormap() );
-#endif // TQT_NO_XFTFREETYPE
-
- // NET window states
- long net_winstates[6] = { 0, 0, 0, 0, 0, 0 };
- int curr_winstate = 0;
-
- struct {
- ulong flags, functions, decorations;
- long input_mode;
- ulong status;
- } mwmhints;
-
- mwmhints.flags = mwmhints.functions = 0L;
- mwmhints.decorations = (1L << 0); // MWM_DECOR_ALL
- mwmhints.input_mode = 0L;
- mwmhints.status = 0L;
-
- if (topLevel && ! (desktop || popup)) {
- ulong wsa_mask = 0;
-
- if ( testWFlags(WStyle_Splash) ) {
- if (qt_net_supports(qt_net_wm_window_type_splash)) {
- clearWFlags( WX11BypassWM );
- } else {
- setWFlags( WX11BypassWM | WStyle_Tool | WStyle_NoBorder );
- }
- }
- if (testWFlags(WStyle_Customize)) {
- mwmhints.decorations = 0L;
- mwmhints.flags |= (1L << 1); // MWM_HINTS_DECORATIONS
-
- if ( testWFlags( WStyle_NormalBorder | WStyle_DialogBorder ) ) {
- mwmhints.decorations |= (1L << 1); // MWM_DECOR_BORDER
- mwmhints.decorations |= (1L << 2); // MWM_DECOR_RESIZEH
- }
-
- if ( testWFlags( WStyle_Title ) )
- mwmhints.decorations |= (1L << 3); // MWM_DECOR_TITLE
-
- if ( testWFlags( WStyle_SysMenu ) )
- mwmhints.decorations |= (1L << 4); // MWM_DECOR_MENU
-
- if ( testWFlags( WStyle_Minimize ) )
- mwmhints.decorations |= (1L << 5); // MWM_DECOR_MINIMIZE
-
- if ( testWFlags( WStyle_Maximize ) )
- mwmhints.decorations |= (1L << 6); // MWM_DECOR_MAXIMIZE
-
- if (testWFlags(WStyle_Tool)) {
- wsa.save_under = True;
- wsa_mask |= CWSaveUnder;
- }
- } else if (testWFlags(WType_Dialog)) {
- setWFlags(WStyle_NormalBorder | WStyle_Title |
- WStyle_SysMenu | WStyle_ContextHelp);
- } else {
- setWFlags(WStyle_NormalBorder | WStyle_Title |
- WStyle_MinMax | WStyle_SysMenu);
-
- // maximized netwm state
- if (testWFlags(WState_Maximized)) {
- net_winstates[curr_winstate++] = qt_net_wm_state_max_v;
- net_winstates[curr_winstate++] = qt_net_wm_state_max_h;
- }
- }
-
- // stays on top
- if (testWFlags(WStyle_StaysOnTop)) {
- net_winstates[curr_winstate++] = qt_net_wm_state_above;
- net_winstates[curr_winstate++] = qt_net_wm_state_stays_on_top;
- }
-
- if (testWFlags(WShowModal)) {
- mwmhints.input_mode = 3L; // MWM_INPUT_FULL_APPLICATION_MODAL
- mwmhints.flags |= (1L << 2); // MWM_HINTS_INPUT_MODE
-
- net_winstates[curr_winstate++] = qt_net_wm_state_modal;
- }
-
- if ( testWFlags( WX11BypassWM ) ) {
- wsa.override_redirect = True;
- wsa_mask |= CWOverrideRedirect;
- }
-
- if ( wsa_mask && initializeWindow )
- XChangeWindowAttributes( dpy, id, wsa_mask, &wsa );
- } else {
- if (! testWFlags(WStyle_Customize))
- setWFlags(WStyle_NormalBorder | WStyle_Title |
- WStyle_MinMax | WStyle_SysMenu);
- }
-
-
- if ( !initializeWindow ) {
- // do no initialization
- } else if ( popup ) { // popup widget
- wsa.override_redirect = True;
- wsa.save_under = True;
- XChangeWindowAttributes( dpy, id, CWOverrideRedirect | CWSaveUnder,
- &wsa );
- x11SetWindowType();
- } else if ( topLevel && !desktop ) { // top-level widget
- TQWidget *p = parentWidget(); // real parent
- if (p)
- p = p->tqtopLevelWidget();
-
- if (dialog || testWFlags(WStyle_DialogBorder) || testWFlags(WStyle_Tool)) {
- if ( p )
- XSetTransientForHint( dpy, id, p->winId() );
- else // application-modal
- XSetTransientForHint( dpy, id, root_win );
- }
-
- // find the real client leader, i.e. a toplevel without parent
- while ( p && p->parentWidget())
- p = p->parentWidget()->tqtopLevelWidget();
-
- XSizeHints size_hints;
- size_hints.flags = USSize | PSize | PWinGravity;
- size_hints.x = crect.left();
- size_hints.y = crect.top();
- size_hints.width = crect.width();
- size_hints.height = crect.height();
- size_hints.win_gravity =
- TQApplication::reverseLayout() ? NorthEastGravity : NorthWestGravity;
-
- XWMHints wm_hints; // window manager hints
- wm_hints.input = True;
- wm_hints.initial_state = NormalState;
- wm_hints.flags = InputHint | StateHint;
- if ( !qt_x11_wm_client_leader )
- qt_x11_create_wm_client_leader();
-
- wm_hints.window_group = qt_x11_wm_client_leader;
- wm_hints.flags |= WindowGroupHint;
-
- XClassHint class_hint;
- class_hint.res_name = (char *) tqAppName(); // application name
- class_hint.res_class = (char *) tqAppClass(); // application class
-
- XSetWMProperties( dpy, id, 0, 0, 0, 0, &size_hints, &wm_hints, &class_hint );
-
- XResizeWindow( dpy, id, crect.width(), crect.height() );
- XStoreName( dpy, id, tqAppName() );
- Atom protocols[5];
- int n = 0;
- protocols[n++] = qt_wm_delete_window; // support del window protocol
- protocols[n++] = qt_wm_take_focus; // support take focus window protocol
- protocols[n++] = qt_net_wm_ping; // support _NET_WM_PING protocol
-#ifndef TQT_NO_XSYNC
- protocols[n++] = qt_net_wm_sync_request;// support the _NET_WM_SYNC_REQUEST protocol
-#endif
- if ( testWFlags( WStyle_ContextHelp ) )
- protocols[n++] = qt_net_wm_context_help;
- XSetWMProtocols( dpy, id, protocols, n );
-
- // set mwm hints
- if ( mwmhints.flags != 0l )
- XChangeProperty(dpy, id, qt_xa_motif_wm_hints, qt_xa_motif_wm_hints, 32,
- PropModeReplace, (unsigned char *) &mwmhints, 5);
- else
- XDeleteProperty(dpy, id, qt_xa_motif_wm_hints);
-
- x11SetWindowType();
-
- // set _NET_WM_WINDOW_STATE
- if (curr_winstate > 0)
- XChangeProperty(dpy, id, qt_net_wm_state, XA_ATOM, 32, PropModeReplace,
- (unsigned char *) net_winstates, curr_winstate);
- else
- XDeleteProperty(dpy, id, qt_net_wm_state);
-
- // set _NET_WM_PID
- long curr_pid = getpid();
- XChangeProperty(dpy, id, qt_net_wm_pid, XA_CARDINAL, 32, PropModeReplace,
- (unsigned char *) &curr_pid, 1);
-
-#ifndef TQT_NO_XSYNC
- // set _NET_WM_SYNC_COUNTER
- createSyncCounter();
- long counterVal = topData()->syncCounter;
- XChangeProperty( dpy, id, qt_net_wm_sync_request_counter, XA_CARDINAL, 32, PropModeReplace,
- (unsigned char*) &counterVal, 1);
-#endif
-
- // when we create a toplevel widget, the frame strut should be dirty
- fstrut_dirty = 1;
-
- // declare the widget's object name as window role
- XChangeProperty( dpy, id,
- qt_window_role, XA_STRING, 8, PropModeReplace,
- (unsigned char *)name(), tqstrlen( name() ) );
-
- // set client leader property
- XChangeProperty( dpy, id, qt_wm_client_leader,
- XA_WINDOW, 32, PropModeReplace,
- (unsigned char *)&qt_x11_wm_client_leader, 1 );
- } else {
- // non-toplevel widgets don't have a frame, so no need to
- // update the strut
- fstrut_dirty = 0;
- }
-
- if ( initializeWindow ) {
- // don't erase when resizing
- wsa.bit_gravity =
- TQApplication::reverseLayout() ? NorthEastGravity : NorthWestGravity;
- XChangeWindowAttributes( dpy, id, CWBitGravity, &wsa );
- }
-
- setWState( WState_MouseTracking );
- setMouseTracking( FALSE ); // also sets event mask
- if ( desktop ) {
- setWState( WState_Visible );
- } else if ( topLevel ) { // set X cursor
- setWState( WState_OwnCursor );
- if ( initializeWindow )
- qt_x11_enforce_cursor( this );
- }
-
- if ( destroyw )
- qt_XDestroyWindow( this, dpy, destroyw );
-
-#if !defined(TQT_NO_IM_EXTENSIONS)
- ic = 0;
-#endif
-}
-
-
-/*!
- Frees up window system resources. Destroys the widget window if \a
- destroyWindow is TRUE.
-
- destroy() calls itself recursively for all the child widgets,
- passing \a destroySubWindows for the \a destroyWindow parameter.
- To have more control over destruction of subwidgets, destroy
- subwidgets selectively first.
-
- This function is usually called from the TQWidget destructor.
-*/
-
-void TQWidget::destroy( bool destroyWindow, bool destroySubWindows )
-{
- deactivateWidgetCleanup();
- if ( testWState(WState_Created) ) {
- clearWState( WState_Created );
- if ( childrenListObject() ) {
- TQObjectListIt it(*childrenListObject());
- register TQObject *obj;
- while ( (obj=it.current()) ) { // destroy all widget tqchildren
- ++it;
- if ( obj->isWidgetType() )
- ((TQWidget*)obj)->destroy(destroySubWindows,
- destroySubWindows);
- }
- }
- if ( mouseGrb == this )
- releaseMouse();
- if ( keyboardGrb == this )
- releaseKeyboard();
- if ( isTopLevel() )
- qt_deferred_map_take( this );
- if ( testWFlags(WShowModal) ) // just be sure we leave modal
- qt_leave_modal( this );
- else if ( testWFlags(WType_Popup) )
- tqApp->closePopup( this );
-
-#ifndef TQT_NO_XFTFREETYPE
- if ( rendhd) {
- if ( destroyWindow )
- XftDrawDestroy( (XftDraw *) rendhd );
- else
- free( (void*) rendhd );
- rendhd = 0;
- }
-#endif // TQT_NO_XFTFREETYPE
-
- if ( testWFlags(WType_Desktop) ) {
- if ( acceptDrops() )
- qt_dnd_enable( this, FALSE );
- } else {
- if ( destroyWindow )
- qt_XDestroyWindow( this, x11Display(), winid );
- }
-#ifndef TQT_NO_XSYNC
- destroySyncCounter();
-#endif
- setWinId( 0 );
-
- extern void qPRCleanup( TQWidget *widget ); // from qapplication_x11.cpp
- if ( testWState(WState_Reparented) )
- qPRCleanup(this);
-
- if( this == icHolderWidget() ) {
- destroyInputContext();
- } else {
- // release previous focus information participating with
- // preedit preservation of qic
- TQInputContext *qic = getInputContext();
- if ( qic )
- qic->releaseComposingWidget( this );
- }
- }
-}
-
-void TQWidget::reparentSys( TQWidget *parent, WFlags f, const TQPoint &p, bool showIt )
-{
- extern void qPRCreate( const TQWidget *, Window );
-
- Display *dpy = x11Display();
- TQCursor oldcurs;
- bool setcurs = testWState(WState_OwnCursor);
- if ( setcurs ) {
- oldcurs = cursor();
- unsetCursor();
- }
-
- // dnd unregister (we will register again below)
- bool accept_drops = acceptDrops();
- setAcceptDrops( FALSE );
-
- // clear mouse tracking, re-enabled below
- bool mouse_tracking = hasMouseTracking();
- clearWState(WState_MouseTracking);
-
- TQWidget* oldtlw = tqtopLevelWidget();
- TQWidget *oldparent = parentWidget();
- WId old_winid = winid;
- if ( testWFlags(WType_Desktop) )
- old_winid = 0;
- setWinId( 0 );
-
- // hide and reparent our own window away. Otherwise we might get
- // destroyed when emitting the child remove event below. See TQWorkspace.
- XUnmapWindow( x11Display(), old_winid );
- XReparentWindow( x11Display(), old_winid,
- RootWindow( x11Display(), x11Screen() ), 0, 0 );
-
- if ( this == icHolderWidget() ) {
- // input contexts are sometimes associated with toplevel widgets, so
- // we need destroy the context here. if we are reparenting back to
- // toplevel, then we may have another context created, otherwise we
- // will use our new ic holder's context
- destroyInputContext();
- }
-
-#ifndef TQT_NO_XSYNC
- destroySyncCounter();
-#endif
-
- if ( isTopLevel() || !parent ) // we are toplevel, or reparenting to toplevel
- topData()->parentWinId = 0;
-
- if ( parent != parentObj ) {
- if ( parentObj ) // remove from parent
- parentObj->removeChild( this );
- if ( parent ) // insert into new parent
- parent->insertChild( this );
- }
- bool enable = isEnabled(); // remember status
- FocusPolicy fp = focusPolicy();
- TQSize s = size();
- TQPixmap *bgp = (TQPixmap *)backgroundPixmap();
- TQColor bgc = bg_col; // save colors
- TQString capt= caption();
- widget_flags = f;
- clearWState( WState_Created | WState_Visible | WState_ForceHide );
- create();
- if ( isTopLevel() || (!parent || parent->isVisible() ) )
- setWState( WState_ForceHide ); // new widgets do not show up in already visible parents
-
- const TQObjectList *chlist = childrenListObject();
- if ( chlist ) { // reparent tqchildren
- TQObjectList childList(*chlist);
- TQObjectListIt it(childList); // iterate over copy
- TQObject *obj;
- while ( (obj=it.current()) ) {
- if ( obj->isWidgetType() ) {
- TQWidget *w = (TQWidget *)obj;
- if ( !w->isTopLevel() ) {
- XReparentWindow( x11Display(), w->winId(), winId(),
- w->tqgeometry().x(), w->tqgeometry().y() );
- } else if ( w->isPopup()
- || w->testWFlags(WStyle_DialogBorder)
- || w->testWFlags(WType_Dialog)
- || w->testWFlags(WStyle_Tool) ) {
- /*
- when reparenting toplevel windows with toplevel-transient tqchildren,
- we need to make sure that the window manager gets the updated
- WM_TRANSIENT_FOR information... unfortunately, some window managers
- don't handle changing WM_TRANSIENT_FOR before the toplevel window is
- visible, so we unmap and remap all toplevel-transient tqchildren *after*
- the toplevel parent has been mapped. thankfully, this is easy in TQt :)
- */
- XUnmapWindow(w->x11Display(), w->winId());
- XSetTransientForHint(w->x11Display(), w->winId(), winId());
- TQApplication::postEvent(w, new TQEvent(TQEvent::ShowWindowRequest));
- }
- }
- ++it;
- }
- }
- qPRCreate( this, old_winid );
- if ( bgp )
- XSetWindowBackgroundPixmap( dpy, winid, bgp->handle() );
- else
- XSetWindowBackground( dpy, winid, bgc.pixel(x11Screen()) );
-
- if (isTopLevel()) {
- // preserve maximized/fullscreen flags and the normal tqgeometry
- uint save_state = widget_state & (WState_Maximized | WState_FullScreen);
- const TQRect r = topData()->normalGeometry;
- setGeometry(p.x(), p.y(), s.width(), s.height());
- widget_state |= save_state;
- topData()->normalGeometry = r;
- } else {
- setGeometry(p.x(), p.y(), s.width(), s.height());
- }
-
- setEnabled( enable );
- setFocusPolicy( fp );
- if ( !capt.isNull() ) {
- extra->topextra->caption = TQString::null;
- setCaption( capt );
- }
- if ( showIt )
- show();
- if ( old_winid )
- qt_XDestroyWindow( this, dpy, old_winid );
- if ( setcurs )
- setCursor(oldcurs);
-
- reparentFocusWidgets( oldtlw );
-
- // re-register dnd
- if (oldparent)
- oldparent->checkChildrenDnd();
-
- if ( accept_drops )
- setAcceptDrops( TRUE );
- else {
- checkChildrenDnd();
- topData()->dnd = 0;
- qt_dnd_enable(this, (extra && extra->tqchildren_use_dnd));
- }
-
- // re-enable mouse tracking
- if (mouse_tracking)
- setMouseTracking(mouse_tracking);
-}
-
-// Sets the EWMH (netwm) window type. Needed as a separate function
-// because create() may be too soon in some cases.
-void TQWidget::x11SetWindowType( X11WindowType type )
-{
- // NET window types
- long net_wintypes[7] = { 0, 0, 0, 0, 0, 0, 0 };
- int curr_wintype = 0;
- if( testWFlags(WType_Desktop))
- return;
- if( type == X11WindowTypeSelect ) {
- if ( testWFlags(WStyle_Splash)) {
- if (qt_net_supports(qt_net_wm_window_type_splash)) {
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_splash;
- }
- } else if (inherits(TQTOOLBAR_OBJECT_NAME_STRING)) {
- // toolbar netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_toolbar;
- } else if (testWFlags(WStyle_Customize) && testWFlags(WStyle_Tool)) {
- // utility netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_utility;
- } else if (testWFlags(WType_Dialog)) {
- // dialog netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_dialog;
- }
- } else if( type == X11WindowTypeCombo ) {
- // combo netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_combo;
- } else if( type == X11WindowTypeDND ) {
- // dnd netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_dnd;
- } else if( type == X11WindowTypeDropdown ) {
- // dropdown netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_dropdown_menu;
- } else if( type == X11WindowTypePopup ) {
- // popup netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_popup_menu;
- } else if( type == X11WindowTypeMenu ) {
- // menu netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_menu;
- } else if( type == X11WindowTypeTooltip ) {
- // tooltip netwm type
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_tooltip;
- }
-
- // normal netwm type - default
- net_wintypes[curr_wintype++] = qt_net_wm_window_type_normal;
- // set _NET_WM_WINDOW_TYPE
- if (curr_wintype > 0)
- XChangeProperty(x11Display(), winId(), qt_net_wm_window_type, XA_ATOM, 32, PropModeReplace,
- (unsigned char *) net_wintypes, curr_wintype);
- else
- XDeleteProperty(x11Display(), winId(), qt_net_wm_window_type);
-}
-
-void TQWidget::x11SetWindowTransient( TQWidget* parent )
-{
- XSetTransientForHint( x11Display(), winId(), parent->winId());
-}
-
-/*!
- Translates the widget coordinate \a pos to global screen
- coordinates. For example, \c{mapToGlobal(TQPoint(0,0))} would give
- the global coordinates of the top-left pixel of the widget.
-
- \sa mapFromGlobal() mapTo() mapToParent()
-*/
-
-TQPoint TQWidget::mapToGlobal( const TQPoint &pos ) const
-{
- int x, y;
- Window child;
- XTranslateCoordinates( x11Display(), winId(),
- TQApplication::desktop()->screen(x11Screen())->winId(),
- pos.x(), pos.y(), &x, &y, &child );
- return TQPoint( x, y );
-}
-
-/*!
- Translates the global screen coordinate \a pos to widget
- coordinates.
-
- \sa mapToGlobal() mapFrom() mapFromParent()
-*/
-
-TQPoint TQWidget::mapFromGlobal( const TQPoint &pos ) const
-{
- int x, y;
- Window child;
- XTranslateCoordinates( x11Display(),
- TQApplication::desktop()->screen(x11Screen())->winId(),
- winId(), pos.x(), pos.y(), &x, &y, &child );
- return TQPoint( x, y );
-}
-
-/*!
- When a widget gets focus, it should call setMicroFocusHint() with
- some appropriate position and size, \a x, \a y, \a width and \a
- height. This has no \e visual effect, it just provides hints to
- any system-specific input handling tools.
-
- The \a text argument should be TRUE if this is a position for text
- input.
-
- In the Windows version of TQt, this method sets the system caret,
- which is used for user Accessibility focus handling. If \a text
- is TRUE, it also sets the IME composition window in Far East Asian
- language input systems.
-
- In the X11 version of TQt, if \a text is TRUE, this method sets the
- input method focus point in the preedit (XIM "spot" point) for
- complex language input handling.
-
- The font \a f is a rendering hint to the currently active input method.
- If \a f is 0 the widget's font is used.
-
- \sa microFocusHint()
-*/
-void TQWidget::setMicroFocusHint(int x, int y, int width, int height,
- bool text, TQFont *f )
-{
-#ifndef TQT_NO_IM
- if ( text ) {
- // trigger input context creation if it hasn't happened already
- createInputContext();
-
- TQInputContext *qic = getInputContext();
- if(qic) {
- TQPoint gp = mapToGlobal( TQPoint( x, y ) );
- qic->setMicroFocus(gp.x(), gp.y(), width, height, f);
- }
- }
-#endif
-
- if ( TQRect( x, y, width, height ) != microFocusHint() ) {
- createExtra();
- extraData()->micro_focus_hint.setRect( x, y, width, height );
- }
-}
-
-
-void TQWidget::setFontSys( TQFont * )
-{
- // Nothing
-}
-
-
-void TQWidget::setBackgroundColorDirect( const TQColor &color )
-{
- bg_col = color;
- if ( extra && extra->bg_pix ) { // kill the background pixmap
- delete extra->bg_pix;
- extra->bg_pix = 0;
- }
- XSetWindowBackground( x11Display(), winId(), bg_col.pixel(x11Screen()) );
-}
-
-static int allow_null_pixmaps = 0;
-
-
-void TQWidget::setBackgroundPixmapDirect( const TQPixmap &pixmap )
-{
- TQPixmap old;
- if ( extra && extra->bg_pix )
- old = *extra->bg_pix;
- if ( !allow_null_pixmaps && pixmap.isNull() ) {
- XSetWindowBackground( x11Display(), winId(), bg_col.pixel(x11Screen()) );
- if ( extra && extra->bg_pix ) {
- delete extra->bg_pix;
- extra->bg_pix = 0;
- }
- } else {
- TQPixmap pm = pixmap;
- if (!pm.isNull()) {
- if ( pm.depth() == 1 && TQPixmap::defaultDepth() > 1 ) {
- pm = TQPixmap( pixmap.size() );
- bitBlt( &pm, 0, 0, &pixmap, 0, 0, pm.width(), pm.height() );
- }
- }
- if ( extra && extra->bg_pix )
- delete extra->bg_pix;
- else
- createExtra();
- extra->bg_pix = new TQPixmap( pm );
- TQ_CHECK_PTR( extra->bg_pix );
- extra->bg_pix->x11SetScreen( x11Screen() );
- XSetWindowBackgroundPixmap( x11Display(), winId(), extra->bg_pix->handle() );
- if ( testWFlags(WType_Desktop) ) // save rootinfo later
- qt_updated_rootinfo();
- }
-}
-
-
-/*!
- Sets the window-system background of the widget to nothing.
-
- Note that "nothing" is actually a pixmap that isNull(), thus you
- can check for an empty background by checking backgroundPixmap().
-
- \sa setBackgroundPixmap(), setBackgroundColor()
-*/
-void TQWidget::setBackgroundEmpty()
-{
- allow_null_pixmaps++;
- setErasePixmap(TQPixmap());
- allow_null_pixmaps--;
-}
-
-
-void TQWidget::setBackgroundX11Relative()
-{
- XSetWindowBackgroundPixmap( x11Display(), winId(), ParentRelative );
-}
-
-void TQWidget::setCursor( const TQCursor &cursor )
-{
- if ( cursor.handle() != arrowCursor.handle()
- || (extra && extra->curs) ) {
- createExtra();
- delete extra->curs;
- extra->curs = new TQCursor(cursor);
- }
- setWState( WState_OwnCursor );
- qt_x11_enforce_cursor( this );
- XFlush( x11Display() );
-}
-
-void TQWidget::unsetCursor()
-{
- if ( extra ) {
- delete extra->curs;
- extra->curs = 0;
- }
- if ( !isTopLevel() )
- clearWState( WState_OwnCursor );
- qt_x11_enforce_cursor( this );
- XFlush( x11Display() );
-}
-
-static XTextProperty*
-qstring_to_xtp( const TQString& s )
-{
- static XTextProperty tp = { 0, 0, 0, 0 };
- static bool free_prop = TRUE; // we can't free tp.value in case it references
- // the data of the static TQCString below.
- if ( tp.value ) {
- if ( free_prop )
- XFree( tp.value );
- tp.value = 0;
- free_prop = TRUE;
- }
-
- static const TQTextCodec* mapper = TQTextCodec::codecForLocale();
- int errCode = 0;
- if ( mapper ) {
- TQCString mapped = mapper->fromUnicode(s);
- char* tl[2];
- tl[0] = mapped.data();
- tl[1] = 0;
- errCode = XmbTextListToTextProperty( TQPaintDevice::x11AppDisplay(),
- tl, 1, XStdICCTextStyle, &tp );
-#if defined(TQT_DEBUG)
- if ( errCode < 0 )
- qDebug( "qstring_to_xtp result code %d", errCode );
-#endif
- }
- if ( !mapper || errCode < 0 ) {
- static TQCString qcs;
- qcs = s.ascii();
- tp.value = (uchar*)qcs.data();
- tp.encoding = XA_STRING;
- tp.format = 8;
- tp.nitems = qcs.length();
- free_prop = FALSE;
- }
-
- // ### If we knew WM could understand tqunicode, we could use
- // ### a much simpler, cheaper encoding...
- /*
- tp.value = (XChar2b*)s.tqunicode();
- tp.encoding = XA_UNICODE; // wish
- tp.format = 16;
- tp.nitems = s.length();
- */
-
- return &tp;
-}
-
-void TQWidget::setCaption( const TQString &caption )
-{
- if ( TQWidget::caption() == caption )
- return;
-
- topData()->caption = caption;
- XSetWMName( x11Display(), winId(), qstring_to_xtp(caption) );
-
- TQCString net_wm_name = caption.utf8();
- XChangeProperty(x11Display(), winId(), qt_net_wm_name, qt_utf8_string, 8,
- PropModeReplace, (unsigned char *)net_wm_name.data(),
- net_wm_name.length());
-
- TQEvent e( TQEvent::CaptionChange );
- TQApplication::sendEvent( this, &e );
-}
-
-void TQWidget::setIcon( const TQPixmap &pixmap )
-{
- if ( extra && extra->topextra ) {
- delete extra->topextra->icon;
- extra->topextra->icon = 0;
- } else {
- createTLExtra();
- }
- Pixmap icon_pixmap = 0;
- Pixmap mask_pixmap = 0;
- if ( !pixmap.isNull() ) {
- TQPixmap* pm = new TQPixmap( pixmap );
- extra->topextra->icon = pm;
- if ( !pm->mask() )
- pm->setMask( pm->createHeuristicMask() ); // may do detach()
- icon_pixmap = pm->handle();
- if ( pm->mask() )
- mask_pixmap = pm->mask()->handle();
- }
- XWMHints *h = XGetWMHints( x11Display(), winId() );
- XWMHints wm_hints;
- bool got_hints = h != 0;
- if ( !got_hints ) {
- h = &wm_hints;
- h->flags = 0;
- }
- h->icon_pixmap = icon_pixmap;
- h->icon_mask = mask_pixmap;
- h->flags |= IconPixmapHint | IconMaskHint;
- XSetWMHints( x11Display(), winId(), h );
- if ( got_hints )
- XFree( (char *)h );
- TQEvent e( TQEvent::IconChange );
- TQApplication::sendEvent( this, &e );
-}
-
-void TQWidget::setIconText( const TQString &iconText )
-{
- if (TQWidget::iconText() == iconText)
- return;
-
- topData()->iconText = iconText;
- XSetWMIconName( x11Display(), winId(), qstring_to_xtp(iconText) );
-
- TQCString net_wm_icon_name = iconText.utf8();
- XChangeProperty(x11Display(), winId(), qt_net_wm_icon_name, qt_utf8_string, 8, PropModeReplace,
- (unsigned char *) net_wm_icon_name.data(), net_wm_icon_name.length());
-}
-
-void TQWidget::setMouseTracking( bool enable )
-{
- bool gmt = TQApplication::hasGlobalMouseTracking();
- if ( !enable == !testWState(WState_MouseTracking) && !gmt )
- return;
- uint m = (enable || gmt) ? (uint)PointerMotionMask : 0;
- if ( enable )
- setWState( WState_MouseTracking );
- else
- clearWState( WState_MouseTracking );
- if ( testWFlags(WType_Desktop) ) { // desktop widget?
- TQWidget* main_desktop = find( winId() );
- if ( main_desktop->testWFlags(WPaintDesktop) )
- XSelectInput( x11Display(), winId(),
- stdDesktopEventMask | ExposureMask );
- else
- XSelectInput( x11Display(), winId(), stdDesktopEventMask );
- } else {
- XSelectInput( x11Display(), winId(),
- m | stdWidgetEventMask );
-#if defined (TQT_TABLET_SUPPORT)
- if ( devStylus != NULL ) {
- XSelectExtensionEvent( x11Display(), winId(), event_list_stylus,
- qt_curr_events_stylus );
- }
- if ( devEraser != NULL ) {
- XSelectExtensionEvent( x11Display(), winId(), event_list_eraser,
- qt_curr_events_eraser );
- }
-#endif
- }
-}
-
-
-/*!
- Grabs the mouse input.
-
- This widget receives all mouse events until releaseMouse() is
- called; other widgets get no mouse events at all. Keyboard
- events are not affected. Use grabKeyboard() if you want to grab
- that.
-
- \warning Bugs in mouse-grabbing applications very often lock the
- terminal. Use this function with extreme caution, and consider
- using the \c -nograb command line option while debugging.
-
- It is almost never necessary to grab the mouse when using TQt, as
- TQt grabs and releases it sensibly. In particular, TQt grabs the
- mouse when a mouse button is pressed and keeps it until the last
- button is released.
-
- Note that only visible widgets can grab mouse input. If
- isVisible() returns FALSE for a widget, that widget cannot call
- grabMouse().
-
- \sa releaseMouse() grabKeyboard() releaseKeyboard() grabKeyboard()
- tqfocusWidget()
-*/
-
-void TQWidget::grabMouse()
-{
- if ( isVisible() && !qt_nograb() ) {
- if ( mouseGrb )
- mouseGrb->releaseMouse();
-#if defined(TQT_CHECK_STATE)
- int status =
-#endif
- XGrabPointer( x11Display(), winId(), False,
- (uint)( ButtonPressMask | ButtonReleaseMask |
- PointerMotionMask | EnterWindowMask |
- LeaveWindowMask ),
- GrabModeAsync, GrabModeAsync,
- None, None, GET_QT_X_TIME() );
-#if defined(TQT_CHECK_STATE)
- if ( status ) {
- const char *s =
- status == GrabNotViewable ? "\"GrabNotViewable\"" :
- status == AlreadyGrabbed ? "\"AlreadyGrabbed\"" :
- status == GrabFrozen ? "\"GrabFrozen\"" :
- status == GrabInvalidTime ? "\"GrabInvalidTime\"" :
- "<?>";
- qWarning( "Grabbing the mouse failed with %s", s );
- }
-#endif
- mouseGrb = this;
- }
-}
-
-/*!
- \overload
-
- Grabs the mouse input and changes the cursor tqshape.
-
- The cursor will assume tqshape \a cursor (for as long as the mouse
- focus is grabbed) and this widget will be the only one to receive
- mouse events until releaseMouse() is called().
-
- \warning Grabbing the mouse might lock the terminal.
-
- \sa releaseMouse(), grabKeyboard(), releaseKeyboard(), setCursor()
-*/
-
-void TQWidget::grabMouse( const TQCursor &cursor )
-{
- if ( !qt_nograb() ) {
- if ( mouseGrb )
- mouseGrb->releaseMouse();
-#if defined(TQT_CHECK_STATE)
- int status =
-#endif
- XGrabPointer( x11Display(), winId(), False,
- (uint)(ButtonPressMask | ButtonReleaseMask |
- PointerMotionMask | EnterWindowMask | LeaveWindowMask),
- GrabModeAsync, GrabModeAsync,
- None, cursor.handle(), GET_QT_X_TIME() );
-#if defined(TQT_CHECK_STATE)
- if ( status ) {
- const char *s =
- status == GrabNotViewable ? "\"GrabNotViewable\"" :
- status == AlreadyGrabbed ? "\"AlreadyGrabbed\"" :
- status == GrabFrozen ? "\"GrabFrozen\"" :
- status == GrabInvalidTime ? "\"GrabInvalidTime\"" :
- "<?>";
- qWarning( "Grabbing the mouse failed with %s", s );
- }
-#endif
- mouseGrb = this;
- }
-}
-
-/*!
- Releases the mouse grab.
-
- \sa grabMouse(), grabKeyboard(), releaseKeyboard()
-*/
-
-void TQWidget::releaseMouse()
-{
- if ( !qt_nograb() && mouseGrb == this ) {
- XUngrabPointer( x11Display(), GET_QT_X_TIME() );
- XFlush( x11Display() );
- mouseGrb = 0;
- }
-}
-
-/*!
- Grabs the keyboard input.
-
- This widget reveives all keyboard events until releaseKeyboard()
- is called; other widgets get no keyboard events at all. Mouse
- events are not affected. Use grabMouse() if you want to grab that.
-
- The focus widget is not affected, except that it doesn't receive
- any keyboard events. setFocus() moves the focus as usual, but the
- new focus widget receives keyboard events only after
- releaseKeyboard() is called.
-
- If a different widget is currently grabbing keyboard input, that
- widget's grab is released first.
-
- \sa releaseKeyboard() grabMouse() releaseMouse() tqfocusWidget()
-*/
-
-void TQWidget::grabKeyboard()
-{
- if ( !qt_nograb() ) {
- if ( keyboardGrb )
- keyboardGrb->releaseKeyboard();
- XGrabKeyboard( x11Display(), winid, False, GrabModeAsync, GrabModeAsync,
- GET_QT_X_TIME() );
- keyboardGrb = this;
- }
-}
-
-/*!
- Releases the keyboard grab.
-
- \sa grabKeyboard(), grabMouse(), releaseMouse()
-*/
-
-void TQWidget::releaseKeyboard()
-{
- if ( !qt_nograb() && keyboardGrb == this ) {
- XUngrabKeyboard( x11Display(), GET_QT_X_TIME() );
- keyboardGrb = 0;
- }
-}
-
-
-/*!
- Returns the widget that is currently grabbing the mouse input.
-
- If no widget in this application is currently grabbing the mouse,
- 0 is returned.
-
- \sa grabMouse(), keyboardGrabber()
-*/
-
-TQWidget *TQWidget::mouseGrabber()
-{
- return mouseGrb;
-}
-
-/*!
- Returns the widget that is currently grabbing the keyboard input.
-
- If no widget in this application is currently grabbing the
- keyboard, 0 is returned.
-
- \sa grabMouse(), mouseGrabber()
-*/
-
-TQWidget *TQWidget::keyboardGrabber()
-{
- return keyboardGrb;
-}
-
-/*!
- Sets the top-level widget containing this widget to be the active
- window.
-
- An active window is a visible top-level window that has the
- keyboard input focus.
-
- This function performs the same operation as clicking the mouse on
- the title bar of a top-level window. On X11, the result depends on
- the Window Manager. If you want to ensure that the window is
- stacked on top as well you should also call raise(). Note that the
- window must be visible, otherwise setActiveWindow() has no effect.
-
- On Windows, if you are calling this when the application is not
- currently the active one then it will not make it the active
- window. It will flash the task bar entry blue to indicate that
- the window has done something. This is because Microsoft do not
- allow an application to interrupt what the user is currently doing
- in another application.
-
- \sa isActiveWindow(), tqtopLevelWidget(), show()
-*/
-
-void TQWidget::setActiveWindow()
-{
- TQWidget *tlw = tqtopLevelWidget();
- if ( tlw->isVisible() && !tlw->topData()->embedded && !qt_deferred_map_contains(tlw) ) {
- XSetInputFocus( x11Display(), tlw->winId(), RevertToNone, GET_QT_X_TIME());
- focusInputContext();
- }
-}
-
-
-/*!
- Updates the widget unless updates are disabled or the widget is
- hidden.
-
- This function does not cause an immediate tqrepaint; instead it
- schedules a paint event for processing when TQt returns to the main
- event loop. This permits TQt to optimize for more speed and less
- flicker than a call to tqrepaint() does.
-
- Calling update() several times normally results in just one
- paintEvent() call.
-
- TQt normally erases the widget's area before the paintEvent() call.
- If the \c WRepaintNoErase widget flag is set, the widget is
- responsible for painting all its pixels itself.
-
- \sa tqrepaint(), paintEvent(), setUpdatesEnabled(), erase(),
- setWFlags()
-*/
-
-void TQWidget::update()
-{
- if ( (widget_state & (WState_Visible|WState_BlockUpdates)) ==
- WState_Visible )
- TQApplication::postEvent( this, new TQPaintEvent( clipRegion(), !testWFlags(WRepaintNoErase) ) );
-}
-
-/*!
- \overload
-
- Updates a rectangle (\a x, \a y, \a w, \a h) inside the widget
- unless updates are disabled or the widget is hidden.
-
- This function does not cause an immediate tqrepaint; instead it
- schedules a paint event for processing when TQt returns to the main
- event loop. This permits TQt to optimize for more speed and less
- flicker and a call to tqrepaint() does.
-
- Calling update() several times normally results in just one
- paintEvent() call.
-
- If \a w is negative, it is replaced with \c{width() - x}. If \a h
- is negative, it is replaced width \c{height() - y}.
-
- TQt normally erases the specified area before the paintEvent()
- call. If the \c WRepaintNoErase widget flag is set, the widget is
- responsible for painting all its pixels itself.
-
- \sa tqrepaint(), paintEvent(), setUpdatesEnabled(), erase()
-*/
-
-void TQWidget::update( int x, int y, int w, int h )
-{
- if ( w && h &&
- (widget_state & (WState_Visible|WState_BlockUpdates)) == WState_Visible ) {
- if ( w < 0 )
- w = crect.width() - x;
- if ( h < 0 )
- h = crect.height() - y;
- if ( w != 0 && h != 0 )
- TQApplication::postEvent( this,
- new TQPaintEvent( clipRegion().intersect(TQRect(x,y,w,h)),
- !testWFlags( WRepaintNoErase ) ) );
- }
-}
-
-/*!
- \overload void TQWidget::update( const TQRect &r )
-
- Updates a rectangle \a r inside the widget unless updates are
- disabled or the widget is hidden.
-
- This function does not cause an immediate tqrepaint; instead it
- schedules a paint event for processing when TQt returns to the main
- event loop. This permits TQt to optimize for more speed and less
- flicker and a call to tqrepaint() does.
-
- Calling update() several times normally results in just one
- paintEvent() call.
-*/
-
-/*!
- \overload void TQWidget::tqrepaint( bool erase )
-
- This version repaints the entire widget.
-*/
-
-/*!
- \overload void TQWidget::tqrepaint()
-
- This version erases and repaints the entire widget.
-*/
-
-/*!
- Repaints the widget directly by calling paintEvent() immediately,
- unless updates are disabled or the widget is hidden.
-
- If \a erase is TRUE, TQt erases the area \a (x, y, w, h) before the
- paintEvent() call.
-
- If \a w is negative, it is replaced with \c{width() - x}, and if
- \a h is negative, it is replaced width \c{height() - y}.
-
- We suggest only using tqrepaint() if you need an immediate tqrepaint,
- for example during animation. In almost all circumstances update()
- is better, as it permits TQt to optimize for speed and minimize
- flicker.
-
- \warning If you call tqrepaint() in a function which may itself be
- called from paintEvent(), you may get infinite recursion. The
- update() function never causes recursion.
-
- \sa update(), paintEvent(), setUpdatesEnabled(), erase()
-*/
-
-void TQWidget::tqrepaint( int x, int y, int w, int h, bool erase )
-{
- if ( (widget_state & (WState_Visible|WState_BlockUpdates)) == WState_Visible ) {
- if ( x > crect.width() || y > crect.height() )
- return;
- if ( w < 0 )
- w = crect.width() - x;
- if ( h < 0 )
- h = crect.height() - y;
- TQRect r(x,y,w,h);
- if ( r.isEmpty() )
- return; // nothing to do
- TQPaintEvent e( r, erase );
- if ( r != rect() )
- qt_set_paintevent_clipping( this, r );
- if ( erase && w != 0 && h != 0 ) {
- if ( backgroundOrigin() == WidgetOrigin )
- XClearArea( x11Display(), winId(), x, y, w, h, False );
- else
- this->erase( x, y, w, h);
- }
- TQApplication::sendEvent( this, &e );
- qt_clear_paintevent_clipping();
- }
-}
-
-/*!
- \overload
-
- Repaints the widget directly by calling paintEvent() directly,
- unless updates are disabled or the widget is hidden.
-
- Erases the widget region \a reg if \a erase is TRUE.
-
- Only use tqrepaint if your widget needs to be repainted immediately,
- for example when doing some animation. In all other cases, use
- update(). Calling update() many times in a row will generate a
- single paint event.
-
- \warning If you call tqrepaint() in a function which may itself be
- called from paintEvent(), you may get infinite recursion. The
- update() function never causes recursion.
-
- \sa update(), paintEvent(), setUpdatesEnabled(), erase()
-*/
-
-void TQWidget::tqrepaint( const TQRegion& reg, bool erase )
-{
- if ( (widget_state & (WState_Visible|WState_BlockUpdates)) == WState_Visible ) {
- TQPaintEvent e( reg, erase );
- qt_set_paintevent_clipping( this, reg );
- if ( erase )
- this->erase(reg);
- TQApplication::sendEvent( this, &e );
- qt_clear_paintevent_clipping();
- }
-}
-
-/*!
- \overload void TQWidget::tqrepaint( const TQRect &r, bool erase )
-
- Repaints the widget directly by calling paintEvent() directly,
- unless updates are disabled or the widget is hidden.
-
- Erases the widget region \a r if \a erase is TRUE.
-*/
-
-void TQWidget::setWindowState(uint newstate)
-{
- bool needShow = FALSE;
- uint oldstate = windowState();
- if (isTopLevel()) {
- TQTLWExtra *top = topData();
-
- if ((oldstate & WindowMaximized) != (newstate & WindowMaximized)) {
- if (qt_net_supports(qt_net_wm_state_max_h) && qt_net_supports(qt_net_wm_state_max_v)) {
- qt_net_change_wm_state(this, (newstate & WindowMaximized),
- qt_net_wm_state_max_h, qt_net_wm_state_max_v);
- } else if (! (newstate & WindowFullScreen)) {
- if (newstate & WindowMaximized) {
- // save original tqgeometry
- const TQRect normalGeometry = tqgeometry();
-
- if (isVisible()) {
- updateFrameStrut();
- const TQRect maxRect = TQApplication::desktop()->availableGeometry(this);
- const TQRect r = top->normalGeometry;
- setGeometry(maxRect.x() + top->fleft,
- maxRect.y() + top->ftop,
- maxRect.width() - top->fleft - top->fright,
- maxRect.height() - top->ftop - top->fbottom);
- top->normalGeometry = r;
- }
-
- if (top->normalGeometry.width() < 0)
- top->normalGeometry = normalGeometry;
- } else {
- // restore original tqgeometry
- setGeometry(top->normalGeometry);
- }
- }
- }
-
- if ((oldstate & WindowFullScreen) != (newstate & WindowFullScreen)) {
- if (qt_net_supports(qt_net_wm_state_fullscreen)) {
- qt_net_change_wm_state(this, (newstate & WindowFullScreen),
- qt_net_wm_state_fullscreen);
- } else {
- needShow = isVisible();
-
- if (newstate & WindowFullScreen) {
- const TQRect normalGeometry = TQRect(pos(), size());
-
- top->savedFlags = getWFlags();
- reparent(0, WType_TopLevel | WStyle_Customize | WStyle_NoBorder |
- // preserve some widget flags
- (getWFlags() & 0xffff0000),
- mapToGlobal(TQPoint(0, 0)));
- const TQRect r = top->normalGeometry;
- setGeometry(tqApp->desktop()->screenGeometry(this));
- top->normalGeometry = r;
-
- if ( top->normalGeometry.width() < 0 )
- top->normalGeometry = normalGeometry;
- } else {
- reparent( 0, top->savedFlags, mapToGlobal(TQPoint(0, 0)) );
-
- if (newstate & WindowMaximized) {
- // from fullscreen to maximized
- updateFrameStrut();
- const TQRect maxRect = TQApplication::desktop()->availableGeometry(this);
- const TQRect r = top->normalGeometry;
- setGeometry(maxRect.x() + top->fleft,
- maxRect.y() + top->ftop,
- maxRect.width() - top->fleft - top->fright,
- maxRect.height() - top->ftop - top->fbottom);
- top->normalGeometry = r;
- } else {
- // restore original tqgeometry
- setGeometry(top->normalGeometry);
- }
- }
- }
- }
-
- if ((oldstate & WindowMinimized) != (newstate & WindowMinimized)) {
- if (isVisible()) {
- if (newstate & WindowMinimized) {
- XEvent e;
- e.xclient.type = ClientMessage;
- e.xclient.message_type = qt_wm_change_state;
- e.xclient.display = x11Display();
- e.xclient.window = winid;
- e.xclient.format = 32;
- e.xclient.data.l[0] = IconicState;
- e.xclient.data.l[1] = 0;
- e.xclient.data.l[2] = 0;
- e.xclient.data.l[3] = 0;
- e.xclient.data.l[4] = 0;
- XSendEvent(x11Display(), RootWindow(x11Display(), x11Screen()),
- False, (SubstructureNotifyMask|SubstructureRedirectMask), &e);
- } else {
- XMapWindow(x11Display(), winId());
- }
- }
-
- needShow = FALSE;
- }
- }
-
- widget_state &= ~(WState_Minimized | WState_Maximized | WState_FullScreen);
- if (newstate & WindowMinimized)
- widget_state |= WState_Minimized;
- if (newstate & WindowMaximized)
- widget_state |= WState_Maximized;
- if (newstate & WindowFullScreen)
- widget_state |= WState_FullScreen;
-
- if (needShow)
- show();
-
- if (newstate & WindowActive)
- setActiveWindow();
-
- TQEvent e(TQEvent::WindowStateChange);
- TQApplication::sendEvent(this, &e);
-}
-
-/*!
- \internal
- Platform-specific part of TQWidget::show().
-*/
-
-void TQWidget::showWindow()
-{
- if ( isTopLevel() ) {
- XWMHints *h = XGetWMHints( x11Display(), winId() );
- XWMHints wm_hints;
- bool got_hints = h != 0;
- if ( !got_hints ) {
- h = &wm_hints;
- h->flags = 0;
- }
- h->initial_state = testWState(WState_Minimized) ? IconicState : NormalState;
- h->flags |= StateHint;
- XSetWMHints( x11Display(), winId(), h );
- if ( got_hints )
- XFree( (char *)h );
-
- if (GET_QT_X_USER_TIME() != CurrentTime) {
- Time my_tqx_user_time = GET_QT_X_USER_TIME();
- XChangeProperty(x11Display(), winId(), qt_net_wm_user_time, XA_CARDINAL,
- 32, PropModeReplace, (unsigned char *) &my_tqx_user_time, 1);
- SET_QT_X_USER_TIME(my_tqx_user_time);
- }
-
- if (!topData()->embedded &&
- topData()->parentWinId &&
- topData()->parentWinId != TQPaintDevice::x11AppRootWindow(x11Screen()) &&
- !isMinimized() ) {
- qt_deferred_map_add( this );
- return;
- }
-
- if (isMaximized() && !isFullScreen()
- && !(qt_net_supports(qt_net_wm_state_max_h)
- && qt_net_supports(qt_net_wm_state_max_v))) {
- XMapWindow( x11Display(), winId() );
- qt_wait_for_window_manager(this);
-
- // if the wm was not smart enough to adjust our size, do that manually
- updateFrameStrut();
- TQRect maxRect = TQApplication::desktop()->availableGeometry(this);
-
- TQTLWExtra *top = topData();
- TQRect normalRect = top->normalGeometry;
-
- setGeometry(maxRect.x() + top->fleft,
- maxRect.y() + top->ftop,
- maxRect.width() - top->fleft - top->fright,
- maxRect.height() - top->ftop - top->fbottom);
-
- // restore the original normalGeometry
- top->normalGeometry = normalRect;
- // internalSetGeometry() clears the maximized flag... make sure we set it back
- setWState(WState_Maximized);
-
- return;
- }
-
- if (isFullScreen() && !qt_net_supports(qt_net_wm_state_fullscreen)) {
- XMapWindow(x11Display(), winId());
- qt_wait_for_window_manager(this);
- return;
- }
- }
- XMapWindow( x11Display(), winId() );
-}
-
-
-/*!
- \internal
- Platform-specific part of TQWidget::hide().
-*/
-
-void TQWidget::hideWindow()
-{
- clearWState( WState_Exposed );
- deactivateWidgetCleanup();
- if ( isTopLevel() ) {
- qt_deferred_map_take( this );
- if ( winId() ) // in nsplugin, may be 0
- XWithdrawWindow( x11Display(), winId(), x11Screen() );
-
- TQTLWExtra *top = topData();
- crect.moveTopLeft( TQPoint(crect.x() - top->fleft, crect.y() - top->ftop ) );
-
- // zero the frame strut and mark it dirty
- top->fleft = top->fright = top->ftop = top->fbottom = 0;
- fstrut_dirty = TRUE;
-
- XFlush( x11Display() );
- } else {
- if ( winId() ) // in nsplugin, may be 0
- XUnmapWindow( x11Display(), winId() );
- }
-}
-
-/*!
- Raises this widget to the top of the parent widget's stack.
-
- After this call the widget will be visually in front of any
- overlapping sibling widgets.
-
- \sa lower(), stackUnder()
-*/
-
-void TQWidget::raise()
-{
- TQWidget *p = parentWidget();
- if ( p && p->childObjects && p->childObjects->findRef(this) >= 0 )
- p->childObjects->append( p->childObjects->take() );
- XRaiseWindow( x11Display(), winId() );
-}
-
-/*!
- Lowers the widget to the bottom of the parent widget's stack.
-
- After this call the widget will be visually behind (and therefore
- obscured by) any overlapping sibling widgets.
-
- \sa raise(), stackUnder()
-*/
-
-void TQWidget::lower()
-{
- TQWidget *p = parentWidget();
- if ( p && p->childObjects && p->childObjects->findRef(this) >= 0 )
- p->childObjects->insert( 0, p->childObjects->take() );
- XLowerWindow( x11Display(), winId() );
-}
-
-
-/*!
- Places the widget under \a w in the parent widget's stack.
-
- To make this work, the widget itself and \a w must be siblings.
-
- \sa raise(), lower()
-*/
-void TQWidget::stackUnder( TQWidget* w)
-{
- TQWidget *p = parentWidget();
- if ( !w || isTopLevel() || p != w->parentWidget() || this == w )
- return;
- if ( p && p->childObjects && p->childObjects->findRef(w) >= 0 && p->childObjects->findRef(this) >= 0 ) {
- p->childObjects->take();
- p->childObjects->insert( p->childObjects->findRef(w), this );
- }
- Window stack[2];
- stack[0] = w->winId();;
- stack[1] = winId();
- XRestackWindows( x11Display(), stack, 2 );
-}
-
-
-
-/*
- The global variable qt_widget_tlw_gravity defines the window gravity of
- the next top level window to be created. We do this when setting the
- main widget's tqgeometry and the "-tqgeometry" command line option contains
- a negative position.
-*/
-
-int qt_widget_tlw_gravity = NorthWestGravity;
-
-static void do_size_hints( TQWidget* widget, TQWExtra *x )
-{
- XSizeHints s;
- s.flags = 0;
- if ( x ) {
- s.x = widget->x();
- s.y = widget->y();
- s.width = widget->width();
- s.height = widget->height();
- if ( x->minw > 0 || x->minh > 0 ) { // add minimum size hints
- s.flags |= PMinSize;
- s.min_width = x->minw;
- s.min_height = x->minh;
- }
- if ( x->maxw < TQWIDGETSIZE_MAX || x->maxh < TQWIDGETSIZE_MAX ) {
- s.flags |= PMaxSize; // add maximum size hints
- s.max_width = x->maxw;
- s.max_height = x->maxh;
- }
- if ( x->topextra &&
- (x->topextra->incw > 0 || x->topextra->inch > 0) )
- { // add resize increment hints
- s.flags |= PResizeInc | PBaseSize;
- s.width_inc = x->topextra->incw;
- s.height_inc = x->topextra->inch;
- s.base_width = x->topextra->basew;
- s.base_height = x->topextra->baseh;
- }
-
- if ( x->topextra && x->topextra->uspos) {
- s.flags |= USPosition;
- s.flags |= PPosition;
- }
- if ( x->topextra && x->topextra->ussize) {
- s.flags |= USSize;
- s.flags |= PSize;
- }
- }
- s.flags |= PWinGravity;
- s.win_gravity = qt_widget_tlw_gravity; // usually NorthWest
- // reset in case it was set
- qt_widget_tlw_gravity =
- TQApplication::reverseLayout() ? NorthEastGravity : NorthWestGravity;
- XSetWMNormalHints( widget->x11Display(), widget->winId(), &s );
-}
-
-
-void TQWidget::internalSetGeometry( int x, int y, int w, int h, bool isMove )
-{
- Display *dpy = x11Display();
-
- if ( testWFlags(WType_Desktop) )
- return;
- if (isTopLevel()) {
- if (!qt_net_supports(qt_net_wm_state_max_h)
- && !qt_net_supports(qt_net_wm_state_max_v))
- clearWState(WState_Maximized);
- if (!qt_net_supports(qt_net_wm_state_fullscreen))
- clearWState(WState_FullScreen);
- topData()->normalGeometry = TQRect(0, 0, -1, -1);
- } else {
- // for TQWorkspace
- clearWState(WState_Maximized);
- clearWState(WState_FullScreen);
- }
- if ( extra ) { // any size restrictions?
- w = TQMIN(w,extra->maxw);
- h = TQMIN(h,extra->maxh);
- w = TQMAX(w,extra->minw);
- h = TQMAX(h,extra->minh);
- }
- if ( w < 1 ) // invalid size
- w = 1;
- if ( h < 1 )
- h = 1;
- TQPoint oldPos( pos() );
- TQSize oldSize( size() );
- TQRect oldGeom( crect );
- TQRect r( x, y, w, h );
-
- // We only care about stuff that changes the tqgeometry, or may
- // cause the window manager to change its state
- if ( !isTopLevel() && oldGeom == r )
- return;
-
- crect = r;
- bool isResize = size() != oldSize;
-
- if ( isTopLevel() ) {
- if ( isMove )
- topData()->uspos = 1;
- if ( isResize )
- topData()->ussize = 1;
- do_size_hints( this, extra );
- }
-
- if ( isMove ) {
- if (! qt_broken_wm)
- // pos() is right according to ICCCM 4.1.5
- XMoveResizeWindow( dpy, winid, pos().x(), pos().y(), w, h );
- else
- // work around 4Dwm's incompliance with ICCCM 4.1.5
- XMoveResizeWindow( dpy, winid, x, y, w, h );
- } else if ( isResize )
- XResizeWindow( dpy, winid, w, h );
-
- if ( isVisible() ) {
- if ( isMove && pos() != oldPos ) {
- if ( ! qt_broken_wm ) {
- // pos() is right according to ICCCM 4.1.5
- TQMoveEvent e( pos(), oldPos );
- TQApplication::sendEvent( this, &e );
- } else {
- // work around 4Dwm's incompliance with ICCCM 4.1.5
- TQMoveEvent e( crect.topLeft(), oldGeom.topLeft() );
- TQApplication::sendEvent( this, &e );
- }
- }
- if ( isResize ) {
-
- // set config pending only on resize, see qapplication_x11.cpp, translateConfigEvent()
- setWState( WState_ConfigPending );
-
- TQResizeEvent e( size(), oldSize );
- TQApplication::sendEvent( this, &e );
- }
- } else {
- if ( isMove && pos() != oldPos ) {
- if ( ! qt_broken_wm )
- // pos() is right according to ICCCM 4.1.5
- TQApplication::postEvent( this, new TQMoveEvent( pos(), oldPos ) );
- else
- // work around 4Dwm's incompliance with ICCCM 4.1.5
- TQApplication::postEvent( this, new TQMoveEvent( crect.topLeft(),
- oldGeom.topLeft() ) );
- }
- if ( isResize )
- TQApplication::postEvent( this,
- new TQResizeEvent( size(), oldSize ) );
- }
-}
-
-
-/*!
- \overload
-
- This function corresponds to setMinimumSize( TQSize(minw, minh) ).
- Sets the minimum width to \a minw and the minimum height to \a
- minh.
-*/
-
-void TQWidget::setMinimumSize( int minw, int minh )
-{
-#if defined(TQT_CHECK_RANGE)
- if ( minw < 0 || minh < 0 )
- qWarning("TQWidget::setMinimumSize: The smallest allowed size is (0,0)");
-#endif
- createExtra();
- if ( extra->minw == minw && extra->minh == minh )
- return;
- extra->minw = minw;
- extra->minh = minh;
- if ( minw > width() || minh > height() ) {
- bool resized = testWState( WState_Resized );
- resize( TQMAX(minw,width()), TQMAX(minh,height()) );
- if ( !resized )
- clearWState( WState_Resized ); // not a user resize
- }
- if ( testWFlags(WType_TopLevel) )
- do_size_hints( this, extra );
- updateGeometry();
-}
-
-/*!
- \overload
-
- This function corresponds to setMaximumSize( TQSize(\a maxw, \a
- maxh) ). Sets the maximum width to \a maxw and the maximum height
- to \a maxh.
-*/
-void TQWidget::setMaximumSize( int maxw, int maxh )
-{
-#if defined(TQT_CHECK_RANGE)
- if ( maxw > TQWIDGETSIZE_MAX || maxh > TQWIDGETSIZE_MAX ) {
- qWarning("TQWidget::setMaximumSize: (%s/%s) "
- "The largest allowed size is (%d,%d)",
- name( "unnamed" ), className(), TQWIDGETSIZE_MAX,
- TQWIDGETSIZE_MAX );
- maxw = TQMIN( maxw, TQWIDGETSIZE_MAX );
- maxh = TQMIN( maxh, TQWIDGETSIZE_MAX );
- }
- if ( maxw < 0 || maxh < 0 ) {
- qWarning("TQWidget::setMaximumSize: (%s/%s) Negative sizes (%d,%d) "
- "are not possible",
- name( "unnamed" ), className(), maxw, maxh );
- maxw = TQMAX( maxw, 0 );
- maxh = TQMAX( maxh, 0 );
- }
-#endif
- createExtra();
- if ( extra->maxw == maxw && extra->maxh == maxh )
- return;
- extra->maxw = maxw;
- extra->maxh = maxh;
- if ( maxw < width() || maxh < height() ) {
- bool resized = testWState( WState_Resized );
- resize( TQMIN(maxw,width()), TQMIN(maxh,height()) );
- if ( !resized )
- clearWState( WState_Resized ); // not a user resize
- }
- if ( testWFlags(WType_TopLevel) )
- do_size_hints( this, extra );
- updateGeometry();
-}
-
-/*!
- \overload
-
- Sets the x (width) size increment to \a w and the y (height) size
- increment to \a h.
-*/
-void TQWidget::setSizeIncrement( int w, int h )
-{
- TQTLWExtra* x = topData();
- if ( x->incw == w && x->inch == h )
- return;
- x->incw = w;
- x->inch = h;
- if ( testWFlags(WType_TopLevel) )
- do_size_hints( this, extra );
-}
-
-/*!
- \overload
-
- This corresponds to setBaseSize( TQSize(\a basew, \a baseh) ). Sets
- the widgets base size to width \a basew and height \a baseh.
-*/
-void TQWidget::setBaseSize( int basew, int baseh )
-{
- createTLExtra();
- TQTLWExtra* x = topData();
- if ( x->basew == basew && x->baseh == baseh )
- return;
- x->basew = basew;
- x->baseh = baseh;
- if ( testWFlags(WType_TopLevel) )
- do_size_hints( this, extra );
-}
-
-/*!
- \overload void TQWidget::erase()
-
- This version erases the entire widget.
-*/
-
-/*!
- \overload void TQWidget::erase( const TQRect &r )
-
- Erases the specified area \a r in the widget without generating a
- \link paintEvent() paint event\endlink.
-*/
-
-/*!
- Erases the specified area \a (x, y, w, h) in the widget without
- generating a \link paintEvent() paint event\endlink.
-
- If \a w is negative, it is replaced with \c{width() - x}. If \a h
- is negative, it is replaced width \c{height() - y}.
-
- Child widgets are not affected.
-
- \sa tqrepaint()
-*/
-
-void TQWidget::erase( int x, int y, int w, int h )
-{
- extern void qt_erase_rect( TQWidget*, const TQRect& ); // in qpainer_x11.cpp
- if ( w < 0 )
- w = crect.width() - x;
- if ( h < 0 )
- h = crect.height() - y;
- if ( w != 0 && h != 0 )
- qt_erase_rect( this, TQRect(x, y, w, h ) );
-}
-
-/*!
- \overload
-
- Erases the area defined by \a reg, without generating a \link
- paintEvent() paint event\endlink.
-
- Child widgets are not affected.
-*/
-
-void TQWidget::erase( const TQRegion& reg )
-{
- extern void qt_erase_region( TQWidget*, const TQRegion& ); // in qpainer_x11.cpp
- qt_erase_region( this, reg );
-}
-
-/*!
- Scrolls the widget including its tqchildren \a dx pixels to the
- right and \a dy downwards. Both \a dx and \a dy may be negative.
-
- After scrolling, scroll() sends a paint event for the the part
- that is read but not written. For example, when scrolling 10
- pixels rightwards, the leftmost ten pixels of the widget need
- repainting. The paint event may be delivered immediately or later,
- depending on some heuristics (note that you might have to force
- processing of paint events using TQApplication::sendPostedEvents()
- when using scroll() and move() in combination).
-
- \sa TQScrollView erase() bitBlt()
-*/
-
-void TQWidget::scroll( int dx, int dy )
-{
- scroll( dx, dy, TQRect() );
-}
-
-/*!
- \overload
-
- This version only scrolls \a r and does not move the tqchildren of
- the widget.
-
- If \a r is empty or invalid, the result is undefined.
-
- \sa TQScrollView erase() bitBlt()
-*/
-void TQWidget::scroll( int dx, int dy, const TQRect& r )
-{
- if ( testWState( WState_BlockUpdates ) && !childrenListObject() )
- return;
- bool valid_rect = r.isValid();
- bool just_update = TQABS( dx ) > width() || TQABS( dy ) > height();
- if ( just_update )
- update();
- TQRect sr = valid_rect?r:clipRegion().boundingRect();
- int x1, y1, x2, y2, w=sr.width(), h=sr.height();
- if ( dx > 0 ) {
- x1 = sr.x();
- x2 = x1+dx;
- w -= dx;
- } else {
- x2 = sr.x();
- x1 = x2-dx;
- w += dx;
- }
- if ( dy > 0 ) {
- y1 = sr.y();
- y2 = y1+dy;
- h -= dy;
- } else {
- y2 = sr.y();
- y1 = y2-dy;
- h += dy;
- }
-
- if ( dx == 0 && dy == 0 )
- return;
-
- Display *dpy = x11Display();
- GC gc = qt_xget_readonly_gc( x11Screen(), FALSE );
- // Want expose events
- if ( w > 0 && h > 0 && !just_update ) {
- XSetGraphicsExposures( dpy, gc, True );
- XCopyArea( dpy, winId(), winId(), gc, x1, y1, w, h, x2, y2);
- XSetGraphicsExposures( dpy, gc, False );
- }
-
- if ( !valid_rect && childrenListObject() ) { // scroll tqchildren
- TQPoint pd( dx, dy );
- TQObjectListIt it(*childrenListObject());
- register TQObject *object;
- while ( it ) { // move all tqchildren
- object = it.current();
- if ( object->isWidgetType() ) {
- TQWidget *w = (TQWidget *)object;
- w->move( w->pos() + pd );
- }
- ++it;
- }
- }
-
- if ( just_update )
- return;
-
- // Don't let the server be bogged-down with tqrepaint events
- bool repaint_immediately = qt_sip_count( this ) < 3;
-
- if ( dx ) {
- int x = x2 == sr.x() ? sr.x()+w : sr.x();
- if ( repaint_immediately )
- tqrepaint( x, sr.y(), TQABS(dx), sr.height(), !testWFlags(WRepaintNoErase) );
- else
- XClearArea( dpy, winid, x, sr.y(), TQABS(dx), sr.height(), True );
- }
- if ( dy ) {
- int y = y2 == sr.y() ? sr.y()+h : sr.y();
- if ( repaint_immediately )
- tqrepaint( sr.x(), y, sr.width(), TQABS(dy), !testWFlags(WRepaintNoErase) );
- else
- XClearArea( dpy, winid, sr.x(), y, sr.width(), TQABS(dy), True );
- }
-
- qt_insert_sip( this, dx, dy ); // #### ignores r
-}
-
-
-/*!
- \overload void TQWidget::drawText( const TQPoint &pos, const TQString& str )
-
- Draws the string \a str at position \a pos.
-*/
-
-/*!
- Draws the string \a str at position \a(x, y).
-
- The \a y position is the base line position of the text. The text
- is drawn using the default font and the default foreground color.
-
- This function is provided for convenience. You will generally get
- more flexible results and often higher speed by using a a \link
- TQPainter painter\endlink instead.
-
- \sa setFont(), foregroundColor(), TQPainter::drawText()
-*/
-
-void TQWidget::drawText( int x, int y, const TQString &str )
-{
- if ( testWState(WState_Visible) ) {
- TQPainter paint;
- paint.begin( this );
- paint.drawText( x, y, str );
- paint.end();
- }
-}
-
-
-/*!
- Internal implementation of the virtual TQPaintDevice::metric()
- function.
-
- Use the TQPaintDeviceMetrics class instead.
-
- \a m is the metric to get.
-*/
-
-int TQWidget::metric( int m ) const
-{
- int val;
- if ( m == TQPaintDeviceMetrics::PdmWidth ) {
- val = crect.width();
- } else if ( m == TQPaintDeviceMetrics::PdmHeight ) {
- val = crect.height();
- } else {
- Display *dpy = x11Display();
- int scr = x11Screen();
- switch ( m ) {
- case TQPaintDeviceMetrics::PdmDpiX:
- case TQPaintDeviceMetrics::PdmPhysicalDpiX:
- val = TQPaintDevice::x11AppDpiX( scr );
- break;
- case TQPaintDeviceMetrics::PdmDpiY:
- case TQPaintDeviceMetrics::PdmPhysicalDpiY:
- val = TQPaintDevice::x11AppDpiY( scr );
- break;
- case TQPaintDeviceMetrics::PdmWidthMM:
- val = (DisplayWidthMM(dpy,scr)*crect.width())/
- DisplayWidth(dpy,scr);
- break;
- case TQPaintDeviceMetrics::PdmHeightMM:
- val = (DisplayHeightMM(dpy,scr)*crect.height())/
- DisplayHeight(dpy,scr);
- break;
- case TQPaintDeviceMetrics::PdmNumColors:
- val = x11Cells();
- break;
- case TQPaintDeviceMetrics::PdmDepth:
- val = x11Depth();
- break;
- default:
- val = 0;
-#if defined(TQT_CHECK_RANGE)
- qWarning( "TQWidget::metric: Invalid metric command" );
-#endif
- }
- }
- return val;
-}
-
-void TQWidget::createSysExtra()
-{
- extra->xDndProxy = 0;
- extra->tqchildren_use_dnd = FALSE;
- extra->compress_events = TRUE;
-}
-
-void TQWidget::deleteSysExtra()
-{
-}
-
-void TQWidget::createTLSysExtra()
-{
-#if defined(TQT_NO_IM_EXTENSIONS)
- // created lazily
- extra->topextra->xic = 0;
-#endif
-#ifndef TQT_NO_XSYNC
- extra->topextra->syncCounter = 0;
- extra->topextra->syncRequestValue[0] = 0;
- extra->topextra->syncRequestValue[1] = 0;
-#endif
-}
-
-void TQWidget::deleteTLSysExtra()
-{
- // don't destroy input context here. it will be destroyed in
- // TQWidget::destroy() destroyInputContext();
-}
-
-/*
- examine the tqchildren of our parent up the tree and set the
- tqchildren_use_dnd extra data appropriately... this is used to keep DND enabled
- for widgets that are reparented and don't have DND enabled, BUT *DO* have
- tqchildren (or tqchildren of tqchildren ...) with DND enabled...
-*/
-void TQWidget::checkChildrenDnd()
-{
- TQWidget *widget = this;
- const TQObjectList *tqchildren;
- const TQObject *object;
- const TQWidget *child;
- while (widget && ! widget->isDesktop()) {
- // note: this isn't done for the desktop widget
-
- bool tqchildren_use_dnd = FALSE;
- tqchildren = widget->childrenListObject();
- if ( tqchildren ) {
- TQObjectListIt it(*tqchildren);
- while ( (object = it.current()) ) {
- ++it;
- if ( object->isWidgetType() ) {
- child = (const TQWidget *) object;
- tqchildren_use_dnd = (tqchildren_use_dnd ||
- child->acceptDrops() ||
- (child->extra &&
- child->extra->tqchildren_use_dnd));
- }
- }
- }
-
- widget->createExtra();
- widget->extra->tqchildren_use_dnd = tqchildren_use_dnd;
-
- widget = widget->parentWidget();
- }
-}
-
-
-#ifndef TQT_NO_XSYNC
-// create a window's XSyncCounter
-void TQWidget::createSyncCounter()
-{
- if( !qt_use_xsync || !isTopLevel() || topData()->syncCounter )
- return;
- XSyncValue zero;
- XSyncIntToValue( &zero, 0 );
- topData()->syncCounter = XSyncCreateCounter( x11Display(), zero );
-}
-
-// destroy a window's XSyncCounter
-void TQWidget::destroySyncCounter()
-{
- if( !qt_use_xsync || !extra || !extra->topextra
- || !extra->topextra->syncCounter )
- return;
- XSyncDestroyCounter( x11Display(), extra->topextra->syncCounter );
- extra->topextra->syncCounter = 0;
-}
-
-// increment a window's XSyncCounter
-void TQWidget::incrementSyncCounter()
-{
- if( qt_use_xsync && topData()->syncCounter &&
- !(topData()->syncRequestValue[0] == 0 &&
- topData()->syncRequestValue[1] == 0) ) {
- XSyncValue val;
- XSyncIntsToValue( &val, topData()->syncRequestValue[ 0 ], topData()->syncRequestValue[ 1 ] );
- XSyncSetCounter( x11Display(), topData()->syncCounter, val );
- topData()->syncRequestValue[0] = topData()->syncRequestValue[1] = 0;
- }
-}
-
-// handle _NET_WM_SYNC_REQUEST
-void TQWidget::handleSyncRequest( void* ev )
-{
- XEvent* xev = (XEvent*)ev;
- topData()->syncRequestValue[ 0 ] = xev->xclient.data.l[ 2 ];
- topData()->syncRequestValue[ 1 ] = xev->xclient.data.l[ 3 ];
-}
-#endif // TQT_NO_XSYNC
-
-
-/*!
- \property TQWidget::acceptDrops
- \brief whether drop events are enabled for this widget
-
- Setting this property to TRUE announces to the system that this
- widget \e may be able to accept drop events.
-
- If the widget is the desktop (TQWidget::isDesktop()), this may
- fail if another application is using the desktop; you can call
- acceptDrops() to test if this occurs.
-
- \warning
- Do not modify this property in a Drag&Drop event handler.
-*/
-bool TQWidget::acceptDrops() const
-{
- return testWState( WState_DND );
-}
-
-void TQWidget::setAcceptDrops( bool on )
-{
- if ( testWState(WState_DND) != on ) {
- if ( qt_dnd_enable( this, on ) ) {
- if ( on )
- setWState( WState_DND );
- else
- clearWState( WState_DND );
- }
-
- checkChildrenDnd();
- }
-}
-
-/*!
- \overload
-
- Causes only the parts of the widget which overlap \a region to be
- visible. If the region includes pixels outside the rect() of the
- widget, window system controls in that area may or may not be
- visible, depending on the platform.
-
- Note that this effect can be slow if the region is particularly
- complex.
-
- \sa setMask(), clearMask()
-*/
-
-void TQWidget::setMask( const TQRegion& region )
-{
- XShapeCombineRegion( x11Display(), winId(), ShapeBounding, 0, 0,
- region.handle(), ShapeSet );
-}
-
-/*!
- Causes only the pixels of the widget for which \a bitmap has a
- corresponding 1 bit to be visible. Use TQt::color0 to draw
- transparent regions and TQt::color1 to draw opaque regions of the
- bitmap.
-
- If the region includes pixels outside the rect() of the widget,
- window system controls in that area may or may not be visible,
- depending on the platform.
-
- Note that this effect can be slow if the region is particularly
- complex.
-
- See \c examples/tux for an example of masking for transparency.
-
- \sa setMask(), clearMask()
-*/
-
-void TQWidget::setMask( const TQBitmap &bitmap )
-{
- TQBitmap bm = bitmap;
- if ( bm.x11Screen() != x11Screen() )
- bm.x11SetScreen( x11Screen() );
- XShapeCombineMask( x11Display(), winId(), ShapeBounding, 0, 0,
- bm.handle(), ShapeSet );
-}
-
-/*!
- Removes any mask set by setMask().
-
- \sa setMask()
-*/
-
-void TQWidget::clearMask()
-{
- XShapeCombineMask( x11Display(), winId(), ShapeBounding, 0, 0,
- None, ShapeSet );
-}
-
-/*!\reimp
- */
-void TQWidget::setName( const char *name )
-{
- TQObject::setName( name );
- if ( isTopLevel() ) {
- XChangeProperty( x11Display(), winId(),
- qt_window_role, XA_STRING, 8, PropModeReplace,
- (unsigned char *)name, tqstrlen( name ) );
- }
-}
-
-
-/*!
- \internal
-
- Computes the frame rectangle when needed. This is an internal function, you
- should never call this.
-*/
-
-void TQWidget::updateFrameStrut() const
-{
- TQWidget *that = (TQWidget *) this;
-
- if (! isVisible() || isDesktop()) {
- that->fstrut_dirty = (! isVisible());
- return;
- }
-
- Atom type_ret;
- Window l = winId(), w = winId(), p, r; // target window, it's parent, root
- Window *c;
- int i_unused;
- unsigned int nc;
- unsigned char *data_ret;
- unsigned long l_unused;
-
- while (XQueryTree(TQPaintDevice::x11AppDisplay(), w, &r, &p, &c, &nc)) {
- if (c && nc > 0)
- XFree(c);
-
- if (! p) {
- qWarning("TQWidget::updateFrameStrut(): ERROR - no parent");
- return;
- }
-
- // if the parent window is the root window, an Enlightenment virtual root or
- // a NET WM virtual root window, stop here
- data_ret = 0;
- if (p == r ||
- (XGetWindowProperty(TQPaintDevice::x11AppDisplay(), p,
- qt_enlightenment_desktop, 0, 1, False, XA_CARDINAL,
- &type_ret, &i_unused, &l_unused, &l_unused,
- &data_ret) == Success &&
- type_ret == XA_CARDINAL)) {
- if (data_ret)
- XFree(data_ret);
-
- break;
- } else if (qt_net_supports(qt_net_virtual_roots) && qt_net_virtual_root_list) {
- int i = 0;
- while (qt_net_virtual_root_list[i] != 0) {
- if (qt_net_virtual_root_list[i++] == p)
- break;
- }
- }
-
- l = w;
- w = p;
- }
-
- // we have our window
- int transx, transy;
- XWindowAttributes wattr;
- if (XTranslateCoordinates(TQPaintDevice::x11AppDisplay(), l, w,
- 0, 0, &transx, &transy, &p) &&
- XGetWindowAttributes(TQPaintDevice::x11AppDisplay(), w, &wattr)) {
- TQTLWExtra *top = that->topData();
- top->fleft = transx;
- top->ftop = transy;
- top->fright = wattr.width - crect.width() - top->fleft;
- top->fbottom = wattr.height - crect.height() - top->ftop;
-
- // add the border_width for the window managers frame... some window managers
- // do not use a border_width of zero for their frames, and if we the left and
- // top strut, we ensure that pos() is absolutely correct. frameGeometry()
- // will still be incorrect though... perhaps i should have foffset as well, to
- // indicate the frame offset (equal to the border_width on X).
- // - Brad
- top->fleft += wattr.border_width;
- top->fright += wattr.border_width;
- top->ftop += wattr.border_width;
- top->fbottom += wattr.border_width;
- }
-
- that->fstrut_dirty = 0;
-}
-
-
-/*!
- This function returns the widget holding the TQInputContext
- instance for this widget. The instance is used for text input to
- this widget, switching input method, etc.
-
- By default, this function delegates the role of returning input
- context holder widget to TQApplication::locateICHolderWidget().
-
- This definition enables application developer to change the
- mapping of widgets to TQInputContext instance simply by overriding
- TQApplication::locateICHolderWidget().
-
- \sa TQApplication::locateICHolderWidget()
-*/
-TQWidget *TQWidget::icHolderWidget()
-{
- return tqApp->locateICHolderWidget(this);
-}
-
-
-/*!
- This function returns the TQInputContext instance for this widget.
- This instance is used for text input to this widget, etc.
- It is simply the accessor function.
-*/
-TQInputContext *TQWidget::getInputContext()
-{
- TQInputContext *qic = 0;
-
-// #if !defined(TQT_NO_IM_EXTENSIONS)
- if ( isInputMethodEnabled() ) {
-#if !defined(TQT_NO_IM_EXTENSIONS)
- qic = icHolderWidget()->ic;
-#else
-// {
- // icHolderWidget is always tqtopLevelWidget
- TQTLWExtra *topdata = icHolderWidget()->topData();
- qic = (TQInputContext *)topdata->xic;
-#endif
- }
-
- return qic;
-}
-
-
-/*!
- This function replaces the TQInputContext instance used for text
- input to this widget. The \a identifierName is the identifier name
- of newly choosed input method.
-*/
-void TQWidget::changeInputContext( const TQString& identifierName )
-{
- TQWidget *icWidget = icHolderWidget();
-#if !defined(TQT_NO_IM_EXTENSIONS)
- TQInputContext **qicp = &icWidget->ic;
-#else
- TQInputContext **qicp = (TQInputContext **)&icWidget->topData()->xic;
-#endif
-
- if( *qicp )
- delete *qicp;
- // an input context that has the identifierName is generated.
- TQInputContext *qic = TQInputContextFactory::create( identifierName, icWidget );
- *qicp = qic;
- if ( qic ) {
- TQObject::connect( qic, TQT_SIGNAL(imEventGenerated(TQObject *,TQIMEvent *)),
- tqApp, TQT_SLOT(postIMEvent(TQObject *,TQIMEvent *)) );
- TQObject::connect( qic, TQT_SIGNAL(deletionRequested()),
- icWidget, TQT_SLOT(destroyInputContext()) );
- }
-}
-
-
-/*!
- \internal
- This is an internal function, you should never call this.
-
- This function is called to generate an input context
- according to a configuration for default input method
-
- When TQT_NO_IM_EXTENSIONS is not set, input context is
- generated only when isInputMethodEnabled() returns TRUE.
-*/
-void TQWidget::createInputContext()
-{
-// #if !defined(TQT_NO_IM_EXTENSIONS)
- if( !isInputMethodEnabled() || TQApplication::closingDown() )
- return;
-// #endif
-
- TQWidget *icWidget = icHolderWidget();
-#ifndef TQT_NO_IM
-#if !defined(TQT_NO_IM_EXTENSIONS)
- TQInputContext **qicp = &icWidget->ic;
-#else
- TQInputContext **qicp = (TQInputContext **)&icWidget->topData()->xic;
-#endif
-
- if ( ! *qicp ) {
- // an input context of the default input method is generated.
- TQInputContext *qic = TQInputContextFactory::create( TQApplication::defaultInputMethod(), icWidget );
-
- *qicp = qic;
- if ( qic ) {
- TQObject::connect( qic, TQT_SIGNAL(imEventGenerated(TQObject *,TQIMEvent *)),
- tqApp, TQT_SLOT(postIMEvent(TQObject *,TQIMEvent *)) );
- TQObject::connect( qic, TQT_SIGNAL(deletionRequested()),
- icWidget, TQT_SLOT(destroyInputContext()) );
- }
- }
-#endif // TQT_NO_IM
-}
-
-
-/*!
- \internal
-
- This slot is used to destroy the input context that belonging
- to the widget itself, so icHolderWidget()->ic is not fetched.
-
- \sa TQInputContext::deletionRequested()
-*/
-void TQWidget::destroyInputContext()
-{
-#ifndef TQT_NO_IM
-#if !defined(TQT_NO_IM_EXTENSIONS)
- TQInputContext **qicp = &ic;
-#else
- if ( ! extra || ! extra->topextra )
- return;
-
- TQInputContext **qicp = (TQInputContext **)&extra->topextra->xic;
-#endif
-
- if( *qicp )
- delete *qicp;
-
- *qicp = 0;
-#endif // TQT_NO_IM
-}
-
-
-/*!
- This function is called when text widgets need to be neutral state to
- execute text operations properly. See qlineedit.cpp and qtextedit.cpp as
- example.
-
- Ordinary reset that along with changing focus to another widget,
- moving the cursor, etc, is implicitly handled via
- unfocusInputContext() because whether reset or not when such
- situation is a responsibility of input methods. So we delegate the
- responsibility to the input context via unfocusInputContext(). See
- 'Preedit preservation' section of the class description of
- TQInputContext for further information.
-
- \sa TQInputContext, unfocusInputContext(), TQInputContext::unsetFocus()
-*/
-void TQWidget::resetInputContext()
-{
-#ifndef TQT_NO_IM
- // trigger input context creation if it hasn't happened already
- createInputContext();
-
- TQInputContext *qic = getInputContext();
- if( qic )
- qic->reset();
-#endif // TQT_NO_IM
-}
-
-
-/*!
- \internal
- This is an internal function, you should never call this.
-
- This function is called to focus associated input context. The
- code intends to eliminate duplicate focus for the context even if
- the context is shared between widgets
-
- \sa TQInputContext::setFocus()
- */
-void TQWidget::focusInputContext()
-{
-#ifndef TQT_NO_IM
- TQWidget* tlw = tqtopLevelWidget();
-
- if (!tlw->isPopup() || isInputMethodEnabled()) {
- // trigger input context creation if it hasn't happened already
- createInputContext();
-
- TQInputContext *qic = getInputContext();
- if ( qic ) {
- if( qic->tqfocusWidget() != this ) {
- qic->setFocusWidget( this );
- qic->setFocus();
- }
- }
- }
-#endif // TQT_NO_IM
-}
-
-
-/*!
- \internal
- This is an internal function, you should never call this.
-
- This function is called to remove focus from associated input
- context.
-
- \sa TQInputContext::unsetFocus()
- */
-void TQWidget::unfocusInputContext()
-{
-#ifndef TQT_NO_IM
- // trigger input context creation if it hasn't happened already
- createInputContext();
-
- TQInputContext *qic = getInputContext();
- if ( qic ) {
- // may be caused reset() in some input methods
- qic->unsetFocus();
- qic->setFocusWidget( 0 );
- }
-#endif // TQT_NO_IM
-}
-
-
-/*!
- This function is called to send mouse event to associated input
- context by derived text widgets. A derived text widget must be
- calculate \a x as character offset at the mouse cursor in the
- preedit.
-
- \sa TQInputContext::mouseHandler()
- */
-void TQWidget::sendMouseEventToInputContext( int x, TQEvent::Type type,
- TQt::ButtonState button,
- TQt::ButtonState state )
-{
-#ifndef TQT_NO_IM
- // trigger input context creation if it hasn't happened already
- createInputContext();
-
- TQInputContext *qic = getInputContext();
- if ( qic ) {
- // may be causing reset() in some input methods
- qic->mouseHandler( x, type, button, state );
- }
-#endif // TQT_NO_IM
-}
-
-
-void TQWidget::setWindowOpacity(double)
-{
-}
-
-double TQWidget::windowOpacity() const
-{
- return 1.0;
-}
-
-#endif // USE_QT4