summaryrefslogtreecommitdiffstats
path: root/tqtinterface/qt4/src/widgets/tqtoolbutton.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tqtinterface/qt4/src/widgets/tqtoolbutton.cpp')
-rw-r--r--tqtinterface/qt4/src/widgets/tqtoolbutton.cpp1041
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 [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.
-**
-**********************************************************************/
-
-#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