QStyleOptionMenuItem Class

The QStyleOptionMenuItem class is used to describe the parameter necessary for drawing a menu item. More...

Header: #include <QStyleOptionMenuItem>
CMake: find_package(Qt6 COMPONENTS Widgets REQUIRED)
target_link_libraries(mytarget PRIVATE Qt6::Widgets)
qmake: QT += widgets
Inherits: QStyleOption

Public Types

enum CheckType { NotCheckable, Exclusive, NonExclusive }
enum MenuItemType { Normal, DefaultItem, Separator, SubMenu, Scroller, …, EmptyArea }
enum StyleOptionType { Type }
enum StyleOptionVersion { Version }

Public Functions

QStyleOptionMenuItem(const QStyleOptionMenuItem &other)
QStyleOptionMenuItem()

Public Variables

QStyleOptionMenuItem::CheckType checkType
bool checked
QFont font
QIcon icon
int maxIconWidth
bool menuHasCheckableItems
QStyleOptionMenuItem::MenuItemType menuItemType
QRect menuRect
int reservedShortcutWidth
QString text

Detailed Description

QStyleOptionMenuItem contains all the information that QStyle functions need to draw the menu items from QMenu. It is also used for drawing other menu-related widgets.

For performance reasons, there are few member functions and the access to the member variables is direct (i.e., using the . or -> operator). This makes the structures straightforward to use and emphasizes that these are simply parameters used by the style functions.

For an example demonstrating how style options can be used, see the Styles example.

See also QStyleOption.

Member Type Documentation

enum QStyleOptionMenuItem::CheckType

This enum is used to indicate whether or not a check mark should be drawn for the item, or even if it should be drawn at all.

ConstantValueDescription
QStyleOptionMenuItem::NotCheckable0The item is not checkable.
QStyleOptionMenuItem::Exclusive1The item is an exclusive check item (like a radio button).
QStyleOptionMenuItem::NonExclusive2The item is a non-exclusive check item (like a check box).

See also checkType, QAction::checkable, QAction::checked, and QActionGroup::exclusionPolicy.

This enum indicates the type of menu item that the structure describes.

ConstantValueDescription
QStyleOptionMenuItem::Normal0A normal menu item.
QStyleOptionMenuItem::DefaultItem1A menu item that is the default action as specified with QMenu::defaultAction().
QStyleOptionMenuItem::Separator2A menu separator.
QStyleOptionMenuItem::SubMenu3Indicates the menu item points to a sub-menu.
QStyleOptionMenuItem::Scroller4A popup menu scroller (currently only used on macOS).
QStyleOptionMenuItem::TearOff5A tear-off handle for the menu.
QStyleOptionMenuItem::Margin6The margin of the menu.
QStyleOptionMenuItem::EmptyArea7The empty area of the menu.

See also menuItemType.

enum QStyleOptionMenuItem::StyleOptionType

This enum is used to hold information about the type of the style option, and is defined for each QStyleOption subclass.

ConstantValueDescription
QStyleOptionMenuItem::TypeSO_MenuItemThe type of style option provided (SO_MenuItem for this class).

The type is used internally by QStyleOption, its subclasses, and qstyleoption_cast() to determine the type of style option. In general you do not need to worry about this unless you want to create your own QStyleOption subclass and your own styles.

See also StyleOptionVersion.

enum QStyleOptionMenuItem::StyleOptionVersion

This enum is used to hold information about the version of the style option, and is defined for each QStyleOption subclass.

ConstantValueDescription
QStyleOptionMenuItem::Version11

The version is used by QStyleOption subclasses to implement extensions without breaking compatibility. If you use qstyleoption_cast(), you normally do not need to check it.

See also StyleOptionType.

Member Function Documentation

QStyleOptionMenuItem::QStyleOptionMenuItem(const QStyleOptionMenuItem &other)

Constructs a copy of the other style option.

QStyleOptionMenuItem::QStyleOptionMenuItem()

Constructs a QStyleOptionMenuItem, initializing the members variables to their default values.

Member Variable Documentation

QStyleOptionMenuItem::CheckType QStyleOptionMenuItem::checkType

This variable holds the type of checkmark of the menu item

The default value is NotCheckable.

See also CheckType.

bool QStyleOptionMenuItem::checked

This variable holds whether the menu item is checked or not

The default value is false.

QFont QStyleOptionMenuItem::font

This variable holds the font used for the menu item text

This is the font that should be used for drawing the menu text minus the shortcut. The shortcut is usually drawn using the painter's font. By default, the application's default font is used.

QIcon QStyleOptionMenuItem::icon

This variable holds the icon for the menu item

The default value is an empty icon, i.e. an icon with neither a pixmap nor a filename.

int QStyleOptionMenuItem::maxIconWidth

This variable holds the maximum icon width for the icon in the menu item

This can be used for drawing the icon into the correct place or properly aligning items. The variable must be set regardless of whether or not the menu item has an icon. The default value is 0.

This variable holds whether the menu as a whole has checkable items or not

The default value is true.

If this option is set to false, then the menu has no checkable items. This makes it possible for GUI styles to save some horizontal space that would normally be used for the check column.

This variable holds the type of menu item

The default value is Normal.

See also MenuItemType.

This variable holds the rectangle for the entire menu

The default value is a null rectangle, i.e. a rectangle with both the width and the height set to 0.

int QStyleOptionMenuItem::reservedShortcutWidth

This variable holds the reserved width for the menu item's shortcut

QMenu sets it to the width occupied by the widest shortcut among all visible items within the menu.

The default value is 0.

QString QStyleOptionMenuItem::text

This variable holds the text for the menu item

Note that the text format is something like this "Menu text\tShortcut".

If the menu item doesn't have a shortcut, it will just contain the menu item's text. The default value is an empty string.