Source code for umbra.ui.widgets.active_QLabel

#!/usr/bin/env python
# -*- coding: utf-8 -*-

"""
**active_QLabel.py**

**Platform:**
	Windows, Linux, Mac Os X.

**Description:**
	Defines the :class:`Active_QLabel` class.

**Others:**

"""

#**********************************************************************************************************************
#***	Future imports.
#**********************************************************************************************************************
from __future__ import unicode_literals

#**********************************************************************************************************************
#***	External imports.
#**********************************************************************************************************************
from PyQt4.QtCore import pyqtSignal
from PyQt4.QtGui import QCursor
from PyQt4.QtGui import QLabel
from PyQt4.QtGui import QPixmap

#**********************************************************************************************************************
#***	Internal imports.
#**********************************************************************************************************************
import foundations.exceptions
import foundations.verbose
import umbra.ui.common

#**********************************************************************************************************************
#***	Module attributes.
#**********************************************************************************************************************
__author__ = "Thomas Mansencal"
__copyright__ = "Copyright (C) 2008 - 2014 - Thomas Mansencal"
__license__ = "GPL V3.0 - http://www.gnu.org/licenses/"
__maintainer__ = "Thomas Mansencal"
__email__ = "[email protected]"
__status__ = "Production"

__all__ = ["LOGGER", "Active_QLabel"]

LOGGER = foundations.verbose.installLogger()

