diff options
Diffstat (limited to 'tqtinterface/qt4/src/widgets/tqtoolbutton.cpp')
| -rw-r--r-- | tqtinterface/qt4/src/widgets/tqtoolbutton.cpp | 1041 | 
1 files changed, 0 insertions, 1041 deletions
| diff --git a/tqtinterface/qt4/src/widgets/tqtoolbutton.cpp b/tqtinterface/qt4/src/widgets/tqtoolbutton.cpp deleted file mode 100644 index 9f392ca..0000000 --- a/tqtinterface/qt4/src/widgets/tqtoolbutton.cpp +++ /dev/null @@ -1,1041 +0,0 @@ -/**************************************************************************** -** -** Implementation of TQToolButton class -** -** Created : 980320 -** -** Copyright (C) 2010 Timothy Pearson and (C) 1992-2008 Trolltech ASA. -** -** This file is part of the widgets module of the TQt GUI Toolkit. -** -** This file may be used under the terms of the GNU General -** Public License versions 2.0 or 3.0 as published by the Free -** Software Foundation and appearing in the files LICENSE.GPL2 -** and LICENSE.GPL3 included in the packaging of this file. -** Alternatively you may (at your option) use any later version -** of the GNU General Public License if such license has been -** publicly approved by Trolltech ASA (or its successors, if any) -** and the KDE Free TQt Foundation. -** -** Please review the following information to ensure GNU General -** Public Licensing requirements will be met: -** http://trolltech.com/products/qt/licenses/licensing/opensource/. -** If you are unsure which license is appropriate for your use, please -** review the following information: -** http://trolltech.com/products/qt/licenses/licensing/licensingoverview -** or contact the sales department at sales@trolltech.com. -** -** This file may be used under the terms of the Q Public License as -** defined by Trolltech ASA and appearing in the file LICENSE.TQPL -** included in the packaging of this file.  Licensees holding valid TQt -** Commercial licenses may use this file in accordance with the TQt -** Commercial License Agreement provided with the Software. -** -** This file is provided "AS IS" with NO WARRANTY OF ANY KIND, -** INCLUDING THE WARRANTIES OF DESIGN, MERCHANTABILITY AND FITNESS FOR -** A PARTICULAR PURPOSE. Trolltech reserves all rights not granted -** herein. -** -**********************************************************************/ - -#undef TQT_NO_COMPAT -#include "tqtoolbutton.h" -#ifndef TQT_NO_TOOLBUTTON - -#include "tqdrawutil.h" -#include "tqpainter.h" -#include "tqpixmap.h" -#include "tqwmatrix.h" -#include "tqapplication.h" -#include "tqstyle.h" -#include "tqmainwindow.h" -#include "tqtooltip.h" -#include "tqtoolbar.h" -#include "tqimage.h" -#include "tqiconset.h" -#include "tqtimer.h" -#include "tqpopupmenu.h" -#include "tqguardedptr.h" - -class TQToolButtonPrivate -{ -    // ### add tool tip magic here -public: -#ifndef TQT_NO_POPUPMENU -    TQGuardedPtr<TQPopupMenu> popup; -    TQTimer* popupTimer; -    int delay; -#endif -    TQt::ArrowType arrow; -    uint instantPopup	    : 1; -    uint autoraise	    : 1; -    uint repeat		    : 1; -    uint discardNextMouseEvent : 1; -    TQToolButton::TextPosition textPos; -}; - - -/*! -    \class TQToolButton tqtoolbutton.h -    \brief The TQToolButton class provides a quick-access button to -    commands or options, usually used inside a TQToolBar. - -    \ingroup basic -    \mainclass - -    A tool button is a special button that provides quick-access to -    specific commands or options. As opposed to a normal command -    button, a tool button usually doesn't show a text label, but shows -    an icon instead. Its classic usage is to select tools, for example -    the "pen" tool in a drawing program. This would be implemented -    with a TQToolButton as toggle button (see setToggleButton() ). - -    TQToolButton supports auto-raising. In auto-raise mode, the button -    draws a 3D frame only when the mouse points at it. The feature is -    automatically turned on when a button is used inside a TQToolBar. -    Change it with setAutoRaise(). - -    A tool button's icon is set as TQIconSet. This makes it possible to -    specify different pixmaps for the disabled and active state. The -    disabled pixmap is used when the button's functionality is not -    available. The active pixmap is displayed when the button is -    auto-raised because the mouse pointer is hovering over it. - -    The button's look and dimension is adjustable with -    setUsesBigPixmap() and setUsesTextLabel(). When used inside a -    TQToolBar in a TQMainWindow, the button automatically adjusts to -    TQMainWindow's settings (see TQMainWindow::setUsesTextLabel() and -    TQMainWindow::setUsesBigPixmaps()). The pixmap set on a TQToolButton -    will be set to 22x22 if it is bigger than this size. If -    usesBigPixmap() is TRUE, then the pixmap will be set to 32x32. - -    A tool button can offer additional choices in a popup menu. The -    feature is sometimes used with the "Back" button in a web browser. -    After pressing and holding the button down for a while, a menu -    pops up showing a list of possible pages to jump to. With -    TQToolButton you can set a popup menu using setPopup(). The default -    delay is 600ms; you can adjust it with setPopupDelay(). - -    \img qdockwindow.png Toolbar with Toolbuttons \caption A floating -    TQToolbar with TQToolbuttons - -    \sa TQPushButton TQToolBar TQMainWindow \link guibooks.html#fowler -    GUI Design Handbook: Push Button\endlink -*/ - -/*! -    \enum TQToolButton::TextPosition - -    The position of the tool button's textLabel in relation to the -    tool button's icon. - -    \value BesideIcon The text appears beside the icon. -    \value BelowIcon The text appears below the icon. -*/ - - -/*! -    Constructs an empty tool button called \a name, with parent \a -    parent. -*/ - -TQToolButton::TQToolButton( TQWidget * parent, const char *name ) -    : TQButton( parent, name ) -{ -    init(); -#ifndef TQT_NO_TOOLBAR -    TQToolBar* tb = ::tqqt_cast<TQToolBar*>(parent); -    if ( tb ) { -	setAutoRaise( TRUE ); -	if ( tb->mainWindow() ) { -	    connect( tb->mainWindow(), TQT_SIGNAL(pixmapSizeChanged(bool)), -	             this, TQT_SLOT(setUsesBigPixmap(bool)) ); -	    setUsesBigPixmap( tb->mainWindow()->usesBigPixmaps() ); -	    connect( tb->mainWindow(), TQT_SIGNAL(usesTextLabelChanged(bool)), -	             this, TQT_SLOT(setUsesTextLabel(bool)) ); -	    setUsesTextLabel( tb->mainWindow()->usesTextLabel() ); -	} else { -	    setUsesBigPixmap( FALSE ); -	} -    } else -#endif -    { -	setUsesBigPixmap( FALSE ); -    } -} - - -/*! -    Constructs a tool button as an arrow button. The \c ArrowType \a -    type defines the arrow direction. Possible values are \c -    LeftArrow, \c RightArrow, \c UpArrow and \c DownArrow. - -    An arrow button has auto-repeat turned on by default. - -    The \a parent and \a name arguments are sent to the TQWidget -    constructor. -*/ -TQToolButton::TQToolButton( TQt::ArrowType type, TQWidget *parent, const char *name ) -    : TQButton( parent, name ) -{ -    init(); -    setUsesBigPixmap( FALSE ); -    setAutoRepeat( TRUE ); -    d->arrow = type; -    hasArrow = TRUE; -} - - -/*  Set-up code common to all the constructors */ - -void TQToolButton::init() -{ -    d = new TQToolButtonPrivate; -    d->textPos = Under; -#ifndef TQT_NO_POPUPMENU -    d->delay = 600; -    d->popup = 0; -    d->popupTimer = 0; -#endif -    d->autoraise = FALSE; -    d->arrow = TQt::LeftArrow; -    d->instantPopup = FALSE; -    d->discardNextMouseEvent = FALSE; -    bpID = bp.serialNumber(); -    spID = sp.serialNumber(); - -    utl = FALSE; -    ubp = TRUE; -    hasArrow = FALSE; - -    s = 0; - -    setFocusPolicy( Qt::NoFocus ); -    setBackgroundMode( TQt::PaletteButton); -    tqsetSizePolicy( TQSizePolicy( TQSizePolicy::Minimum, TQSizePolicy::Minimum ) ); -} - -#ifndef TQT_NO_TOOLBAR - -/*! -    Constructs a tool button called \a name, that is a child of \a -    parent (which must be a TQToolBar). - -    The tool button will display \a iconSet, with its text label and -    tool tip set to \a textLabel and its status bar message set to \a -    grouptext. It will be connected to the \a slot in object \a -    receiver. -*/ - -TQToolButton::TQToolButton( const TQIconSet& iconSet, const TQString &textLabel, -			  const TQString& grouptext, -			  TQT_BASE_OBJECT_NAME * receiver, const char *slot, -			  TQToolBar * parent, const char *name ) -    : TQButton( parent, name ) -{ -    init(); -    setAutoRaise( TRUE ); -    setIconSet( iconSet ); -    setTextLabel( textLabel ); -    if ( receiver && slot ) -	connect( this, TQT_SIGNAL(clicked()), receiver, slot ); -    if ( parent->mainWindow() ) { -	connect( parent->mainWindow(), TQT_SIGNAL(pixmapSizeChanged(bool)), -		 this, TQT_SLOT(setUsesBigPixmap(bool)) ); -	setUsesBigPixmap( parent->mainWindow()->usesBigPixmaps() ); -	connect( parent->mainWindow(), TQT_SIGNAL(usesTextLabelChanged(bool)), -		 this, TQT_SLOT(setUsesTextLabel(bool)) ); -	setUsesTextLabel( parent->mainWindow()->usesTextLabel() ); -    } else { -	setUsesBigPixmap( FALSE ); -    } -#ifndef TQT_NO_TOOLTIP -    if ( !textLabel.isEmpty() ) { -	if ( !grouptext.isEmpty() && parent->mainWindow() ) -	    TQToolTip::add( this, textLabel, -			   parent->mainWindow()->toolTipGroup(), grouptext ); -	else -	    TQToolTip::add( this, textLabel ); -    } else if ( !grouptext.isEmpty() && parent->mainWindow() ) -	TQToolTip::add( this, TQString::null, -		parent->mainWindow()->toolTipGroup(), grouptext ); -#endif -} - -#endif - - -/*! -    Destroys the object and frees any allocated resources. -*/ - -TQToolButton::~TQToolButton() -{ -#ifndef TQT_NO_POPUPMENU -    d->popupTimer = 0; -    d->popup = 0; -#endif -    delete d; -    delete s; -} - - -/*! -    \property TQToolButton::backgroundMode -    \brief the toolbutton's background mode - -    Get this property with backgroundMode(). - -    \sa TQWidget::setBackgroundMode() -*/ - -/*! -    \property TQToolButton::toggleButton -    \brief whether this tool button is a toggle button. - -    Toggle buttons have an on/off state similar to \link TQCheckBox -    check boxes. \endlink A tool button is not a toggle button by -    default. - -    \sa setOn(), toggle() -*/ - -void TQToolButton::setToggleButton( bool enable ) -{ -    TQButton::setToggleButton( enable ); -} - - -/*! -    \reimp -*/ -TQSize TQToolButton::tqsizeHint() const -{ -    constPolish(); - -    int w = 0, h = 0; - -    if ( iconSet().isNull() && !text().isNull() && !usesTextLabel() ) { -     	w = fontMetrics().width( text() ); -     	h = fontMetrics().height(); // boundingRect()? -    } else if ( usesBigPixmap() ) { -     	TQPixmap pm = iconSet().pixmap( TQIconSet::Large, TQIconSet::Normal ); -     	w = pm.width(); -     	h = pm.height(); -	TQSize iconSize = TQIconSet::iconSize( TQIconSet::Large ); -	if ( w < iconSize.width() ) -     	    w = iconSize.width(); -     	if ( h < iconSize.height() ) -     	    h = iconSize.height(); -    } else if ( !iconSet().isNull() ) { -	// ### in 3.1, use TQIconSet::iconSize( TQIconSet::Small ); -     	TQPixmap pm = iconSet().pixmap( TQIconSet::Small, TQIconSet::Normal ); -     	w = pm.width(); -     	h = pm.height(); -	if ( w < 16 ) -	    w = 16; -	if ( h < 16 ) -	    h = 16; -    } - -    if ( usesTextLabel() ) { -	TQSize textSize = fontMetrics().size( TQt::ShowPrefix, textLabel() ); -	textSize.setWidth( textSize.width() + fontMetrics().width(' ')*2 ); -	if ( d->textPos == Under ) { -	    h += 4 + textSize.height(); -	    if ( textSize.width() > w ) -		w = textSize.width(); -	} else { // Right -	    w += 4 + textSize.width(); -	    if ( textSize.height() > h ) -		h = textSize.height(); -	} -    } - -#ifndef TQT_NO_POPUPMENU -    if ( popup() && ! popupDelay() ) -     	w += tqstyle().tqpixelMetric(TQStyle::PM_MenuButtonIndicator, this); -#endif -    return (tqstyle().tqsizeFromContents(TQStyle::CT_ToolButton, this, TQSize(w, h)). -	    expandedTo(TQApplication::globalStrut())); -} - -/*! -    \reimp - */ -TQSize TQToolButton::tqminimumSizeHint() const -{ -    return tqsizeHint(); -} - -/*! -    \property TQToolButton::usesBigPixmap -    \brief whether this toolbutton uses big pixmaps. - -    TQToolButton automatically connects this property to the relevant -    signal in the TQMainWindow in which it resides. We strongly -    recommend that you use TQMainWindow::setUsesBigPixmaps() instead. - -    This property's default is TRUE. - -    \warning If you set some buttons (in a TQMainWindow) to have big -    pixmaps and others to have small pixmaps, TQMainWindow may not get -    the tqgeometry right. -*/ - -void TQToolButton::setUsesBigPixmap( bool enable ) -{ -    if ( (bool)ubp == enable ) -	return; - -    ubp = enable; -    if ( isVisible() ) { -	update(); -	updateGeometry(); -    } -} - - -/*! -    \property TQToolButton::usesTextLabel -    \brief whether the toolbutton displays a text label below the button pixmap. - -    The default is FALSE. - -    TQToolButton automatically connects this slot to the relevant -    signal in the TQMainWindow in which is resides. -*/ - -void TQToolButton::setUsesTextLabel( bool enable ) -{ -    if ( (bool)utl == enable ) -	return; - -    utl = enable; -    if ( isVisible() ) { -	update(); -	updateGeometry(); -    } -} - - -/*! -    \property TQToolButton::on -    \brief whether this tool button is on. - -    This property has no effect on \link isToggleButton() non-toggling -    buttons. \endlink The default is FALSE (i.e. off). - -    \sa isToggleButton() toggle() -*/ - -void TQToolButton::setOn( bool enable ) -{ -    if ( !isToggleButton() ) -	return; -    TQButton::setOn( enable ); -} - - -/*! -    Toggles the state of this tool button. - -    This function has no effect on \link isToggleButton() non-toggling -    buttons. \endlink - -    \sa isToggleButton() toggled() -*/ - -void TQToolButton::toggle() -{ -    if ( !isToggleButton() ) -	return; -    TQButton::setOn( !isOn() ); -} - - -/*! -    \reimp -*/ -void TQToolButton::drawButton( TQPainter * p ) -{ -    TQStyle::SCFlags controls = TQStyle::SC_ToolButton; -    TQStyle::SCFlags active = TQStyle::SC_None; - -    TQt::ArrowType arrowtype = d->arrow; - -    if (isDown()) -	active |= TQStyle::SC_ToolButton; - -#ifndef TQT_NO_POPUPMENU -    if (d->popup && !d->delay) { -	controls |= TQStyle::SC_ToolButtonMenu; -	if (d->instantPopup || isDown()) -	    active |= TQStyle::SC_ToolButtonMenu; -    } -#endif - -    TQStyle::SFlags flags = TQStyle::Style_Default; -    if (isEnabled()) -	flags |= TQStyle::Style_Enabled; -    if (hasFocus()) -	flags |= TQStyle::Style_HasFocus; -    if (isDown()) -	flags |= TQStyle::Style_Down; -    if (isOn()) -	flags |= TQStyle::Style_On; -    if (autoRaise()) { -	flags |= TQStyle::Style_AutoRaise; -	if (uses3D()) { -	    flags |= TQStyle::Style_MouseOver; -	    if (! isOn() && ! isDown()) -		flags |= TQStyle::Style_Raised; -	} -    } else if (! isOn() && ! isDown()) -	flags |= TQStyle::Style_Raised; - -    tqstyle().tqdrawComplexControl(TQStyle::CC_ToolButton, p, this, rect(), tqcolorGroup(), -			       flags, controls, active, -				hasArrow ? TQStyleOption(arrowtype) : -				    TQStyleOption()); -    drawButtonLabel(p); -} - - -/*! -    \reimp -*/ -void TQToolButton::drawButtonLabel(TQPainter *p) -{ -    TQRect r = -	TQStyle::tqvisualRect(tqstyle().subRect(TQStyle::SR_ToolButtonContents, this), this); - -    TQt::ArrowType arrowtype = d->arrow; - -    TQStyle::SFlags flags = TQStyle::Style_Default; -    if (isEnabled()) -	flags |= TQStyle::Style_Enabled; -    if (hasFocus()) -	flags |= TQStyle::Style_HasFocus; -    if (isDown()) -	flags |= TQStyle::Style_Down; -    if (isOn()) -	flags |= TQStyle::Style_On; -    if (autoRaise()) { -	flags |= TQStyle::Style_AutoRaise; -	if (uses3D()) { -	    flags |= TQStyle::Style_MouseOver; -	    if (! isOn() && ! isDown()) -		flags |= TQStyle::Style_Raised; -	} -    } else if (! isOn() && ! isDown()) -	flags |= TQStyle::Style_Raised; - -    tqstyle().tqdrawControl(TQStyle::CE_ToolButtonLabel, p, this, r, -			tqcolorGroup(), flags, -			hasArrow ? TQStyleOption(arrowtype) : -			    TQStyleOption()); -} - - -/*! -    \reimp - */ -void TQToolButton::enterEvent( TQEvent * e ) -{ -    if ( autoRaise() && isEnabled() ) -	tqrepaint(FALSE); - -    TQButton::enterEvent( e ); -} - - -/*! -    \reimp - */ -void TQToolButton::leaveEvent( TQEvent * e ) -{ -    if ( autoRaise() && isEnabled() ) -	tqrepaint(FALSE); - -    TQButton::leaveEvent( e ); -} - -/*! -    \reimp - */ -void TQToolButton::moveEvent( TQMoveEvent * ) -{ -    //   Reimplemented to handle pseudo transparency in case the toolbars -    //   has a fancy pixmap background. -    if ( parentWidget() && parentWidget()->backgroundPixmap() && -	 autoRaise() && !uses3D() ) -	tqrepaint( FALSE ); -} - -/*! -    \reimp -*/ -void TQToolButton::mousePressEvent( TQMouseEvent *e ) -{ -    TQRect popupr = -	TQStyle::tqvisualRect( tqstyle().querySubControlMetrics(TQStyle::CC_ToolButton, this, -				       TQStyle::SC_ToolButtonMenu), this ); -    d->instantPopup = (popupr.isValid() && popupr.contains(e->pos())); - -#ifndef TQT_NO_POPUPMENU -    if ( d->discardNextMouseEvent ) { -	d->discardNextMouseEvent = FALSE; -	d->instantPopup = FALSE; -	d->popup->removeEventFilter( this ); -	return; -    } -    if ( e->button() == Qt::LeftButton && d->delay <= 0 && d->popup && d->instantPopup && !d->popup->isVisible() ) { -	openPopup(); -	return; -    } -#endif - -    d->instantPopup = FALSE; -    TQButton::mousePressEvent( e ); -} - -/*! -    \reimp -*/ -bool TQToolButton::eventFilter( TQObject *o, TQEvent *e ) -{ -#ifndef TQT_NO_POPUPMENU -    if ( TQT_BASE_OBJECT(o) != TQT_BASE_OBJECT(d->popup) ) -	return TQButton::eventFilter( o, e ); -    switch ( e->type() ) { -    case TQEvent::MouseButtonPress: -    case TQEvent::MouseButtonDblClick: -	{ -	    TQMouseEvent *me = (TQMouseEvent*)e; -	    TQPoint p = me->globalPos(); -	    if ( TQApplication::widgetAt( p, TRUE ) == this ) -		d->discardNextMouseEvent = TRUE; -	} -	break; -    default: -	break; -    } -#endif -    return TQButton::eventFilter( o, e ); -} - -/*! -    Returns TRUE if this button should be drawn using raised edges; -    otherwise returns FALSE. - -    \sa drawButton() -*/ - -bool TQToolButton::uses3D() const -{ -    return tqstyle().tqstyleHint(TQStyle::SH_ToolButton_Uses3D) -	&& (!autoRaise() || ( hasMouse() && isEnabled() ) -#ifndef TQT_NO_POPUPMENU -	    || ( d->popup && d->popup->isVisible() && d->delay <= 0 ) || d->instantPopup -#endif -	    ); -} - - -/*! -    \property TQToolButton::textLabel -    \brief the label of this button. - -    Setting this property automatically sets the text as a tool tip -    too. There is no default text. -*/ - -void TQToolButton::setTextLabel( const TQString &newLabel ) -{ -    setTextLabel( newLabel, TRUE ); -} - -/*! -    \overload - -    Sets the label of this button to \a newLabel and automatically -    sets it as a tool tip if \a tipToo is TRUE. -*/ - -void TQToolButton::setTextLabel( const TQString &newLabel , bool tipToo ) -{ -    if ( tl == newLabel ) -	return; - -#ifndef TQT_NO_TOOLTIP -    if ( tipToo ) { -        TQToolTip::remove( this ); -        TQToolTip::add( this, newLabel ); -    } -#endif - -    tl = newLabel; -    if ( usesTextLabel() && isVisible() ) { -	update(); -	updateGeometry(); -    } - -} - -#ifndef TQT_NO_COMPAT - -TQIconSet TQToolButton::onIconSet() const -{ -    return iconSet(); -} - -TQIconSet TQToolButton::offIconSet( ) const -{ -    return iconSet(); -} - - -/*! -  \property TQToolButton::onIconSet -  \brief the icon set that is used when the button is in an "on" state - -  \obsolete - -  Since TQt 3.0, TQIconSet contains both the On and Off icons. There is -  now an \l TQToolButton::iconSet property that replaces both \l -  TQToolButton::onIconSet and \l TQToolButton::offIconSet. - -  For ease of porting, this property is a synonym for \l -  TQToolButton::iconSet. You probably want to go over your application -  code and use the TQIconSet On/Off mechanism. - -  \sa iconSet TQIconSet::State -*/ -void TQToolButton::setOnIconSet( const TQIconSet& set ) -{ -    setIconSet( set ); -    /* -      ### Get rid of all qWarning in this file in 4.0. -      Also consider inlining the obsolete functions then. -    */ -    qWarning( "TQToolButton::setOnIconSet(): This function is not supported" -	      " anymore" ); -} - -/*! -  \property TQToolButton::offIconSet -  \brief the icon set that is used when the button is in an "off" state - -  \obsolete - -  Since TQt 3.0, TQIconSet contains both the On and Off icons. There is -  now an \l TQToolButton::iconSet property that replaces both \l -  TQToolButton::onIconSet and \l TQToolButton::offIconSet. - -  For ease of porting, this property is a synonym for \l -  TQToolButton::iconSet. You probably want to go over your application -  code and use the TQIconSet On/Off mechanism. - -  \sa iconSet TQIconSet::State -*/ -void TQToolButton::setOffIconSet( const TQIconSet& set ) -{ -    setIconSet( set ); -} - -#endif - -/*! \property TQToolButton::pixmap -    \brief the pixmap of the button - -    The pixmap property has no meaning for tool buttons. Use the -    iconSet property instead. -*/ - -/*! -    \property TQToolButton::iconSet -    \brief the icon set providing the icon shown on the button - -    Setting this property sets \l TQToolButton::pixmap to a null -    pixmap. There is no default iconset. - -    \sa pixmap(), setToggleButton(), isOn() -*/ -void TQToolButton::setIconSet( const TQIconSet & set ) -{ -    if ( s ) -	delete s; -    setPixmap( TQPixmap() ); -    s = new TQIconSet( set ); -    if ( isVisible() ) -	update(); -} - -/*! \overload -    \obsolete - -  Since TQt 3.0, TQIconSet contains both the On and Off icons. - -  For ease of porting, this function ignores the \a on parameter and -  sets the \l iconSet property. If you relied on the \a on parameter, -  you probably want to update your code to use the TQIconSet On/Off -  mechanism. - -  \sa iconSet TQIconSet::State -*/ - -#ifndef TQT_NO_COMPAT - -void TQToolButton::setIconSet( const TQIconSet & set, bool /* on */ ) -{ -    setIconSet( set ); -    qWarning( "TQToolButton::setIconSet(): 'on' parameter ignored" ); -} - -#endif - -TQIconSet TQToolButton::iconSet() const -{ -    TQToolButton *that = (TQToolButton *) this; - -    if ( pixmap() && !pixmap()->isNull() && -	 (!that->s || (that->s->pixmap().serialNumber() != -	 pixmap()->serialNumber())) ) { -	if ( that->s ) -	    delete that->s; -	that->s = new TQIconSet( *pixmap() ); -    } -    if ( that->s ) -	return *that->s; -    /* -      In 2.x, we used to return a temporary nonnull TQIconSet. If you -      revert to the old behavior, you will break calls to -      TQIconSet::isNull() in this file. -    */ -    return TQIconSet(); -} - -#ifndef TQT_NO_COMPAT -/*! \overload -    \obsolete - -  Since TQt 3.0, TQIconSet contains both the On and Off icons. - -  For ease of porting, this function ignores the \a on parameter and -  returns the \l iconSet property. If you relied on the \a on -  parameter, you probably want to update your code to use the TQIconSet -  On/Off mechanism. -*/ -TQIconSet TQToolButton::iconSet( bool /* on */ ) const -{ -    return iconSet(); -} - -#endif - -#ifndef TQT_NO_POPUPMENU -/*! -    Associates the popup menu \a popup with this tool button. - -    The popup will be shown each time the tool button has been pressed -    down for a certain amount of time. A typical application example -    is the "back" button in some web browsers's tool bars. If the user -    clicks it, the browser simply browses back to the previous page. -    If the user presses and holds the button down for a while, the -    tool button shows a menu containing the current history list. - -    Ownership of the popup menu is not transferred to the tool button. - -    \sa popup() -*/ -void TQToolButton::setPopup( TQPopupMenu* popup ) -{ -    if ( popup && !d->popupTimer ) { -	connect( this, TQT_SIGNAL( pressed() ), this, TQT_SLOT( popupPressed() ) ); -	d->popupTimer = new TQTimer( this ); -	connect( d->popupTimer, TQT_SIGNAL( timeout() ), this, TQT_SLOT( popupTimerDone() ) ); -    } -    d->popup = popup; - -    update(); -} - -/*! -    Returns the associated popup menu, or 0 if no popup menu has been -    defined. - -    \sa setPopup() -*/ -TQPopupMenu* TQToolButton::popup() const -{ -    return d->popup; -} - -/*! -    Opens (pops up) the associated popup menu. If there is no such -    menu, this function does nothing. This function does not return -    until the popup menu has been closed by the user. -*/ -void TQToolButton::openPopup() -{ -    if ( !d->popup ) -	return; - -    d->instantPopup = TRUE; -    tqrepaint( FALSE ); -    if ( d->popupTimer ) -	d->popupTimer->stop(); -    TQGuardedPtr<TQToolButton> that = this; -    popupTimerDone(); -    if ( !that ) -	return; -    d->instantPopup = FALSE; -    tqrepaint( FALSE ); -} - -void TQToolButton::popupPressed() -{ -    if ( d->popupTimer && d->delay > 0 ) -	d->popupTimer->start( d->delay, TRUE ); -} - -void TQToolButton::popupTimerDone() -{ -    if ( (!isDown() && d->delay > 0 ) || !d->popup ) -	return; - -    d->popup->installEventFilter( this ); -    d->repeat = autoRepeat(); -    setAutoRepeat( FALSE ); -    bool horizontal = TRUE; -#ifndef TQT_NO_TOOLBAR -    TQToolBar *tb = ::tqqt_cast<TQToolBar*>(parentWidget()); -    if ( tb && tb->orientation() == Qt::Vertical ) -	horizontal = FALSE; -#endif -    TQPoint p; -    TQRect screen = tqApp->desktop()->availableGeometry( this ); -    if ( horizontal ) { -	if ( TQApplication::reverseLayout() ) { -	    if ( mapToGlobal( TQPoint( 0, rect().bottom() ) ).y() + d->popup->tqsizeHint().height() <= screen.height() ) { -		p = mapToGlobal( rect().bottomRight() ); -	    } else { -		p = mapToGlobal( rect().topRight() - TQPoint( 0, d->popup->tqsizeHint().height() ) ); -	    } -	    p.rx() -= d->popup->tqsizeHint().width(); -	} else { -	    if ( mapToGlobal( TQPoint( 0, rect().bottom() ) ).y() + d->popup->tqsizeHint().height() <= screen.height() ) { -		p = mapToGlobal( rect().bottomLeft() ); -	    } else { -		p = mapToGlobal( rect().topLeft() - TQPoint( 0, d->popup->tqsizeHint().height() ) ); -	    } -	} -    } else { -	if ( TQApplication::reverseLayout() ) { -	    if ( mapToGlobal( TQPoint( rect().left(), 0 ) ).x() - d->popup->tqsizeHint().width() <= screen.x() ) { -		p = mapToGlobal( rect().topRight() ); -	    } else { -		p = mapToGlobal( rect().topLeft() ); -		p.rx() -= d->popup->tqsizeHint().width(); -	    } -	} else { -	    if ( mapToGlobal( TQPoint( rect().right(), 0 ) ).x() + d->popup->tqsizeHint().width() <= screen.width() ) { -		p = mapToGlobal( rect().topRight() ); -	    } else { -		p = mapToGlobal( rect().topLeft() - TQPoint( d->popup->tqsizeHint().width(), 0 ) ); -	    } -	} -    } -    TQGuardedPtr<TQToolButton> that = this; -    d->popup->exec( p, -1 ); -    if ( !that ) -	return; - -    setDown( FALSE ); -    if ( d->repeat ) -	setAutoRepeat( TRUE ); -} - -/*! -    \property TQToolButton::popupDelay -    \brief the time delay between pressing the button and the appearance of the associated popup menu in milliseconds. - -    Usually this is around half a second. A value of 0 draws the down -    arrow button to the side of the button which can be used to open -    up the popup menu. - -    \sa setPopup() -*/ -void TQToolButton::setPopupDelay( int delay ) -{ -    d->delay = delay; - -    update(); -} - -int TQToolButton::popupDelay() const -{ -    return d->delay; -} -#endif - - -/*! -    \property TQToolButton::autoRaise -    \brief whether auto-raising is enabled or not. - -    The default is disabled (i.e. FALSE). -*/ -void TQToolButton::setAutoRaise( bool enable ) -{ -    d->autoraise = enable; - -    update(); -} - -bool TQToolButton::autoRaise() const -{ -    return d->autoraise; -} - -/*! -    \property TQToolButton::textPosition -    \brief the position of the text label of this button. -*/ - -TQToolButton::TextPosition TQToolButton::textPosition() const -{ -    return d->textPos; -} - -void TQToolButton::setTextPosition( TextPosition pos ) -{ -    d->textPos = pos; -    updateGeometry(); -    update(); -} - -/*! \reimp */ - -void TQToolButton::setText( const TQString &txt ) -{ -    TQButton::setText( txt ); -    if ( !text().isEmpty() ) { -	delete s; -	s = 0; -    } -} - -#ifndef TQT_NO_PALETTE -/*! -    \reimp -*/ -void TQToolButton::paletteChange( const TQPalette & ) -{ -    if ( s ) -	s->clearGenerated(); -} -#endif - -#endif | 
