QMacStyle Class
The QMacStyle class provides a Mac OS X style using the Apple Appearance Manager. More...
#include <QMacStyle> Inherits: QWindowsStyle.
Public Types
enum | ComplexControl { CC_SpinBox, CC_ComboBox, CC_ScrollBar, CC_Slider, ..., CC_CustomBase } |
enum | ContentsType { CT_CheckBox, CT_ComboBox, CT_HeaderSection, CT_LineEdit, ..., CT_MdiControls } |
enum | ControlElement { CE_PushButton, CE_PushButtonBevel, CE_PushButtonLabel, CE_DockWidgetTitle, ..., CE_ShapedFrame } |
enum | FocusRectPolicy { FocusEnabled, FocusDisabled, FocusDefault } |
enum | PixelMetric { PM_ButtonMargin, PM_DockWidgetTitleBarButtonMargin, PM_ButtonDefaultIndicator, PM_MenuButtonIndicator, ..., PM_SubMenuOverlap } |
enum | PrimitiveElement { PE_FrameStatusBar, PE_PanelButtonCommand, PE_FrameDefaultButton, PE_PanelButtonBevel, ..., PE_PanelMenu } |
enum | RequestSoftwareInputPanel { RSIP_OnMouseClickAndAlreadyFocused, RSIP_OnMouseClick } |
enum | StandardPixmap { SP_TitleBarMinButton, SP_TitleBarMenuButton, SP_TitleBarMaxButton, SP_TitleBarCloseButton, ..., SP_CustomBase } |
flags | State |
enum | StateFlag { State_None, State_Active, State_AutoRaise, State_Children, ..., State_Small } |
enum | StyleHint { SH_EtchDisabledText, SH_DitherDisabledText, SH_GUIStyle, SH_ScrollBar_ContextMenu, ..., SH_RequestSoftwareInputPanel } |
enum | SubControl { SC_None, SC_ScrollBarAddLine, SC_ScrollBarSubLine, SC_ScrollBarAddPage, ..., SC_All } |
flags | SubControls |
enum | SubElement { SE_PushButtonContents, SE_PushButtonFocusRect, SE_PushButtonLayoutItem, SE_CheckBoxIndicator, ..., SE_ToolBarHandle } |
enum | WidgetSizePolicy { SizeSmall, SizeLarge, SizeMini, SizeDefault } |
Public Functions
| QMacStyle() |
| QStyle() |
virtual | ~QMacStyle() |
virtual | ~QStyle() |
int | combinedLayoutSpacing(QSizePolicy::ControlTypes controls1, QSizePolicy::ControlTypes controls2, Qt::Orientation orientation, QStyleOption * option = 0, QWidget * widget = 0) const |
virtual void | drawComplexControl(ComplexControl control, const QStyleOptionComplex * option, QPainter * painter, const QWidget * widget = 0) const = 0 |
virtual void | drawControl(ControlElement element, const QStyleOption * option, QPainter * painter, const QWidget * widget = 0) const = 0 |
virtual void | drawItemPixmap(QPainter * painter, const QRect & rectangle, int alignment, const QPixmap & pixmap) const |
virtual void | drawItemText(QPainter * painter, const QRect & rectangle, int alignment, const QPalette & palette, bool enabled, const QString & text, QPalette::ColorRole textRole = QPalette::NoRole) const |
virtual void | drawPrimitive(PrimitiveElement element, const QStyleOption * option, QPainter * painter, const QWidget * widget = 0) const = 0 |
virtual QPixmap | generatedIconPixmap(QIcon::Mode iconMode, const QPixmap & pixmap, const QStyleOption * option) const = 0 |
virtual SubControl | hitTestComplexControl(ComplexControl control, const QStyleOptionComplex * option, const QPoint & position, const QWidget * widget = 0) const = 0 |
virtual QRect | itemPixmapRect(const QRect & rectangle, int alignment, const QPixmap & pixmap) const |
virtual QRect | itemTextRect(const QFontMetrics & metrics, const QRect & rectangle, int alignment, bool enabled, const QString & text) const |
int | layoutSpacing(QSizePolicy::ControlType control1, QSizePolicy::ControlType control2, Qt::Orientation orientation, const QStyleOption * option = 0, const QWidget * widget = 0) const |
virtual int | pixelMetric(PixelMetric metric, const QStyleOption * option = 0, const QWidget * widget = 0) const = 0 |
virtual void | polish(QWidget * widget) |
virtual void | polish(QApplication * application) |
virtual void | polish(QPalette & palette) |
const QStyle * | proxy() const |
virtual QSize | sizeFromContents(ContentsType type, const QStyleOption * option, const QSize & contentsSize, const QWidget * widget = 0) const = 0 |
QIcon | standardIcon(StandardPixmap standardIcon, const QStyleOption * option = 0, const QWidget * widget = 0) const |
virtual QPalette | standardPalette() const |
virtual int | styleHint(StyleHint hint, const QStyleOption * option = 0, const QWidget * widget = 0, QStyleHintReturn * returnData = 0) const = 0 |
virtual QRect | subControlRect(ComplexControl control, const QStyleOptionComplex * option, SubControl subControl, const QWidget * widget = 0) const = 0 |
virtual QRect | subElementRect(SubElement element, const QStyleOption * option, const QWidget * widget = 0) const = 0 |
virtual void | unpolish(QWidget * widget) |
virtual void | unpolish(QApplication * application) |
Reimplemented Public Functions
virtual void | drawComplexControl(ComplexControl cc, const QStyleOptionComplex * opt, QPainter * p, const QWidget * widget = 0) const |
virtual void | drawControl(ControlElement ce, const QStyleOption * opt, QPainter * p, const QWidget * w = 0) const |
virtual void | drawItemText(QPainter * p, const QRect & r, int flags, const QPalette & pal, bool enabled, const QString & text, QPalette::ColorRole textRole = QPalette::NoRole) const |
virtual void | drawPrimitive(PrimitiveElement pe, const QStyleOption * opt, QPainter * p, const QWidget * w = 0) const |
virtual bool | event(QEvent * e) |
virtual QPixmap | generatedIconPixmap(QIcon::Mode iconMode, const QPixmap & pixmap, const QStyleOption * opt) const |
virtual SubControl | hitTestComplexControl(ComplexControl cc, const QStyleOptionComplex * opt, const QPoint & pt, const QWidget * widget = 0) const |
virtual int | pixelMetric(PixelMetric metric, const QStyleOption * opt = 0, const QWidget * widget = 0) const |
virtual void | polish(QWidget * w) |
virtual void | polish(QApplication *) |
virtual void | polish(QPalette & pal) |
virtual QSize | sizeFromContents(ContentsType ct, const QStyleOption * opt, const QSize & csz, const QWidget * widget = 0) const |
virtual QPalette | standardPalette() const |
virtual QPixmap | standardPixmap(StandardPixmap standardPixmap, const QStyleOption * opt, const QWidget * widget = 0) const |
virtual int | styleHint(StyleHint sh, const QStyleOption * opt = 0, const QWidget * w = 0, QStyleHintReturn * hret = 0) const |
virtual QRect | subControlRect(ComplexControl cc, const QStyleOptionComplex * opt, SubControl sc, const QWidget * widget = 0) const |
virtual QRect | subElementRect(SubElement sr, const QStyleOption * opt, const QWidget * widget = 0) const |
virtual void | unpolish(QWidget * w) |
virtual void | unpolish(QApplication *) |
Static Public Members
QRect | alignedRect(Qt::LayoutDirection direction, Qt::Alignment alignment, const QSize & size, const QRect & rectangle) |
int | sliderPositionFromValue(int min, int max, int logicalValue, int span, bool upsideDown = false) |
int | sliderValueFromPosition(int min, int max, int position, int span, bool upsideDown = false) |
Qt::Alignment | visualAlignment(Qt::LayoutDirection direction, Qt::Alignment alignment) |
QPoint | visualPos(Qt::LayoutDirection direction, const QRect & boundingRectangle, const QPoint & logicalPosition) |
QRect | visualRect(Qt::LayoutDirection direction, const QRect & boundingRectangle, const QRect & logicalRectangle) |
- 11 static public members inherited from QObject
Protected Slots
int | layoutSpacingImplementation(QSizePolicy::ControlType control1, QSizePolicy::ControlType control2, Qt::Orientation orientation, const QStyleOption * option = 0, const QWidget * widget = 0) const |
QIcon | standardIconImplementation(StandardPixmap standardIcon, const QStyleOption * option = 0, const QWidget * widget = 0) const |
Additional Inherited Members
Detailed Description
The QMacStyle class provides a Mac OS X style using the Apple Appearance Manager.
This class is implemented as a wrapper to the HITheme APIs, allowing applications to be styled according to the current theme in use on Mac OS X. This is done by having primitives in QStyle implemented in terms of what Mac OS X would normally theme.
Warning: This style is only available on Mac OS X because it relies on the HITheme APIs.
There are additional issues that should be taken into consideration to make an application compatible with the Apple Human Interface Guidelines. Some of these issues are outlined below.
- Layout - The restrictions on window layout are such that some aspects of layout that are style-dependent cannot be achieved using QLayout. Changes are being considered (and feedback would be appreciated) to make layouts QStyle-able. Some of the restrictions involve horizontal and vertical widget alignment and widget size (covered below).
- Widget size - Mac OS X allows widgets to have specific fixed sizes. Qt does not fully implement this behavior so as to maintain cross-platform compatibility. As a result some widgets sizes may be inappropriate (and subsequently not rendered correctly by the HITheme APIs).The QWidget::sizeHint() will return the appropriate size for many managed widgets (widgets enumerated in QStyle::ContentsType).
- Effects - QMacStyle uses HITheme for performing most of the drawing, but also uses emulation in a few cases where HITheme does not provide the required functionality (for example, tab bars on Panther, the toolbar separator, etc). We tried to make the emulation as close to the original as possible. Please report any issues you see in effects or non-standard widgets.
There are other issues that need to be considered in the feel of your application (including the general color scheme to match the Aqua colors). The Guidelines mentioned above will remain current with new advances and design suggestions for Mac OS X.
Note that the functions provided by QMacStyle are reimplementations of QStyle functions; see QStyle for their documentation.
See also QWindowsXPStyle, QWindowsStyle, QPlastiqueStyle, QCDEStyle, and QMotifStyle.
Member Type Documentation
enum QMacStyle::FocusRectPolicy
This type is used to signify a widget's focus rectangle policy.
Constant | Value | Description |
QMacStyle::FocusEnabled | 0 | show a focus rectangle when the widget has focus. |
QMacStyle::FocusDisabled | 1 | never show a focus rectangle for the widget. |
QMacStyle::FocusDefault | 2 | show a focus rectangle when the widget has focus and the widget is a QSpinWidget, QDateTimeEdit, QLineEdit, QListBox, QListView, editable QTextEdit, or one of their subclasses. |
enum QMacStyle::WidgetSizePolicy
Constant | Value |
QMacStyle::SizeSmall | 0 |
QMacStyle::SizeLarge | 1 |
QMacStyle::SizeMini | 2 |
QMacStyle::SizeDefault | 3 |
Member Function Documentation
QMacStyle::QMacStyle()
Constructs a QMacStyle object.
QMacStyle::~QMacStyle() [virtual]
Destructs a QMacStyle object.
Reimplemented from QStyle::drawComplexControl().
void QMacStyle::drawControl(ControlElement ce, const QStyleOption * opt, QPainter * p, const QWidget * w = 0) const [virtual]
Reimplemented from QStyle::drawControl().
void QMacStyle::drawItemText(QPainter * p, const QRect & r, int flags, const QPalette & pal, bool enabled, const QString & text, QPalette::ColorRole textRole = QPalette::NoRole) const [virtual]
Reimplemented from QStyle::drawItemText().
Reimplemented from QStyle::drawPrimitive().
bool QMacStyle::event(QEvent * e) [virtual]
Reimplemented from QObject::event().
QPixmap QMacStyle::generatedIconPixmap(QIcon::Mode iconMode, const QPixmap & pixmap, const QStyleOption * opt) const [virtual]
Reimplemented from QStyle::generatedIconPixmap().
Reimplemented from QStyle::hitTestComplexControl().
int QMacStyle::pixelMetric(PixelMetric metric, const QStyleOption * opt = 0, const QWidget * widget = 0) const [virtual]
Reimplemented from QStyle::pixelMetric().
void QMacStyle::polish(QWidget * w) [virtual]
Reimplemented from QStyle::polish().
void QMacStyle::polish(QApplication *) [virtual]
Reimplemented from QStyle::polish().
void QMacStyle::polish(QPalette & pal) [virtual]
Reimplemented from QStyle::polish().
QSize QMacStyle::sizeFromContents(ContentsType ct, const QStyleOption * opt, const QSize & csz, const QWidget * widget = 0) const [virtual]
Reimplemented from QStyle::sizeFromContents().
QPalette QMacStyle::standardPalette() const [virtual]
Reimplemented from QStyle::standardPalette().
QPixmap QMacStyle::standardPixmap(StandardPixmap standardPixmap, const QStyleOption * opt, const QWidget * widget = 0) const [virtual]
Reimplemented from QStyle::standardPixmap().
int QMacStyle::styleHint(StyleHint sh, const QStyleOption * opt = 0, const QWidget * w = 0, QStyleHintReturn * hret = 0) const [virtual]
Reimplemented from QStyle::styleHint().
Reimplemented from QStyle::subControlRect().
QRect QMacStyle::subElementRect(SubElement sr, const QStyleOption * opt, const QWidget * widget = 0) const [virtual]
Reimplemented from QStyle::subElementRect().
void QMacStyle::unpolish(QWidget * w) [virtual]
Reimplemented from QStyle::unpolish().
void QMacStyle::unpolish(QApplication *) [virtual]
Reimplemented from QStyle::unpolish().
|