Fix misplacement of placeholder text in QLineEdit with RTL content

The placeholder text was rendered in the wrong position after clicking
on the clear button in a QLineEdit with right-to-left content. The
button was still taking up space while it was fading out, so the first
paintEvent rendered the placeholder with space reserved for the clear
button. Once the button gets hidden, no new update was issued, so
garbage was left behind.

Fix this by not giving a fading-out clear button any margin space. The
result of this is that the placeholder text is visible underneath the
fading-out clear button. This is preferable to the placeholder text
being first rendered next to the fading-out clear button, and then
popping to the edge when the clear button is hidden (which would have
been the result of issuing a complete update for the line edit at the
end of the fade-out animation).

Fixes: QTBUG-93742
Pick-to: 6.1 6.0 5.15
Done-with: Volker Hilsheimer <volker.hilsheimer@qt.io>
Change-Id: Id0429362a60bba6839aa02068b00edb15e3ab8ab
Reviewed-by: Volker Hilsheimer <volker.hilsheimer@qt.io>
This commit is contained in:
Fan RuiJie 2021-05-20 17:02:08 +08:00
parent 57bb7cac64
commit dc794f7622
2 changed files with 13 additions and 3 deletions

View File

@ -679,10 +679,18 @@ static int effectiveTextMargin(int defaultMargin, const QLineEditPrivate::SideWi
if (widgets.empty()) if (widgets.empty())
return defaultMargin; return defaultMargin;
return defaultMargin + (parameters.margin + parameters.widgetWidth) * const auto visibleSideWidgetCount = std::count_if(widgets.begin(), widgets.end(),
int(std::count_if(widgets.begin(), widgets.end(),
[](const QLineEditPrivate::SideWidgetEntry &e) { [](const QLineEditPrivate::SideWidgetEntry &e) {
return e.widget->isVisibleTo(e.widget->parentWidget()); })); #if QT_CONFIG(animation)
// a button that's fading out doesn't get any space
if (auto* iconButton = qobject_cast<QLineEditIconButton*>(e.widget))
return iconButton->needsSpace();
#endif
return e.widget->isVisibleTo(e.widget->parentWidget());
});
return defaultMargin + (parameters.margin + parameters.widgetWidth) * visibleSideWidgetCount;
} }
QMargins QLineEditPrivate::effectiveTextMargins() const QMargins QLineEditPrivate::effectiveTextMargins() const

View File

@ -95,6 +95,8 @@ public:
bool shouldHideWithText() const; bool shouldHideWithText() const;
void setHideWithText(bool hide); void setHideWithText(bool hide);
// m_wasHidden is true unless the button is fading out
bool needsSpace() const { return m_wasHidden; }
#endif #endif
protected: protected: