mirror of
https://github.com/crystalidea/qt-build-tools.git
synced 2025-01-23 04:14:37 +08:00
5.15.7 - better fix for QTBUG-98483
This commit is contained in:
parent
d42c07546d
commit
d3a3d28e3a
@ -3724,6 +3724,9 @@ void QMacStyle::drawControl(ControlElement ce, const QStyleOption *opt, QPainter
|
|||||||
|
|
||||||
const bool isEnabled = btn->state & State_Enabled;
|
const bool isEnabled = btn->state & State_Enabled;
|
||||||
const bool isPressed = btn->state & State_Sunken;
|
const bool isPressed = btn->state & State_Sunken;
|
||||||
|
const bool isDefault = (btn->features & QStyleOptionButton::DefaultButton)
|
||||||
|
|| (btn->features & QStyleOptionButton::AutoDefaultButton
|
||||||
|
&& d->autoDefaultButton == btn->styleObject);
|
||||||
const bool isHighlighted = isActive &&
|
const bool isHighlighted = isActive &&
|
||||||
((btn->state & State_On)
|
((btn->state & State_On)
|
||||||
|| (btn->features & QStyleOptionButton::DefaultButton)
|
|| (btn->features & QStyleOptionButton::DefaultButton)
|
||||||
@ -3743,6 +3746,32 @@ void QMacStyle::drawControl(ControlElement ce, const QStyleOption *opt, QPainter
|
|||||||
pb.enabled = isEnabled;
|
pb.enabled = isEnabled;
|
||||||
[pb highlight:isPressed];
|
[pb highlight:isPressed];
|
||||||
pb.state = isHighlighted && !isPressed ? NSOnState : NSOffState;
|
pb.state = isHighlighted && !isPressed ? NSOnState : NSOffState;
|
||||||
|
|
||||||
|
if (QOperatingSystemVersion::current() >= QOperatingSystemVersion::MacOSMonterey) {
|
||||||
|
// Starting from macOS Monterey buttons look/work slightly differently. First, the
|
||||||
|
// the default/autodefault buttons. Setting the state to ON is enough to make
|
||||||
|
// NSButtonPushOnPushOf type of buttons to use the accent color. To make it look
|
||||||
|
// recessed/pressed, we have to combine _both_ the state ON, and highlight:YES
|
||||||
|
// (previously, we were simply using highlight:YES and state OFF for such case).
|
||||||
|
// Non-default buttons work differently - they don't use accent color, but
|
||||||
|
// instead either darker or lighter bezel when pressed(depending on the theme),
|
||||||
|
// which is simply activated by highlight:YES (those buttons are not push on/push
|
||||||
|
// off type anymore, so seem to ignore the state).
|
||||||
|
|
||||||
|
// We only adust those:
|
||||||
|
if (ct == QMacStylePrivate::Button_PushButton) {
|
||||||
|
if (isDefault)
|
||||||
|
pb.state = isActive ? NSControlStateValueOn : NSControlStateValueOff;
|
||||||
|
else {
|
||||||
|
pb.buttonType = NSButtonTypeMomentaryPushIn;
|
||||||
|
if (btn->state & State_On)
|
||||||
|
[pb highlight:YES];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Note, for NSButtonTypeMomentaryPushIn we'll have to later adjust the text color
|
||||||
|
// accordingly, see CE_PushButtonLabel :(
|
||||||
|
}
|
||||||
|
|
||||||
d->drawNSViewInRect(pb, frameRect, p, ^(CGContextRef, const CGRect &r) {
|
d->drawNSViewInRect(pb, frameRect, p, ^(CGContextRef, const CGRect &r) {
|
||||||
[pb.cell drawBezelWithFrame:r inView:pb.superview];
|
[pb.cell drawBezelWithFrame:r inView:pb.superview];
|
||||||
});
|
});
|
||||||
@ -3787,15 +3816,23 @@ void QMacStyle::drawControl(ControlElement ce, const QStyleOption *opt, QPainter
|
|||||||
|
|
||||||
const auto ct = cocoaControlType(&btn, w);
|
const auto ct = cocoaControlType(&btn, w);
|
||||||
|
|
||||||
|
const bool isDefault = (btn.features & QStyleOptionButton::DefaultButton && !d->autoDefaultButton)
|
||||||
|
|| d->autoDefaultButton == btn.styleObject;
|
||||||
|
|
||||||
if (!hasMenu && ct != QMacStylePrivate::Button_SquareButton) {
|
if (!hasMenu && ct != QMacStylePrivate::Button_SquareButton) {
|
||||||
if (isPressed
|
if (isPressed || (isActive && isEnabled
|
||||||
|| (isActive && isEnabled
|
&& ((btn.state & State_On) || isDefault))) // Hello, LISP!
|
||||||
&& ((btn.state & State_On)
|
|
||||||
|| ((btn.features & QStyleOptionButton::DefaultButton) && !d->autoDefaultButton)
|
|
||||||
|| d->autoDefaultButton == btn.styleObject)))
|
|
||||||
btn.palette.setColor(QPalette::ButtonText, Qt::white);
|
btn.palette.setColor(QPalette::ButtonText, Qt::white);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!isDarkMode() && QOperatingSystemVersion::current() >= QOperatingSystemVersion::MacOSMonterey) {
|
||||||
|
if (!isDefault) {
|
||||||
|
// Yes, it's a gray button of type NSButtonTypeMomentaryPushIn (see CE_PushButtonBevel above),
|
||||||
|
// white text (if set in the previous statement) would be invisible.
|
||||||
|
btn.palette.setColor(QPalette::ButtonText, Qt::black);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ((!hasIcon && !hasMenu) || (hasIcon && !hasText)) {
|
if ((!hasIcon && !hasMenu) || (hasIcon && !hasText)) {
|
||||||
QCommonStyle::drawControl(ce, &btn, p, w);
|
QCommonStyle::drawControl(ce, &btn, p, w);
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user