#**********************************************************************************************************************
#***	Module classes and definitions.
#**********************************************************************************************************************
[docs]class Active_QLabel(QLabel): """ Defines a `QLabel <http://doc.qt.nokia.com/qlabel.html>`_ subclass providing a clickable label with hovering capabilities. """ # Custom signals definitions. clicked = pyqtSignal() """ This signal is emited by the :class:`Active_QLabel` class when it has been clicked. ( pyqtSignal ) """ pressed = pyqtSignal() """ This signal is emited by the :class:`Active_QLabel` class when it has been pressed. ( pyqtSignal ) """ released = pyqtSignal() """ This signal is emited by the :class:`Active_QLabel` class when it has been released. ( pyqtSignal ) """ toggled = pyqtSignal(bool) """ This signal is emited by the :class:`Active_QLabel` class when it has been toggled. ( pyqtSignal ) :return: Current checked state. :rtype: bool """ def __init__(self, parent=None, defaultPixmap=None, hoverPixmap=None, activePixmap=None, checkable=False, checked=False): """ Initializes the class. :param parent: Widget parent. :type parent: QObject :param defaultPixmap: Label default pixmap. :type defaultPixmap: QPixmap :param hoverPixmap: Label hover pixmap. :type hoverPixmap: QPixmap :param activePixmap: Label active pixmap. :type activePixmap: QPixmap :param checkable: Checkable state. :type checkable: bool :param checked: Checked state. :type checked: bool """ LOGGER.debug("> Initializing '{0}()' class.".format(self.__class__.__name__)) QLabel.__init__(self, parent) # --- Setting class attributes. --- self.__defaultPixmap = None self.defaultPixmap = defaultPixmap or QPixmap() self.__hoverPixmap = None self.hoverPixmap = hoverPixmap or QPixmap() self.__activePixmap = None self.activePixmap = activePixmap or QPixmap() self.__checkable = None self.checkable = checkable self.__checked = None self.checked = checked self.__menu = None if self.__checked: self.setPixmap(self.__activePixmap) else: self.setPixmap(self.__defaultPixmap) #****************************************************************************************************************** #*** Attributes properties. #****************************************************************************************************************** @property def defaultPixmap(self): """ Property for **self.__defaultPixmap** attribute. :return: self.__defaultPixmap. :rtype: QPixmap """ return self.__defaultPixmap @defaultPixmap.setter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(AssertionError) def defaultPixmap(self, value): """ Setter for **self.__defaultPixmap** attribute. :param value: Attribute value. :type value: QPixmap """ if value is not None: assert type(value) is QPixmap, "'{0}' attribute: '{1}' type is not 'QPixmap'!".format("defaultPixmap", value) self.__defaultPixmap = value @defaultPixmap.deleter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(foundations.exceptions.ProgrammingError)
[docs] def defaultPixmap(self): """ Deleter for **self.__defaultPixmap** attribute. """ raise foundations.exceptions.ProgrammingError( "{0} | '{1}' attribute is not deletable!".format(self.__class__.__name__, "defaultPixmap"))
@property def hoverPixmap(self): """ Property for **self.__hoverPixmap** attribute. :return: self.__hoverPixmap. :rtype: QPixmap """ return self.__hoverPixmap @hoverPixmap.setter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(AssertionError) def hoverPixmap(self, value): """ Setter for **self.__hoverPixmap** attribute. :param value: Attribute value. :type value: QPixmap """ if value is not None: assert type(value) is QPixmap, "'{0}' attribute: '{1}' type is not 'QPixmap'!".format("hoverPixmap", value) self.__hoverPixmap = value @hoverPixmap.deleter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(foundations.exceptions.ProgrammingError)
[docs] def hoverPixmap(self): """ Deleter for **self.__hoverPixmap** attribute. """ raise foundations.exceptions.ProgrammingError( "{0} | '{1}' attribute is not deletable!".format(self.__class__.__name__, "hoverPixmap"))
@property def activePixmap(self): """ Property for **self.__activePixmap** attribute. :return: self.__activePixmap. :rtype: QPixmap """ return self.__activePixmap @activePixmap.setter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(AssertionError) def activePixmap(self, value): """ Setter for **self.__activePixmap** attribute. :param value: Attribute value. :type value: QPixmap """ if value is not None: assert type(value) is QPixmap, "'{0}' attribute: '{1}' type is not 'QPixmap'!".format("activePixmap", value) self.__activePixmap = value @activePixmap.deleter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(foundations.exceptions.ProgrammingError)
[docs] def activePixmap(self): """ Deleter for **self.__activePixmap** attribute. """ raise foundations.exceptions.ProgrammingError( "{0} | '{1}' attribute is not deletable!".format(self.__class__.__name__, "activePixmap"))
@property def checkable(self): """ Property for **self.__checkable** attribute. :return: self.__checkable. :rtype: bool """ return self.__checkable @checkable.setter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(AssertionError) def checkable(self, value): """ Setter for **self.__checkable** attribute. :param value: Attribute value. :type value: bool """ if value is not None: assert type(value) is bool, "'{0}' attribute: '{1}' type is not 'bool'!".format("checkable", value) self.__checkable = value @checkable.deleter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(foundations.exceptions.ProgrammingError)
[docs] def checkable(self): """ Deleter for **self.__checkable** attribute. """ raise foundations.exceptions.ProgrammingError( "{0} | '{1}' attribute is not deletable!".format(self.__class__.__name__, "checkable"))
@property def checked(self): """ Property for **self.__checked** attribute. :return: self.__checked. :rtype: bool """ return self.__checked @checked.setter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(AssertionError) def checked(self, value): """ Setter for **self.__checked** attribute. :param value: Attribute value. :type value: bool """ if value is not None: assert type(value) is bool, "'{0}' attribute: '{1}' type is not 'bool'!".format("checked", value) self.setChecked(value) @checked.deleter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(foundations.exceptions.ProgrammingError)
[docs] def checked(self): """ Deleter for **self.__checked** attribute. """ raise foundations.exceptions.ProgrammingError( "{0} | '{1}' attribute is not deletable!".format(self.__class__.__name__, "checked"))
@property def menu(self): """ Property for **self.__menu** attribute. :return: self.__menu. :rtype: QMenu """ return self.__menu @menu.setter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(foundations.exceptions.ProgrammingError) def menu(self, value): """ Setter for **self.__menu** attribute. :param value: Attribute value. :type value: QMenu """ raise foundations.exceptions.ProgrammingError( "{0} | '{1}' attribute is read only!".format(self.__class__.__name__, "menu")) @menu.deleter # Oncilla: Statement commented by auto-documentation process: @foundations.exceptions.handleExceptions(foundations.exceptions.ProgrammingError)
[docs] def menu(self): """ Deleter for **self.__menu** attribute. """ raise foundations.exceptions.ProgrammingError( "{0} | '{1}' attribute is not deletable!".format(self.__class__.__name__, "menu")) #****************************************************************************************************************** #*** Class methods. #******************************************************************************************************************
[docs] def enterEvent(self, event): """ Reimplements the :meth:`QLabel.enterEvent` method. :param event: QEvent. :type event: QEvent """ if self.__checkable: not self.__checked and self.setPixmap(self.__hoverPixmap) else: self.setPixmap(self.__hoverPixmap)
[docs] def leaveEvent(self, event): """ Reimplements the :meth:`QLabel.leaveEvent` method. :param event: QEvent. :type event: QEvent """ if self.__checkable: not self.__checked and self.setPixmap(self.__defaultPixmap) else: self.setPixmap(self.__defaultPixmap)
[docs] def mousePressEvent(self, event): """ Reimplements the :meth:`QLabel.mousePressEvent` method. :param event: QEvent. :type event: QEvent """ self.setPixmap(self.__activePixmap) self.__menu and self.__menu.exec_(QCursor.pos()) self.pressed.emit()
[docs] def mouseReleaseEvent(self, event): """ Reimplements the :meth:`QLabel.mouseReleaseEvent` method. :param event: QEvent. :type event: QEvent """ if self.underMouse(): if self.__checkable: self.setChecked(not self.__checked) else: self.setPixmap(self.__activePixmap) else: self.setPixmap(self.__defaultPixmap) self.released.emit() self.clicked.emit()
[docs] def setChecked(self, state): """ Sets the Widget checked state. :param state: New check state. :type state: bool :return: Method success. :rtype: bool """ if not self.__checkable: return False if state: self.__checked = True self.setPixmap(self.__activePixmap) else: self.__checked = False self.setPixmap(self.__defaultPixmap) self.toggled.emit(state) return True
[docs] def setMenu(self, menu): """ Sets the Widget menu. :param menu: Menu. :type menu: QMenu :return: Method success. :rtype: bool """ self.__menu = menu if not self.parent(): return False parent = [parent for parent in umbra.ui.common.parentsWalker(self)].pop() for action in self.__menu.actions(): not action.shortcut().isEmpty() and parent.addAction(action) return True # Oncilla: Statement commented by auto-documentation process: # Oncilla: Statement commented by auto-documentation process: if __name__ == "__main__": # Oncilla: Statement commented by auto-documentation process: import sys # Oncilla: Statement commented by auto-documentation process: from PyQt4.QtGui import QGridLayout # Oncilla: Statement commented by auto-documentation process: from PyQt4.QtGui import QWidget # Oncilla: Statement commented by auto-documentation process: # Oncilla: Statement commented by auto-documentation process: from umbra.globals.uiConstants import UiConstants # Oncilla: Statement commented by auto-documentation process: # Oncilla: Statement commented by auto-documentation process: application = umbra.ui.common.getApplicationInstance() # Oncilla: Statement commented by auto-documentation process: # Oncilla: Statement commented by auto-documentation process: widget = QWidget() # Oncilla: Statement commented by auto-documentation process: # Oncilla: Statement commented by auto-documentation process: gridLayout = QGridLayout() # Oncilla: Statement commented by auto-documentation process: widget.setLayout(gridLayout) # Oncilla: Statement commented by auto-documentation process: # Oncilla: Statement commented by auto-documentation process: activeLabelA = Active_QLabel(widget, QPixmap(umbra.ui.common.getResourcePath(UiConstants.developmentIcon)), # Oncilla: Statement commented by auto-documentation process: QPixmap(umbra.ui.common.getResourcePath(UiConstants.developmentHoverIcon)), # Oncilla: Statement commented by auto-documentation process: QPixmap(umbra.ui.common.getResourcePath(UiConstants.developmentActiveIcon))) # Oncilla: Statement commented by auto-documentation process: activeLabelB = Active_QLabel(widget, QPixmap(umbra.ui.common.getResourcePath(UiConstants.preferencesIcon)), # Oncilla: Statement commented by auto-documentation process: QPixmap(umbra.ui.common.getResourcePath(UiConstants.preferencesHoverIcon)), # Oncilla: Statement commented by auto-documentation process: QPixmap(umbra.ui.common.getResourcePath(UiConstants.preferencesActiveIcon)), # Oncilla: Statement commented by auto-documentation process: checkable=True, # Oncilla: Statement commented by auto-documentation process: checked=True) # Oncilla: Statement commented by auto-documentation process: for activeLabel in (activeLabelA, activeLabelB): # Oncilla: Statement commented by auto-documentation process: gridLayout.addWidget(activeLabel) # Oncilla: Statement commented by auto-documentation process: # Oncilla: Statement commented by auto-documentation process: widget.show() # Oncilla: Statement commented by auto-documentation process: widget.raise_() # Oncilla: Statement commented by auto-documentation process: # Oncilla: Statement commented by auto-documentation process: sys.exit(application.exec_()) # Oncilla: Statement commented by auto-documentation process: