rsc3/doc-schelp/HelpSource/Classes/QPalette.schelp

102 lines
4.5 KiB
Text

class:: QPalette
summary:: Set of colors used by the GUI
categories:: GUI>Accessories
Description::
QPalette is a strong::set of colors:: that the GUI system uses to draw the views. The colors are organized into three strong::color groups:: (active, inactive and disabled) used according to the state of the views drawn, and each group containing one color assigned to each of the various strong::color roles:: (window, windowText, button, buttonText, etc.), used to draw distinct elements of the views. See link::Reference/palette_color_roles:: and link::Reference/palette_color_groups:: for details.
A palette can be assigned to the whole GUI using link::Classes/QtGUI#*palette::, or to a particular view using link::Classes/View#-palette::. Views will inherit a palette from their parent, and ultimately QtGUI, unless a palette is explicitly assigned to them. Moreover, when setting a palette on a view, it will be combined with the inherited one, overriding only those colors that have been explicitly set on the palette (see link::#-hasColor::). Hence, assigning a new and unmodified palette will reset all the colors to the inherited ones.
There are also two predefined palettes accessible using link::#*light:: and link::#*dark::. The light palette is assigned to QtGUI by default on startup. Should you wish to use a palette that matches the color scheme used natively on your platform, you can access such palette using link::#*system::.
If you wish to design your own palette, it is most convenient to use link::#*auto::, which will automatically derive a palette from only two colors, and then modify the details as you see fit.
Note that in Qt GUI most color-related methods of views (like link::Classes/Window#-background::, link::Classes/Slider#-knobColor::, etc.) actually modify the view's palette.
CLASSMETHODS::
METHOD:: new
Instantiates a new palette, equivalent to the global palette assigned to QtGUI. All colors are considered to not be set (see link::#-hasColor::).
METHOD:: auto
Instantiates a new palette, with colors automatically derived from the given colors for 'button' and 'window' color roles. All colors are considered to be set (see link::#-hasColor::).
argument:: buttonColor
The Color assigned to the button role.
argument:: windowColor
The Color assigned to the window role.
METHOD:: light
A predefined palette using light colors. All colors are considered to be set (see link::#-hasColor::).
METHOD:: dark
A predefined palette using dark colors. All colors are considered to be set (see link::#-hasColor::).
METHOD:: system
The native system palette. All colors are considered to be set (see link::#-hasColor::).
INSTANCEMETHODS::
PRIVATE:: prInit
PRIVATE:: prAuto
PRIVATE:: prSystem
PRIVATE:: prColor
PRIVATE:: prSetColor
PRIVATE:: prHasColor
METHOD:: color
Returns the color assigned to a color role within a color group.
argument:: role
A symbol among link::Reference/palette_color_roles::.
argument:: group
A symbol among link::Reference/palette_color_groups::, or nil, in which case the current color group is used.
METHOD:: setColor
Assigns a color to a color role within a color group.
argument:: color
A Color.
argument:: role
A symbol among link::Reference/palette_color_roles::.
argument:: group
A symbol among link::Reference/palette_color_groups::, or nil, in which case the color will be assigned to all groups.
METHOD:: hasColor
Whether the color belonging to a color role and group has been set on this QPalette instance.
When setting a palette on a view, only colors for which this methods returns true will be changed, others will be inherited from the parent view (or QtGUI if this view has no parent).
argument:: role
A symbol among link::Reference/palette_color_roles::.
argument:: group
A symbol among link::Reference/palette_color_groups::.
METHOD:: window
Convenience method to get or set the color for the 'window' role.
METHOD:: windowText
Convenience method to get or set the color for the 'windowText' role.
METHOD:: button
Convenience method to get or set the color for the 'button' role.
METHOD:: buttonText
Convenience method to get or set the color for the 'buttonText' role.
METHOD:: base
Convenience method to get or set the color for the 'base' role.
METHOD:: baseText
Convenience method to get or set the color for the 'baseText' role.
METHOD:: highlight
Convenience method to get or set the color for the 'highlight' role.
METHOD:: highlightText
Convenience method to get or set the color for the 'highlightText' role.