Skip to main content

A modern and fully customizable tooltip library for PyQt and PySide

Project description

PyQt Tooltip

PyPI Python Build Coverage License

A modern and fully customizable tooltip library for PyQt and PySide

pyqttooltip

Features

  • Fixed and automatic placement
  • Supports fallback placements
  • Customizable triangle
  • Customizable animations and delays
  • Fully customizable and modern UI
  • Works with PyQt5, PyQt6, PySide2, and PySide6

Installation

pip install pyqttooltip

Usage

from PyQt6.QtWidgets import QMainWindow, QPushButton
from pyqttooltip import Tooltip, TooltipPlacement


class Window(QMainWindow):
    def __init__(self):
        super().__init__(parent=None)

        # Add button
        self.button = QPushButton('Button', self)
        
        # Add tooltip to button
        self.tooltip = Tooltip(self.button, 'This is a tooltip')

The tooltip will automatically be shown while hovering the widget. If you want to manually show and hide the tooltip, you can use the show() and hide() methods:

tooltip.show()
tooltip.hide()

To delete a tooltip, you can use the deleteLater() method:

tooltip.deleteLater()

To get notified when a tooltip gets shown or hidden, you can subscribe to the shown and hidden signals:

tooltip.shown.connect(lambda: print('shown'))
tooltip.hidden.connect(lambda: print('hidden'))

Customization

  • Setting the widget:
tooltip.setWidget(widget)  # Default: None
  • Setting the text:
tooltip.setText('Text of the tooltip')  # Default: ''
  • Setting the placement:
tooltip.setPlacement(TooltipPlacement.RIGHT)  # Default: TooltipPlacement.AUTO

AVAILABLE PLACEMENTS:
AUTO, LEFT, RIGHT, TOP, BOTTOM

  • Setting the fallback placements:
tooltip.setFallbackPlacements([TooltipPlacement.TOP, TooltipPlacement.BOTTOM])  # Default: []

If the tooltip doesn't fit on the screen with the primary placement, one of the fallback placements will be chosen instead in the order of the provided list.
To get the current placement of the tooltip, you can use the getActualPlacement() method.

  • Enabling or disabling the triangle:
tooltip.setTriangleEnabled(False)  # Default: True
  • Setting the size of the triangle:
tooltip.setTriangleSize(7)  # Default: 5
  • Setting a duration:
tooltip.setDuration(1000)  # Default: 0

The duration is the time in milliseconds after which the tooltip will start fading out again. If the duration is set to 0, the tooltip will stay visible for as long as the widget is hovered.

  • Setting the offsets:
# Setting the offset for a specific placement
tooltip.setOffsetByPlacement(TooltipPlacement.LEFT, QPoint(-10, 5))

# Using a dict that specifies the offset for each placement you want to set
offsets = {
    TooltipPlacement.LEFT:   QPoint(-10, 5),
    TooltipPlacement.RIGHT:  QPoint(10, 5),
    TooltipPlacement.TOP:    QPoint(5, -10),
    TooltipPlacement.BOTTOM: QPoint(5, 10)
}
tooltip.setOffsets(offsets)

# Setting the offsets for all the placements to a single value
tooltip.setOffsetsAll(QPoint(10, 5))

Each placement / side has its own offset to allow for full customizability. Each offset is a QPoint, which is made up of an x and y value.
By default, all the offsets are set to QPoint(0, 0).

  • Adding delays to the fade in / out animations after hovering the widget:
tooltip.setShowDelay(500)  # Default: 50
tooltip.setHideDelay(500)  # Default: 50
  • Setting the durations of the fade in / out animations:
tooltip.setFadeInDuration(250)   # Default: 150
tooltip.setFadeOutDuration(250)  # Default: 150
  • Setting the border radius:
tooltip.setBorderRadius(0)   # Default: 2
  • Enabling or disabling the border:
tooltip.setBorderEnabled(True)   # Default: False
  • Setting custom colors:
tooltip.setBackgroundColor(QColor('#FCBA03'))   # Default: QColor('#111214')
tooltip.setTextColor(QColor('#000000'))         # Default: QColor('#CFD2D5')
tooltip.setBorderColor(QColor('#A38329'))       # Default: QColor('#403E41')
  • Setting a custom font:
tooltip.setFont(QFont('Consolas', 10))  # Default: QFont('Arial', 9, QFont.Weight.Bold)
  • Applying margins to the content of the tooltip:
tooltip.setMargins(QMargins(10, 8, 10, 8))  # Default: QMargins(12, 8, 12, 7)
  • Setting a maximum width:
tooltip.setMaximumWidth(150)  # Default: 16777215 (QWIDGETSIZE_MAX)
  • Enabling or disabling text centering for wrapped text:
tooltip.setTextCenteringEnabled(False)  # Default: True
  • Enabling or disabling the drop shadow:
tooltip.setDropShadowEnabled(False)  # Default: True
  • Changing the drop shadow strength:
tooltip.setDropShadowStrength(3.5)  # Default: 2.0
  • Making the tooltip translucent:
tooltip.setOpacity(0.8)  # Default: 1.0


Other customization options:

Option Description Default
setShowingOnDisabled() Whether the tooltips should also be shown on disabled widgets False
setFadeInEasingCurve() The easing curve of the fade in animation QEasingCurve.Type.Linear
setFadeOutEasingCurve() The easing curve of the fade out animation QEasingCurve.Type.Linear
setMarginLeft() Set left margin individually 12
setMarginRight() Set right margin individually 12
setMarginTop() Set top margin individually 8
setMarginBottom() Set bottom margin individually 7

Demo

https://github.com/user-attachments/assets/fa768d30-f3cc-4883-aa8b-fed3a8824b23

The demos for PyQt5, PyQt6, and PySide6 can be found in the demo folder.

To keep the demo simple, only the most important features are included. To get an overview of all the customization options, check out the documentation above.

Tests

Installing the required test dependencies PyQt6, pytest, and coveragepy:

pip install PyQt6 pytest coverage

To run the tests with coverage, clone this repository, go into the main directory and run:

coverage run -m pytest
coverage report --ignore-errors -m

License

This software is licensed under the MIT license.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyqttooltip-1.0.0.tar.gz (15.8 kB view details)

Uploaded Source

Built Distribution

pyqttooltip-1.0.0-py3-none-any.whl (15.4 kB view details)

Uploaded Python 3

File details

Details for the file pyqttooltip-1.0.0.tar.gz.

File metadata

  • Download URL: pyqttooltip-1.0.0.tar.gz
  • Upload date:
  • Size: 15.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.3

File hashes

Hashes for pyqttooltip-1.0.0.tar.gz
Algorithm Hash digest
SHA256 4f6056c3c8d53a9873b3337905d669ba5632729ace8935d55d45fec2614a9f01
MD5 16c2eb24314df1ee385960bb50312e25
BLAKE2b-256 562d1db43cbe060c520de42b031eacad4828946c47d63b58fa75dac629b4ac41

See more details on using hashes here.

File details

Details for the file pyqttooltip-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: pyqttooltip-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 15.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.3

File hashes

Hashes for pyqttooltip-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a2d81b0544baea3cb8f171d908c5976125322de7721a634e5bd5f9d713bb442f
MD5 3ba029f0be4c1396900abb4ca816a1e1
BLAKE2b-256 5145627fbd7a6dddf3a55010607e7fb354755b9ae792991a8e66a588f6dfa2a0

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page