mirror of https://github.com/procxx/kepka.git
Qt render bug fixed by patch. Design improvements and fixes.
This commit is contained in:
parent
07689476a6
commit
d0f7c6c210
|
@ -12033,10 +12033,49 @@ index f610e46..547a646 100644
|
||||||
{
|
{
|
||||||
if (QPlatformFileDialogHelper *helper = platformFileDialogHelper())
|
if (QPlatformFileDialogHelper *helper = platformFileDialogHelper())
|
||||||
diff --git a/src/widgets/kernel/qwidget.cpp b/src/widgets/kernel/qwidget.cpp
|
diff --git a/src/widgets/kernel/qwidget.cpp b/src/widgets/kernel/qwidget.cpp
|
||||||
index b1d80d7..4133ed3 100644
|
index b1d80d7..42e32fd 100644
|
||||||
--- a/src/widgets/kernel/qwidget.cpp
|
--- a/src/widgets/kernel/qwidget.cpp
|
||||||
+++ b/src/widgets/kernel/qwidget.cpp
|
+++ b/src/widgets/kernel/qwidget.cpp
|
||||||
@@ -8769,7 +8769,8 @@ bool QWidget::event(QEvent *event)
|
@@ -5138,6 +5138,17 @@ void QWidget::render(QPainter *painter, const QPoint &targetOffset,
|
||||||
|
return; // Fully transparent.
|
||||||
|
|
||||||
|
Q_D(QWidget);
|
||||||
|
+
|
||||||
|
+ // Patch: save and restore dirtyOpaqueChildren field.
|
||||||
|
+ //
|
||||||
|
+ // Just like in QWidget::grab() this field should be restored
|
||||||
|
+ // after the d->render() call, because it will be set to 1 and
|
||||||
|
+ // opaqueChildren field will be filled with empty region in
|
||||||
|
+ // case the widget is hidden (because all the opaque children
|
||||||
|
+ // will be skipped in isVisible() check).
|
||||||
|
+ //
|
||||||
|
+ const bool oldDirtyOpaqueChildren = d->dirtyOpaqueChildren;
|
||||||
|
+
|
||||||
|
const bool inRenderWithPainter = d->extra && d->extra->inRenderWithPainter;
|
||||||
|
const QRegion toBePainted = !inRenderWithPainter ? d->prepareToRender(sourceRegion, renderFlags)
|
||||||
|
: sourceRegion;
|
||||||
|
@@ -5159,6 +5170,10 @@ void QWidget::render(QPainter *painter, const QPoint &targetOffset,
|
||||||
|
if (!inRenderWithPainter && (opacity < 1.0 || (target->devType() == QInternal::Printer))) {
|
||||||
|
d->render_helper(painter, targetOffset, toBePainted, renderFlags);
|
||||||
|
d->extra->inRenderWithPainter = inRenderWithPainter;
|
||||||
|
+
|
||||||
|
+ // Patch: save and restore dirtyOpaqueChildren field.
|
||||||
|
+ d->dirtyOpaqueChildren = oldDirtyOpaqueChildren;
|
||||||
|
+
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -5190,6 +5205,9 @@ void QWidget::render(QPainter *painter, const QPoint &targetOffset,
|
||||||
|
d->setSharedPainter(oldPainter);
|
||||||
|
|
||||||
|
d->extra->inRenderWithPainter = inRenderWithPainter;
|
||||||
|
+
|
||||||
|
+ // Patch: save and restore dirtyOpaqueChildren field.
|
||||||
|
+ d->dirtyOpaqueChildren = oldDirtyOpaqueChildren;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void sendResizeEvents(QWidget *target)
|
||||||
|
@@ -8769,7 +8787,8 @@ bool QWidget::event(QEvent *event)
|
||||||
case QEvent::KeyPress: {
|
case QEvent::KeyPress: {
|
||||||
QKeyEvent *k = (QKeyEvent *)event;
|
QKeyEvent *k = (QKeyEvent *)event;
|
||||||
bool res = false;
|
bool res = false;
|
||||||
|
|
|
@ -78,6 +78,12 @@ boxBlockTitleClose: IconButton(defaultIconButton) {
|
||||||
|
|
||||||
icon: boxBlockTitleCloseIcon;
|
icon: boxBlockTitleCloseIcon;
|
||||||
iconOver: boxBlockTitleCloseIconOver;
|
iconOver: boxBlockTitleCloseIconOver;
|
||||||
|
|
||||||
|
rippleAreaPosition: point(4px, 4px);
|
||||||
|
rippleAreaSize: 40px;
|
||||||
|
ripple: RippleAnimation(defaultRippleAnimation) {
|
||||||
|
color: windowBgOver;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
boxLinkButton: LinkButton {
|
boxLinkButton: LinkButton {
|
||||||
|
|
|
@ -539,10 +539,16 @@ void StickersBox::Inner::onImageLoaded() {
|
||||||
readVisibleSets();
|
readVisibleSets();
|
||||||
}
|
}
|
||||||
|
|
||||||
void StickersBox::Inner::paintButton(Painter &p, int y, bool selected, const QString &text, int badgeCounter) const {
|
void StickersBox::Inner::paintButton(Painter &p, int y, bool selected, std_::unique_ptr<Ui::RippleAnimation> &ripple, const QString &text, int badgeCounter) const {
|
||||||
if (selected) {
|
if (selected) {
|
||||||
p.fillRect(0, y, width(), _buttonHeight, st::contactsBgOver);
|
p.fillRect(0, y, width(), _buttonHeight, st::contactsBgOver);
|
||||||
}
|
}
|
||||||
|
if (ripple) {
|
||||||
|
ripple->paint(p, 0, y, width(), getms());
|
||||||
|
if (ripple->empty()) {
|
||||||
|
ripple.reset();
|
||||||
|
}
|
||||||
|
}
|
||||||
p.setFont(st::stickersFeaturedFont);
|
p.setFont(st::stickersFeaturedFont);
|
||||||
p.setPen(st::stickersFeaturedPen);
|
p.setPen(st::stickersFeaturedPen);
|
||||||
p.drawTextLeft(st::stickersFeaturedPosition.x(), y + st::stickersFeaturedPosition.y(), width(), text);
|
p.drawTextLeft(st::stickersFeaturedPosition.x(), y + st::stickersFeaturedPosition.y(), width(), text);
|
||||||
|
@ -571,12 +577,12 @@ void StickersBox::Inner::paintEvent(QPaintEvent *e) {
|
||||||
int y = st::membersPadding.top();
|
int y = st::membersPadding.top();
|
||||||
if (_hasFeaturedButton) {
|
if (_hasFeaturedButton) {
|
||||||
auto selected = (_selected == -2);
|
auto selected = (_selected == -2);
|
||||||
paintButton(p, y, selected, lang(lng_stickers_featured), Global::FeaturedStickerSetsUnreadCount());
|
paintButton(p, y, selected, _featuredRipple, lang(lng_stickers_featured), Global::FeaturedStickerSetsUnreadCount());
|
||||||
y += _buttonHeight;
|
y += _buttonHeight;
|
||||||
}
|
}
|
||||||
if (_hasArchivedButton) {
|
if (_hasArchivedButton) {
|
||||||
auto selected = (_selected == -1);
|
auto selected = (_selected == -1);
|
||||||
paintButton(p, y, selected, lang(lng_stickers_archived), 0);
|
paintButton(p, y, selected, _archivedRipple, lang(lng_stickers_archived), 0);
|
||||||
y += _buttonHeight;
|
y += _buttonHeight;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -709,7 +715,7 @@ void StickersBox::Inner::mousePressEvent(QMouseEvent *e) {
|
||||||
_mouse = e->globalPos();
|
_mouse = e->globalPos();
|
||||||
onUpdateSelected();
|
onUpdateSelected();
|
||||||
|
|
||||||
_pressed = _selected;
|
setPressed(_selected);
|
||||||
if (_actionSel >= 0) {
|
if (_actionSel >= 0) {
|
||||||
setActionDown(_actionSel);
|
setActionDown(_actionSel);
|
||||||
update(0, _itemsTop + _actionSel * _rowHeight, width(), _rowHeight);
|
update(0, _itemsTop + _actionSel * _rowHeight, width(), _rowHeight);
|
||||||
|
@ -867,9 +873,32 @@ float64 StickersBox::Inner::aboveShadowOpacity() const {
|
||||||
return qMin((dx + dy) * 2. / _rowHeight, 1.);
|
return qMin((dx + dy) * 2. / _rowHeight, 1.);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void StickersBox::Inner::setPressed(int newPressed) {
|
||||||
|
if (auto ripple = (_pressed == -1) ? &_archivedRipple : (_pressed == -2) ? &_featuredRipple : nullptr) {
|
||||||
|
if (*ripple) {
|
||||||
|
(*ripple)->lastStop();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
_pressed = newPressed;
|
||||||
|
if (auto ripple = (_pressed == -1) ? &_archivedRipple : (_pressed == -2) ? &_featuredRipple : nullptr) {
|
||||||
|
if (!*ripple) {
|
||||||
|
auto mask = Ui::RippleAnimation::rectMask(QSize(width(), _buttonHeight));
|
||||||
|
auto updateCallback = [this, index = _pressed] {
|
||||||
|
auto y = st::membersPadding.top();
|
||||||
|
if (index == -1 && _hasFeaturedButton) {
|
||||||
|
y += _buttonHeight;
|
||||||
|
}
|
||||||
|
update(0, y, width(), _buttonHeight);
|
||||||
|
};
|
||||||
|
*ripple = std_::make_unique<Ui::RippleAnimation>(st::defaultRippleAnimation, std_::move(mask), std_::move(updateCallback));
|
||||||
|
}
|
||||||
|
(*ripple)->add(mapFromGlobal(QCursor::pos()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void StickersBox::Inner::mouseReleaseEvent(QMouseEvent *e) {
|
void StickersBox::Inner::mouseReleaseEvent(QMouseEvent *e) {
|
||||||
auto pressed = _pressed;
|
auto pressed = _pressed;
|
||||||
_pressed = -2;
|
setPressed(-3);
|
||||||
|
|
||||||
if (_section != Section::Installed && _selected < 0 && pressed >= 0) {
|
if (_section != Section::Installed && _selected < 0 && pressed >= 0) {
|
||||||
setCursor(style::cur_default);
|
setCursor(style::cur_default);
|
||||||
|
|
|
@ -152,9 +152,10 @@ private slots:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void setActionDown(int newActionDown);
|
void setActionDown(int newActionDown);
|
||||||
|
void setPressed(int newPressed);
|
||||||
void setup();
|
void setup();
|
||||||
QRect relativeAddButtonRect() const;
|
QRect relativeAddButtonRect() const;
|
||||||
void paintButton(Painter &p, int y, bool selected, const QString &text, int badgeCounter) const;
|
void paintButton(Painter &p, int y, bool selected, std_::unique_ptr<Ui::RippleAnimation> &ripple, const QString &text, int badgeCounter) const;
|
||||||
|
|
||||||
void step_shifting(uint64 ms, bool timer);
|
void step_shifting(uint64 ms, bool timer);
|
||||||
void paintRow(Painter &p, int32 index, uint64 ms);
|
void paintRow(Painter &p, int32 index, uint64 ms);
|
||||||
|
@ -238,6 +239,9 @@ private:
|
||||||
int _dragging = -1;
|
int _dragging = -1;
|
||||||
int _above = -1;
|
int _above = -1;
|
||||||
|
|
||||||
|
std_::unique_ptr<Ui::RippleAnimation> _archivedRipple;
|
||||||
|
std_::unique_ptr<Ui::RippleAnimation> _featuredRipple;
|
||||||
|
|
||||||
Ui::RectShadow _aboveShadow;
|
Ui::RectShadow _aboveShadow;
|
||||||
|
|
||||||
int _scrollbar = 0;
|
int _scrollbar = 0;
|
||||||
|
|
|
@ -1122,7 +1122,7 @@ void DialogsInner::setMouseSel(bool msel, bool toTop) {
|
||||||
_selByMouse = msel;
|
_selByMouse = msel;
|
||||||
if (!_selByMouse && toTop) {
|
if (!_selByMouse && toTop) {
|
||||||
if (_state == DefaultState) {
|
if (_state == DefaultState) {
|
||||||
_sel = !shownDialogs()->isEmpty() ? *shownDialogs()->cbegin() : nullptr;
|
_sel = nullptr;
|
||||||
_importantSwitchSel = false;
|
_importantSwitchSel = false;
|
||||||
} else if (_state == FilteredState || _state == SearchedState) { // don't select first elem in search
|
} else if (_state == FilteredState || _state == SearchedState) { // don't select first elem in search
|
||||||
_filteredSel = _peopleSel = _searchedSel = _hashtagSel = -1;
|
_filteredSel = _peopleSel = _searchedSel = _hashtagSel = -1;
|
||||||
|
@ -2376,21 +2376,22 @@ void DialogsWidget::updateLockUnlockVisibility() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void DialogsWidget::updateControlsGeometry() {
|
void DialogsWidget::updateControlsGeometry() {
|
||||||
auto filterTop = 0;
|
auto filterAreaTop = 0;
|
||||||
if (_forwardCancel) {
|
if (_forwardCancel) {
|
||||||
_forwardCancel->moveToLeft(0, filterTop);
|
_forwardCancel->moveToLeft(0, filterAreaTop);
|
||||||
filterTop += st::dialogsForwardHeight;
|
filterAreaTop += st::dialogsForwardHeight;
|
||||||
}
|
}
|
||||||
auto filterLeft = st::dialogsFilterPadding.x() + _mainMenuToggle->width() + st::dialogsFilterPadding.x();
|
auto filterLeft = st::dialogsFilterPadding.x() + _mainMenuToggle->width() + st::dialogsFilterPadding.x();
|
||||||
auto filterRight = (Global::LocalPasscode() ? (st::dialogsFilterPadding.x() + _lockUnlock->width()) : st::dialogsFilterSkip) + st::dialogsFilterPadding.x();
|
auto filterRight = (Global::LocalPasscode() ? (st::dialogsFilterPadding.x() + _lockUnlock->width()) : st::dialogsFilterSkip) + st::dialogsFilterPadding.x();
|
||||||
auto filterWidth = width() - filterLeft - filterRight;
|
auto filterWidth = width() - filterLeft - filterRight;
|
||||||
auto scrollTop = st::dialogsFilterPadding.y() + _mainMenuToggle->height() + st::dialogsFilterPadding.y();
|
auto filterAreaHeight = st::dialogsFilterPadding.y() + _mainMenuToggle->height() + st::dialogsFilterPadding.y();
|
||||||
filterTop += (scrollTop - _filter->height()) / 2;
|
auto filterTop = filterAreaTop + (filterAreaHeight - _filter->height()) / 2;
|
||||||
_filter->setGeometryToLeft(filterLeft, filterTop, filterWidth, _filter->height());
|
_filter->setGeometryToLeft(filterLeft, filterTop, filterWidth, _filter->height());
|
||||||
_mainMenuToggle->moveToLeft(st::dialogsFilterPadding.x(), st::dialogsFilterPadding.y());
|
_mainMenuToggle->moveToLeft(st::dialogsFilterPadding.x(), filterAreaTop + st::dialogsFilterPadding.y());
|
||||||
_lockUnlock->moveToRight(st::dialogsFilterPadding.x(), st::dialogsFilterPadding.y());
|
_lockUnlock->moveToRight(st::dialogsFilterPadding.x(), filterAreaTop + st::dialogsFilterPadding.y());
|
||||||
_cancelSearch->moveToLeft(filterLeft + filterWidth - _cancelSearch->width(), _filter->y());
|
_cancelSearch->moveToLeft(filterLeft + filterWidth - _cancelSearch->width(), _filter->y());
|
||||||
|
|
||||||
|
auto scrollTop = filterAreaTop + filterAreaHeight;
|
||||||
auto addToScroll = App::main() ? App::main()->contentScrollAddToY() : 0;
|
auto addToScroll = App::main() ? App::main()->contentScrollAddToY() : 0;
|
||||||
auto newScrollTop = _scroll->scrollTop() + addToScroll;
|
auto newScrollTop = _scroll->scrollTop() + addToScroll;
|
||||||
auto scrollHeight = height() - scrollTop;
|
auto scrollHeight = height() - scrollTop;
|
||||||
|
|
|
@ -298,7 +298,7 @@ void LayerStackWidget::startAnimation(float64 toOpacity) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool LayerStackWidget::canSetFocus() const {
|
bool LayerStackWidget::canSetFocus() const {
|
||||||
return (layer() || _specialLayer) && !_hiding;
|
return (layer() || _specialLayer || _mainMenu) && !_hiding;
|
||||||
}
|
}
|
||||||
|
|
||||||
void LayerStackWidget::setInnerFocus() {
|
void LayerStackWidget::setInnerFocus() {
|
||||||
|
@ -308,6 +308,8 @@ void LayerStackWidget::setInnerFocus() {
|
||||||
l->setInnerFocus();
|
l->setInnerFocus();
|
||||||
} else if (_specialLayer) {
|
} else if (_specialLayer) {
|
||||||
_specialLayer->setInnerFocus();
|
_specialLayer->setInnerFocus();
|
||||||
|
} else if (_mainMenu) {
|
||||||
|
_mainMenu->setInnerFocus();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -41,6 +41,8 @@ settingsFixedBarTextTop: 16px;
|
||||||
settingsFixedBarClose: IconButton(boxBlockTitleClose) {
|
settingsFixedBarClose: IconButton(boxBlockTitleClose) {
|
||||||
width: settingsFixedBarHeight;
|
width: settingsFixedBarHeight;
|
||||||
height: settingsFixedBarHeight;
|
height: settingsFixedBarHeight;
|
||||||
|
|
||||||
|
rippleAreaPosition: point(6px, 6px);
|
||||||
}
|
}
|
||||||
|
|
||||||
settingsMarginTop: 34px;
|
settingsMarginTop: 34px;
|
||||||
|
|
|
@ -2922,6 +2922,7 @@ EmojiPan::EmojiPan(QWidget *parent) : TWidget(parent)
|
||||||
|
|
||||||
setMouseTracking(true);
|
setMouseTracking(true);
|
||||||
// setAttribute(Qt::WA_AcceptTouchEvents);
|
// setAttribute(Qt::WA_AcceptTouchEvents);
|
||||||
|
setAttribute(Qt::WA_OpaquePaintEvent, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmojiPan::setMaxHeight(int32 h) {
|
void EmojiPan::setMaxHeight(int32 h) {
|
||||||
|
@ -3199,7 +3200,7 @@ void EmojiPan::mouseMoveEvent(QMouseEvent *e) {
|
||||||
if (newX != _iconsX.current()) {
|
if (newX != _iconsX.current()) {
|
||||||
_iconsX = anim::ivalue(newX, newX);
|
_iconsX = anim::ivalue(newX, newX);
|
||||||
_iconsStartAnim = 0;
|
_iconsStartAnim = 0;
|
||||||
if (_iconAnimations.isEmpty()) _a_icons.stop();
|
_a_icons.stop();
|
||||||
updateIcons();
|
updateIcons();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3217,7 +3218,7 @@ void EmojiPan::mouseReleaseEvent(QMouseEvent *e) {
|
||||||
if (newX != _iconsX.current()) {
|
if (newX != _iconsX.current()) {
|
||||||
_iconsX = anim::ivalue(newX, newX);
|
_iconsX = anim::ivalue(newX, newX);
|
||||||
_iconsStartAnim = 0;
|
_iconsStartAnim = 0;
|
||||||
if (_iconAnimations.isEmpty()) _a_icons.stop();
|
_a_icons.stop();
|
||||||
updateIcons();
|
updateIcons();
|
||||||
}
|
}
|
||||||
_iconsDragging = false;
|
_iconsDragging = false;
|
||||||
|
@ -3250,7 +3251,7 @@ bool EmojiPan::event(QEvent *e) {
|
||||||
if (newX != _iconsX.current()) {
|
if (newX != _iconsX.current()) {
|
||||||
_iconsX = anim::ivalue(newX, newX);
|
_iconsX = anim::ivalue(newX, newX);
|
||||||
_iconsStartAnim = 0;
|
_iconsStartAnim = 0;
|
||||||
if (_iconAnimations.isEmpty()) _a_icons.stop();
|
_a_icons.stop();
|
||||||
updateSelected();
|
updateSelected();
|
||||||
updateIcons();
|
updateIcons();
|
||||||
}
|
}
|
||||||
|
@ -3287,8 +3288,6 @@ void EmojiPan::refreshSavedGifs() {
|
||||||
|
|
||||||
void EmojiPan::onRefreshIcons(bool scrollAnimation) {
|
void EmojiPan::onRefreshIcons(bool scrollAnimation) {
|
||||||
_iconOver = -1;
|
_iconOver = -1;
|
||||||
_iconHovers.clear();
|
|
||||||
_iconAnimations.clear();
|
|
||||||
s_inner->fillIcons(_icons);
|
s_inner->fillIcons(_icons);
|
||||||
s_inner->fillPanels(s_panels);
|
s_inner->fillPanels(s_panels);
|
||||||
_iconsX.finish();
|
_iconsX.finish();
|
||||||
|
@ -3298,7 +3297,6 @@ void EmojiPan::onRefreshIcons(bool scrollAnimation) {
|
||||||
if (_icons.isEmpty()) {
|
if (_icons.isEmpty()) {
|
||||||
_iconsMax = 0;
|
_iconsMax = 0;
|
||||||
} else {
|
} else {
|
||||||
_iconHovers = QVector<float64>(_icons.size(), 0);
|
|
||||||
_iconsMax = qMax(int((_icons.size() - 7) * st::emojiCategory.width), 0);
|
_iconsMax = qMax(int((_icons.size() - 7) * st::emojiCategory.width), 0);
|
||||||
}
|
}
|
||||||
if (_iconsX.current() > _iconsMax) {
|
if (_iconsX.current() > _iconsMax) {
|
||||||
|
@ -3352,30 +3350,14 @@ void EmojiPan::updateSelected() {
|
||||||
} else if (_iconOver < 0) {
|
} else if (_iconOver < 0) {
|
||||||
setCursor(style::cur_pointer);
|
setCursor(style::cur_pointer);
|
||||||
}
|
}
|
||||||
bool startanim = false;
|
|
||||||
if (_iconOver >= 0 && _iconOver < _icons.size()) {
|
|
||||||
_iconAnimations.remove(_iconOver + 1);
|
|
||||||
if (_iconAnimations.find(-_iconOver - 1) == _iconAnimations.end()) {
|
|
||||||
if (_iconAnimations.isEmpty() && !_iconsStartAnim) startanim = true;
|
|
||||||
_iconAnimations.insert(-_iconOver - 1, getms());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
_iconOver = newOver;
|
_iconOver = newOver;
|
||||||
if (_iconOver >= 0 && _iconOver < _icons.size()) {
|
|
||||||
_iconAnimations.remove(-_iconOver - 1);
|
|
||||||
if (_iconAnimations.find(_iconOver + 1) == _iconAnimations.end()) {
|
|
||||||
if (_iconAnimations.isEmpty() && !_iconsStartAnim) startanim = true;
|
|
||||||
_iconAnimations.insert(_iconOver + 1, getms());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (startanim && !_a_icons.animating()) _a_icons.start();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmojiPan::updateIcons() {
|
void EmojiPan::updateIcons() {
|
||||||
if (_emojiShown || !s_inner->showSectionIcons()) return;
|
if (_emojiShown || !s_inner->showSectionIcons()) return;
|
||||||
|
|
||||||
QRect r(st::defaultDropdownPadding.left(), st::defaultDropdownPadding.top(), _width - st::defaultDropdownPadding.left() - st::defaultDropdownPadding.right(), _height - st::defaultDropdownPadding.top() - st::defaultDropdownPadding.bottom());
|
QRect r(st::defaultDropdownPadding.left() + st::buttonRadius, st::defaultDropdownPadding.top(), _width - st::defaultDropdownPadding.left() - st::defaultDropdownPadding.right() - 2 * st::buttonRadius, _height - st::defaultDropdownPadding.top() - st::defaultDropdownPadding.bottom());
|
||||||
update(r.left(), _iconsTop, r.width(), st::emojiCategory.height);
|
update(r.left(), _iconsTop, r.width(), st::emojiCategory.height);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3385,20 +3367,6 @@ void EmojiPan::step_icons(uint64 ms, bool timer) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (Animations::iterator i = _iconAnimations.begin(); i != _iconAnimations.end();) {
|
|
||||||
int index = qAbs(i.key()) - 1;
|
|
||||||
float64 dt = float64(ms - i.value()) / st::emojiPanDuration;
|
|
||||||
if (index >= _iconHovers.size()) {
|
|
||||||
i = _iconAnimations.erase(i);
|
|
||||||
} else if (dt >= 1) {
|
|
||||||
_iconHovers[index] = (i.key() > 0) ? 1 : 0;
|
|
||||||
i = _iconAnimations.erase(i);
|
|
||||||
} else {
|
|
||||||
_iconHovers[index] = (i.key() > 0) ? dt : (1 - dt);
|
|
||||||
++i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_iconsStartAnim) {
|
if (_iconsStartAnim) {
|
||||||
float64 dt = (ms - _iconsStartAnim) / float64(st::stickerIconMove);
|
float64 dt = (ms - _iconsStartAnim) / float64(st::stickerIconMove);
|
||||||
if (dt >= 1) {
|
if (dt >= 1) {
|
||||||
|
@ -3414,7 +3382,7 @@ void EmojiPan::step_icons(uint64 ms, bool timer) {
|
||||||
|
|
||||||
if (timer) updateIcons();
|
if (timer) updateIcons();
|
||||||
|
|
||||||
if (_iconAnimations.isEmpty() && !_iconsStartAnim) {
|
if (!_iconsStartAnim) {
|
||||||
_a_icons.stop();
|
_a_icons.stop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3527,8 +3495,6 @@ void EmojiPan::hideFinished() {
|
||||||
_iconSelX = anim::ivalue(0, 0);
|
_iconSelX = anim::ivalue(0, 0);
|
||||||
_iconsStartAnim = 0;
|
_iconsStartAnim = 0;
|
||||||
_a_icons.stop();
|
_a_icons.stop();
|
||||||
_iconHovers = _icons.isEmpty() ? QVector<float64>() : QVector<float64>(_icons.size(), 0);
|
|
||||||
_iconAnimations.clear();
|
|
||||||
|
|
||||||
Notify::clipStopperHidden(ClipStopperSavedGifsPanel);
|
Notify::clipStopperHidden(ClipStopperSavedGifsPanel);
|
||||||
}
|
}
|
||||||
|
@ -3837,8 +3803,6 @@ void EmojiPan::performSwitch() {
|
||||||
updateContentHeight();
|
updateContentHeight();
|
||||||
}
|
}
|
||||||
_iconOver = -1;
|
_iconOver = -1;
|
||||||
_iconHovers = _icons.isEmpty() ? QVector<float64>() : QVector<float64>(_icons.size(), 0);
|
|
||||||
_iconAnimations.clear();
|
|
||||||
_a_icons.stop();
|
_a_icons.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -527,9 +527,9 @@ public:
|
||||||
bool overlaps(const QRect &globalRect) {
|
bool overlaps(const QRect &globalRect) {
|
||||||
if (isHidden() || !_cache.isNull()) return false;
|
if (isHidden() || !_cache.isNull()) return false;
|
||||||
|
|
||||||
return QRect(st::defaultDropdownPadding.left(),
|
return QRect(st::defaultDropdownPadding.left() + st::buttonRadius,
|
||||||
st::defaultDropdownPadding.top(),
|
st::defaultDropdownPadding.top(),
|
||||||
_width - st::defaultDropdownPadding.left() - st::defaultDropdownPadding.right(),
|
_width - st::defaultDropdownPadding.left() - st::defaultDropdownPadding.right() - 2 * st::buttonRadius,
|
||||||
_height - st::defaultDropdownPadding.top() - st::defaultDropdownPadding.bottom()
|
_height - st::defaultDropdownPadding.top() - st::defaultDropdownPadding.bottom()
|
||||||
).contains(QRect(mapFromGlobal(globalRect.topLeft()), globalRect.size()));
|
).contains(QRect(mapFromGlobal(globalRect.topLeft()), globalRect.size()));
|
||||||
}
|
}
|
||||||
|
@ -666,13 +666,10 @@ private:
|
||||||
ChildWidget<Ui::IconButton> _symbols;
|
ChildWidget<Ui::IconButton> _symbols;
|
||||||
|
|
||||||
QList<internal::StickerIcon> _icons;
|
QList<internal::StickerIcon> _icons;
|
||||||
QVector<float64> _iconHovers;
|
|
||||||
int _iconOver = -1;
|
int _iconOver = -1;
|
||||||
int _iconSel = 0;
|
int _iconSel = 0;
|
||||||
int _iconDown = -1;
|
int _iconDown = -1;
|
||||||
bool _iconsDragging = false;
|
bool _iconsDragging = false;
|
||||||
typedef QMap<int32, uint64> Animations; // index - showing, -index - hiding
|
|
||||||
Animations _iconAnimations;
|
|
||||||
Animation _a_icons;
|
Animation _a_icons;
|
||||||
QPoint _iconsMousePos, _iconsMouseDown;
|
QPoint _iconsMousePos, _iconsMouseDown;
|
||||||
int _iconsLeft = 0;
|
int _iconsLeft = 0;
|
||||||
|
|
|
@ -112,7 +112,8 @@ void MainMenu::updateControlsGeometry() {
|
||||||
|
|
||||||
void MainMenu::paintEvent(QPaintEvent *e) {
|
void MainMenu::paintEvent(QPaintEvent *e) {
|
||||||
Painter p(this);
|
Painter p(this);
|
||||||
auto cover = QRect(0, 0, width(), st::mainMenuCoverHeight).intersected(e->rect());
|
auto clip = e->rect();
|
||||||
|
auto cover = QRect(0, 0, width(), st::mainMenuCoverHeight).intersected(clip);
|
||||||
if (!cover.isEmpty()) {
|
if (!cover.isEmpty()) {
|
||||||
p.fillRect(cover, st::mainMenuCoverBg);
|
p.fillRect(cover, st::mainMenuCoverBg);
|
||||||
p.setPen(st::mainMenuCoverFg);
|
p.setPen(st::mainMenuCoverFg);
|
||||||
|
@ -123,7 +124,7 @@ void MainMenu::paintEvent(QPaintEvent *e) {
|
||||||
p.drawTextLeft(st::mainMenuCoverTextLeft, st::mainMenuCoverStatusTop, width(), qsl("online"));
|
p.drawTextLeft(st::mainMenuCoverTextLeft, st::mainMenuCoverStatusTop, width(), qsl("online"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
auto other = QRect(0, st::mainMenuCoverHeight, width(), height() - st::mainMenuCoverHeight);
|
auto other = QRect(0, st::mainMenuCoverHeight, width(), height() - st::mainMenuCoverHeight).intersected(clip);
|
||||||
if (!other.isEmpty()) {
|
if (!other.isEmpty()) {
|
||||||
p.fillRect(other, st::mainMenuBg);
|
p.fillRect(other, st::mainMenuBg);
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,6 +37,9 @@ class MainMenu : public TWidget, private base::Subscriber {
|
||||||
public:
|
public:
|
||||||
MainMenu(QWidget *parent);
|
MainMenu(QWidget *parent);
|
||||||
|
|
||||||
|
void setInnerFocus() {
|
||||||
|
setFocus();
|
||||||
|
}
|
||||||
void showFinished();
|
void showFinished();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
Loading…
Reference in New Issue