mirror of https://github.com/procxx/kepka.git
				
				
				
			Rename some Ui methods.
myEnsureResized -> Ui::SendPendingMoveResizeEvents. myGrab -> Ui::GrabWidget. myGrabImage -> Ui::GrabWidgetToImage.
This commit is contained in:
		
							parent
							
								
									5f8143e6a4
								
							
						
					
					
						commit
						2569df9e5a
					
				|  | @ -169,7 +169,7 @@ QPixmap BoxContent::grabInnerCache() { | ||||||
| 	auto isBottomShadowVisible = !_bottomShadow->isHidden(); | 	auto isBottomShadowVisible = !_bottomShadow->isHidden(); | ||||||
| 	if (isTopShadowVisible) _topShadow->setVisible(false); | 	if (isTopShadowVisible) _topShadow->setVisible(false); | ||||||
| 	if (isBottomShadowVisible) _bottomShadow->setVisible(false); | 	if (isBottomShadowVisible) _bottomShadow->setVisible(false); | ||||||
| 	auto result = myGrab(this, _scroll->geometry()); | 	auto result = Ui::GrabWidget(this, _scroll->geometry()); | ||||||
| 	if (isTopShadowVisible) _topShadow->setVisible(true); | 	if (isTopShadowVisible) _topShadow->setVisible(true); | ||||||
| 	if (isBottomShadowVisible) _bottomShadow->setVisible(true); | 	if (isBottomShadowVisible) _bottomShadow->setVisible(true); | ||||||
| 	return result; | 	return result; | ||||||
|  |  | ||||||
|  | @ -104,7 +104,7 @@ void PeerListBox::prepare() { | ||||||
| 	setDimensions(st::boxWideWidth, st::boxMaxListHeight); | 	setDimensions(st::boxWideWidth, st::boxMaxListHeight); | ||||||
| 	if (_select) { | 	if (_select) { | ||||||
| 		_select->finishAnimating(); | 		_select->finishAnimating(); | ||||||
| 		myEnsureResized(_select); | 		Ui::SendPendingMoveResizeEvents(_select); | ||||||
| 		_scrollBottomFixed = true; | 		_scrollBottomFixed = true; | ||||||
| 		onScrollToY(0); | 		onScrollToY(0); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -52,7 +52,7 @@ ShareBox::ShareBox(QWidget*, CopyCallback &©Callback, SubmitCallback &&submi | ||||||
| 
 | 
 | ||||||
| void ShareBox::prepare() { | void ShareBox::prepare() { | ||||||
| 	_select->resizeToWidth(st::boxWideWidth); | 	_select->resizeToWidth(st::boxWideWidth); | ||||||
| 	myEnsureResized(_select); | 	Ui::SendPendingMoveResizeEvents(_select); | ||||||
| 
 | 
 | ||||||
| 	setTitle(langFactory(lng_share_title)); | 	setTitle(langFactory(lng_share_title)); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -388,10 +388,15 @@ void Panel::toggleOpacityAnimation(bool visible) { | ||||||
| 	if (_useTransparency) { | 	if (_useTransparency) { | ||||||
| 		if (_animationCache.isNull()) { | 		if (_animationCache.isNull()) { | ||||||
| 			showControls(); | 			showControls(); | ||||||
| 			_animationCache = myGrab(this); | 			_animationCache = Ui::GrabWidget(this); | ||||||
| 			hideChildren(); | 			hideChildren(); | ||||||
| 		} | 		} | ||||||
| 		_opacityAnimation.start([this] { update(); }, _visible ? 0. : 1., _visible ? 1. : 0., st::callPanelDuration, _visible ? anim::easeOutCirc : anim::easeInCirc); | 		_opacityAnimation.start( | ||||||
|  | 			[this] { update(); }, | ||||||
|  | 			_visible ? 0. : 1., | ||||||
|  | 			_visible ? 1. : 0., | ||||||
|  | 			st::callPanelDuration, | ||||||
|  | 			_visible ? anim::easeOutCirc : anim::easeInCirc); | ||||||
| 	} | 	} | ||||||
| 	if (isHidden() && _visible) { | 	if (isHidden() && _visible) { | ||||||
| 		show(); | 		show(); | ||||||
|  |  | ||||||
|  | @ -250,7 +250,7 @@ void EmojiColorPicker::hideFast() { | ||||||
| 
 | 
 | ||||||
| void EmojiColorPicker::hideAnimated() { | void EmojiColorPicker::hideAnimated() { | ||||||
| 	if (_cache.isNull()) { | 	if (_cache.isNull()) { | ||||||
| 		_cache = myGrab(this); | 		_cache = Ui::GrabWidget(this); | ||||||
| 		clearSelection(); | 		clearSelection(); | ||||||
| 	} | 	} | ||||||
| 	_hiding = true; | 	_hiding = true; | ||||||
|  | @ -265,7 +265,7 @@ void EmojiColorPicker::showAnimated() { | ||||||
| 	} | 	} | ||||||
| 	_hiding = false; | 	_hiding = false; | ||||||
| 	if (_cache.isNull()) { | 	if (_cache.isNull()) { | ||||||
| 		_cache = myGrab(this); | 		_cache = Ui::GrabWidget(this); | ||||||
| 		clearSelection(); | 		clearSelection(); | ||||||
| 	} | 	} | ||||||
| 	show(); | 	show(); | ||||||
|  |  | ||||||
|  | @ -408,7 +408,7 @@ void FieldAutocomplete::hideAnimated() { | ||||||
| 
 | 
 | ||||||
| 	if (_cache.isNull()) { | 	if (_cache.isNull()) { | ||||||
| 		_scroll->show(); | 		_scroll->show(); | ||||||
| 		_cache = myGrab(this); | 		_cache = Ui::GrabWidget(this); | ||||||
| 	} | 	} | ||||||
| 	_scroll->hide(); | 	_scroll->hide(); | ||||||
| 	_hiding = true; | 	_hiding = true; | ||||||
|  | @ -429,7 +429,7 @@ void FieldAutocomplete::showAnimated() { | ||||||
| 	} | 	} | ||||||
| 	if (_cache.isNull()) { | 	if (_cache.isNull()) { | ||||||
| 		_scroll->show(); | 		_scroll->show(); | ||||||
| 		_cache = myGrab(this); | 		_cache = Ui::GrabWidget(this); | ||||||
| 	} | 	} | ||||||
| 	_scroll->hide(); | 	_scroll->hide(); | ||||||
| 	_hiding = false; | 	_hiding = false; | ||||||
|  |  | ||||||
|  | @ -255,7 +255,7 @@ void TabbedPanel::prepareCache() { | ||||||
| 	auto showAnimation = base::take(_a_show); | 	auto showAnimation = base::take(_a_show); | ||||||
| 	auto showAnimationData = base::take(_showAnimation); | 	auto showAnimationData = base::take(_showAnimation); | ||||||
| 	showChildren(); | 	showChildren(); | ||||||
| 	_cache = myGrab(this); | 	_cache = Ui::GrabWidget(this); | ||||||
| 	_showAnimation = base::take(showAnimationData); | 	_showAnimation = base::take(showAnimationData); | ||||||
| 	_a_show = base::take(showAnimation); | 	_a_show = base::take(showAnimation); | ||||||
| 	if (_a_show.animating()) { | 	if (_a_show.animating()) { | ||||||
|  | @ -296,7 +296,7 @@ QImage TabbedPanel::grabForAnimation() { | ||||||
| 	auto showAnimation = base::take(_a_show); | 	auto showAnimation = base::take(_a_show); | ||||||
| 
 | 
 | ||||||
| 	showChildren(); | 	showChildren(); | ||||||
| 	myEnsureResized(this); | 	Ui::SendPendingMoveResizeEvents(this); | ||||||
| 
 | 
 | ||||||
| 	auto result = QImage(size() * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | 	auto result = QImage(size() * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | ||||||
| 	result.setDevicePixelRatio(cRetinaFactor()); | 	result.setDevicePixelRatio(cRetinaFactor()); | ||||||
|  |  | ||||||
|  | @ -489,7 +489,7 @@ QImage TabbedSelector::grabForAnimation() { | ||||||
| 	showAll(); | 	showAll(); | ||||||
| 	_topShadow->hide(); | 	_topShadow->hide(); | ||||||
| 	_tabsSlider->hide(); | 	_tabsSlider->hide(); | ||||||
| 	myEnsureResized(this); | 	Ui::SendPendingMoveResizeEvents(this); | ||||||
| 
 | 
 | ||||||
| 	auto result = QImage(size() * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | 	auto result = QImage(size() * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | ||||||
| 	result.setDevicePixelRatio(cRetinaFactor()); | 	result.setDevicePixelRatio(cRetinaFactor()); | ||||||
|  |  | ||||||
|  | @ -229,7 +229,7 @@ void DialogsWidget::startWidthAnimation() { | ||||||
| 		st::columnMinimalWidthLeft, | 		st::columnMinimalWidthLeft, | ||||||
| 		scrollGeometry.height()); | 		scrollGeometry.height()); | ||||||
| 	_scroll->setGeometry(grabGeometry); | 	_scroll->setGeometry(grabGeometry); | ||||||
| 	myEnsureResized(_scroll); | 	Ui::SendPendingMoveResizeEvents(_scroll); | ||||||
| 	auto image = QImage( | 	auto image = QImage( | ||||||
| 		grabGeometry.size() * cIntRetinaFactor(), | 		grabGeometry.size() * cIntRetinaFactor(), | ||||||
| 		QImage::Format_ARGB32_Premultiplied); | 		QImage::Format_ARGB32_Premultiplied); | ||||||
|  |  | ||||||
|  | @ -294,7 +294,7 @@ not_null<ChannelData*> Widget::channel() const { | ||||||
| 
 | 
 | ||||||
| QPixmap Widget::grabForShowAnimation(const Window::SectionSlideParams ¶ms) { | QPixmap Widget::grabForShowAnimation(const Window::SectionSlideParams ¶ms) { | ||||||
| 	if (params.withTopBarShadow) _fixedBarShadow->hide(); | 	if (params.withTopBarShadow) _fixedBarShadow->hide(); | ||||||
| 	auto result = myGrab(this); | 	auto result = Ui::GrabWidget(this); | ||||||
| 	if (params.withTopBarShadow) _fixedBarShadow->show(); | 	if (params.withTopBarShadow) _fixedBarShadow->show(); | ||||||
| 	return result; | 	return result; | ||||||
| } | } | ||||||
|  | @ -319,7 +319,7 @@ bool Widget::showInternal( | ||||||
| 
 | 
 | ||||||
| void Widget::setInternalState(const QRect &geometry, not_null<SectionMemento*> memento) { | void Widget::setInternalState(const QRect &geometry, not_null<SectionMemento*> memento) { | ||||||
| 	setGeometry(geometry); | 	setGeometry(geometry); | ||||||
| 	myEnsureResized(this); | 	Ui::SendPendingMoveResizeEvents(this); | ||||||
| 	restoreState(memento); | 	restoreState(memento); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -143,7 +143,9 @@ void DragArea::hideStart() { | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 	if (_cache.isNull()) { | 	if (_cache.isNull()) { | ||||||
| 		_cache = myGrab(this, innerRect().marginsAdded(st::boxRoundShadow.extend)); | 		_cache = Ui::GrabWidget( | ||||||
|  | 			this, | ||||||
|  | 			innerRect().marginsAdded(st::boxRoundShadow.extend)); | ||||||
| 	} | 	} | ||||||
| 	_hiding = true; | 	_hiding = true; | ||||||
| 	setIn(false); | 	setIn(false); | ||||||
|  | @ -162,7 +164,9 @@ void DragArea::showStart() { | ||||||
| 	} | 	} | ||||||
| 	_hiding = false; | 	_hiding = false; | ||||||
| 	if (_cache.isNull()) { | 	if (_cache.isNull()) { | ||||||
| 		_cache = myGrab(this, innerRect().marginsAdded(st::boxRoundShadow.extend)); | 		_cache = Ui::GrabWidget( | ||||||
|  | 			this, | ||||||
|  | 			innerRect().marginsAdded(st::boxRoundShadow.extend)); | ||||||
| 	} | 	} | ||||||
| 	show(); | 	show(); | ||||||
| 	_a_opacity.start([this] { opacityAnimationCallback(); }, 0., 1., st::boxDuration); | 	_a_opacity.start([this] { opacityAnimationCallback(); }, 0., 1., st::boxDuration); | ||||||
|  |  | ||||||
|  | @ -280,7 +280,7 @@ void HistoryHider::startHide() { | ||||||
| 	if (Adaptive::OneColumn()) { | 	if (Adaptive::OneColumn()) { | ||||||
| 		QTimer::singleShot(0, this, SLOT(deleteLater())); | 		QTimer::singleShot(0, this, SLOT(deleteLater())); | ||||||
| 	} else { | 	} else { | ||||||
| 		if (_offered) _cacheForAnim = myGrab(this, _box); | 		if (_offered) _cacheForAnim = Ui::GrabWidget(this, _box); | ||||||
| 		if (_forwardRequest) MTP::cancel(_forwardRequest); | 		if (_forwardRequest) MTP::cancel(_forwardRequest); | ||||||
| 		_send->hide(); | 		_send->hide(); | ||||||
| 		_cancel->hide(); | 		_cancel->hide(); | ||||||
|  |  | ||||||
|  | @ -87,7 +87,7 @@ void Widget::setInternalState( | ||||||
| 		const QRect &geometry, | 		const QRect &geometry, | ||||||
| 		not_null<Memento*> memento) { | 		not_null<Memento*> memento) { | ||||||
| 	setGeometry(geometry); | 	setGeometry(geometry); | ||||||
| 	myEnsureResized(this); | 	Ui::SendPendingMoveResizeEvents(this); | ||||||
| 	restoreState(memento); | 	restoreState(memento); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -652,7 +652,7 @@ QPixmap WrapWidget::grabForShowAnimation( | ||||||
| 	//if (params.withTabs && _topTabs) {
 | 	//if (params.withTabs && _topTabs) {
 | ||||||
| 	//	_topTabs->hide();
 | 	//	_topTabs->hide();
 | ||||||
| 	//}
 | 	//}
 | ||||||
| 	auto result = myGrab(this); | 	auto result = Ui::GrabWidget(this); | ||||||
| 	if (params.withTopBarShadow) { | 	if (params.withTopBarShadow) { | ||||||
| 		_topShadow->setVisible(true); | 		_topShadow->setVisible(true); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -122,7 +122,7 @@ void Widget::setInternalState( | ||||||
| 		const QRect &geometry, | 		const QRect &geometry, | ||||||
| 		not_null<Memento*> memento) { | 		not_null<Memento*> memento) { | ||||||
| 	setGeometry(geometry); | 	setGeometry(geometry); | ||||||
| 	myEnsureResized(this); | 	Ui::SendPendingMoveResizeEvents(this); | ||||||
| 	restoreState(memento); | 	restoreState(memento); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -84,7 +84,7 @@ void Widget::setInternalState( | ||||||
| 		const QRect &geometry, | 		const QRect &geometry, | ||||||
| 		not_null<Memento*> memento) { | 		not_null<Memento*> memento) { | ||||||
| 	setGeometry(geometry); | 	setGeometry(geometry); | ||||||
| 	myEnsureResized(this); | 	Ui::SendPendingMoveResizeEvents(this); | ||||||
| 	restoreState(memento); | 	restoreState(memento); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -103,7 +103,7 @@ void Widget::setInternalState( | ||||||
| 		const QRect &geometry, | 		const QRect &geometry, | ||||||
| 		not_null<Memento*> memento) { | 		not_null<Memento*> memento) { | ||||||
| 	setGeometry(geometry); | 	setGeometry(geometry); | ||||||
| 	myEnsureResized(this); | 	Ui::SendPendingMoveResizeEvents(this); | ||||||
| 	restoreState(memento); | 	restoreState(memento); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -874,7 +874,7 @@ void Widget::prepareCache() { | ||||||
| 	auto showAnimation = base::take(_a_show); | 	auto showAnimation = base::take(_a_show); | ||||||
| 	auto showAnimationData = base::take(_showAnimation); | 	auto showAnimationData = base::take(_showAnimation); | ||||||
| 	showChildren(); | 	showChildren(); | ||||||
| 	_cache = myGrab(this); | 	_cache = Ui::GrabWidget(this); | ||||||
| 	_showAnimation = base::take(showAnimationData); | 	_showAnimation = base::take(showAnimationData); | ||||||
| 	_a_show = base::take(showAnimation); | 	_a_show = base::take(showAnimation); | ||||||
| 	if (_a_show.animating()) { | 	if (_a_show.animating()) { | ||||||
|  | @ -911,7 +911,7 @@ void Widget::startShowAnimation() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QImage Widget::grabForPanelAnimation() { | QImage Widget::grabForPanelAnimation() { | ||||||
| 	myEnsureResized(this); | 	Ui::SendPendingMoveResizeEvents(this); | ||||||
| 	auto result = QImage(size() * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | 	auto result = QImage(size() * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | ||||||
| 	result.setDevicePixelRatio(cRetinaFactor()); | 	result.setDevicePixelRatio(cRetinaFactor()); | ||||||
| 	result.fill(Qt::transparent); | 	result.fill(Qt::transparent); | ||||||
|  |  | ||||||
|  | @ -336,7 +336,7 @@ void Widget::showAnimated(const QPixmap &bgAnimCache, bool back) { | ||||||
| 
 | 
 | ||||||
| 	_a_show.finish(); | 	_a_show.finish(); | ||||||
| 	showControls(); | 	showControls(); | ||||||
| 	(_showBack ? _cacheUnder : _cacheOver) = myGrab(this); | 	(_showBack ? _cacheUnder : _cacheOver) = Ui::GrabWidget(this); | ||||||
| 	hideControls(); | 	hideControls(); | ||||||
| 
 | 
 | ||||||
| 	_a_show.start([this] { animationCallback(); }, 0., 1., st::slideDuration, Window::SlideAnimation::transition()); | 	_a_show.start([this] { animationCallback(); }, 0., 1., st::slideDuration, Window::SlideAnimation::transition()); | ||||||
|  | @ -491,7 +491,7 @@ void Widget::Step::resizeEvent(QResizeEvent *e) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Widget::Step::updateLabelsPosition() { | void Widget::Step::updateLabelsPosition() { | ||||||
| 	myEnsureResized(_description->entity()); | 	Ui::SendPendingMoveResizeEvents(_description->entity()); | ||||||
| 	if (hasCover()) { | 	if (hasCover()) { | ||||||
| 		_title->moveToLeft((width() - _title->width()) / 2, contentTop() + st::introCoverTitleTop); | 		_title->moveToLeft((width() - _title->width()) / 2, contentTop() + st::introCoverTitleTop); | ||||||
| 		_description->moveToLeft((width() - _description->width()) / 2, contentTop() + st::introCoverDescriptionTop); | 		_description->moveToLeft((width() - _description->width()) / 2, contentTop() + st::introCoverDescriptionTop); | ||||||
|  | @ -503,7 +503,7 @@ void Widget::Step::updateLabelsPosition() { | ||||||
| 		if (_errorCentered) { | 		if (_errorCentered) { | ||||||
| 			_error->entity()->resizeToWidth(width()); | 			_error->entity()->resizeToWidth(width()); | ||||||
| 		} | 		} | ||||||
| 		myEnsureResized(_error->entity()); | 		Ui::SendPendingMoveResizeEvents(_error->entity()); | ||||||
| 		auto errorLeft = _errorCentered ? 0 : (contentLeft() + st::buttonRadius); | 		auto errorLeft = _errorCentered ? 0 : (contentLeft() + st::buttonRadius); | ||||||
| 		auto errorTop = contentTop() + (_errorBelowLink ? st::introErrorBelowLinkTop : st::introErrorTop); | 		auto errorTop = contentTop() + (_errorBelowLink ? st::introErrorBelowLinkTop : st::introErrorTop); | ||||||
| 		_error->moveToLeft(errorLeft, errorTop); | 		_error->moveToLeft(errorLeft, errorTop); | ||||||
|  | @ -773,8 +773,16 @@ void Widget::Step::prepareShowAnimated(Step *after) { | ||||||
| 
 | 
 | ||||||
| Widget::Step::CoverAnimation Widget::Step::prepareCoverAnimation(Step *after) { | Widget::Step::CoverAnimation Widget::Step::prepareCoverAnimation(Step *after) { | ||||||
| 	auto result = CoverAnimation(); | 	auto result = CoverAnimation(); | ||||||
| 	result.title = Ui::FlatLabel::CrossFade(after->_title, _title, st::introBg); | 	result.title = Ui::FlatLabel::CrossFade( | ||||||
| 	result.description = Ui::FlatLabel::CrossFade(after->_description->entity(), _description->entity(), st::introBg, after->_description->pos(), _description->pos()); | 		after->_title, | ||||||
|  | 		_title, | ||||||
|  | 		st::introBg); | ||||||
|  | 	result.description = Ui::FlatLabel::CrossFade( | ||||||
|  | 		after->_description->entity(), | ||||||
|  | 		_description->entity(), | ||||||
|  | 		st::introBg, | ||||||
|  | 		after->_description->pos(), | ||||||
|  | 		_description->pos()); | ||||||
| 	result.contentSnapshotWas = after->prepareContentSnapshot(); | 	result.contentSnapshotWas = after->prepareContentSnapshot(); | ||||||
| 	result.contentSnapshotNow = prepareContentSnapshot(); | 	result.contentSnapshotNow = prepareContentSnapshot(); | ||||||
| 	return result; | 	return result; | ||||||
|  | @ -783,13 +791,15 @@ Widget::Step::CoverAnimation Widget::Step::prepareCoverAnimation(Step *after) { | ||||||
| QPixmap Widget::Step::prepareContentSnapshot() { | QPixmap Widget::Step::prepareContentSnapshot() { | ||||||
| 	auto otherTop = _description->y() + _description->height(); | 	auto otherTop = _description->y() + _description->height(); | ||||||
| 	auto otherRect = myrtlrect(contentLeft(), otherTop, st::introStepWidth, height() - otherTop); | 	auto otherRect = myrtlrect(contentLeft(), otherTop, st::introStepWidth, height() - otherTop); | ||||||
| 	return myGrab(this, otherRect); | 	return Ui::GrabWidget(this, otherRect); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QPixmap Widget::Step::prepareSlideAnimation() { | QPixmap Widget::Step::prepareSlideAnimation() { | ||||||
| 	auto grabLeft = (width() - st::introStepWidth) / 2; | 	auto grabLeft = (width() - st::introStepWidth) / 2; | ||||||
| 	auto grabTop = contentTop(); | 	auto grabTop = contentTop(); | ||||||
| 	return myGrab(this, QRect(grabLeft, grabTop, st::introStepWidth, st::introStepHeight)); | 	return Ui::GrabWidget( | ||||||
|  | 		this, | ||||||
|  | 		QRect(grabLeft, grabTop, st::introStepWidth, st::introStepHeight)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Widget::Step::showAnimated(Direction direction) { | void Widget::Step::showAnimated(Direction direction) { | ||||||
|  |  | ||||||
|  | @ -2554,7 +2554,7 @@ Window::SectionSlideParams MainWidget::prepareShowAnimation( | ||||||
| 
 | 
 | ||||||
| 	auto sectionTop = getMainSectionTop(); | 	auto sectionTop = getMainSectionTop(); | ||||||
| 	if (selectingPeer() && Adaptive::OneColumn()) { | 	if (selectingPeer() && Adaptive::OneColumn()) { | ||||||
| 		result.oldContentCache = myGrab(this, QRect( | 		result.oldContentCache = Ui::GrabWidget(this, QRect( | ||||||
| 			0, | 			0, | ||||||
| 			sectionTop, | 			sectionTop, | ||||||
| 			_dialogsWidth, | 			_dialogsWidth, | ||||||
|  | @ -2568,7 +2568,7 @@ Window::SectionSlideParams MainWidget::prepareShowAnimation( | ||||||
| 			_history->grabStart(); | 			_history->grabStart(); | ||||||
| 		} | 		} | ||||||
| 		if (Adaptive::OneColumn()) { | 		if (Adaptive::OneColumn()) { | ||||||
| 			result.oldContentCache = myGrab(this, QRect( | 			result.oldContentCache = Ui::GrabWidget(this, QRect( | ||||||
| 				0, | 				0, | ||||||
| 				sectionTop, | 				sectionTop, | ||||||
| 				_dialogsWidth, | 				_dialogsWidth, | ||||||
|  | @ -2578,7 +2578,7 @@ Window::SectionSlideParams MainWidget::prepareShowAnimation( | ||||||
| 			if (_thirdShadow) { | 			if (_thirdShadow) { | ||||||
| 				_thirdShadow->hide(); | 				_thirdShadow->hide(); | ||||||
| 			} | 			} | ||||||
| 			result.oldContentCache = myGrab(this, QRect( | 			result.oldContentCache = Ui::GrabWidget(this, QRect( | ||||||
| 				_dialogsWidth, | 				_dialogsWidth, | ||||||
| 				sectionTop, | 				sectionTop, | ||||||
| 				width() - _dialogsWidth, | 				width() - _dialogsWidth, | ||||||
|  | @ -2890,7 +2890,7 @@ QPixmap MainWidget::grabForShowAnimation(const Window::SectionSlideParams ¶m | ||||||
| 
 | 
 | ||||||
| 	auto sectionTop = getMainSectionTop(); | 	auto sectionTop = getMainSectionTop(); | ||||||
| 	if (Adaptive::OneColumn()) { | 	if (Adaptive::OneColumn()) { | ||||||
| 		result = myGrab(this, QRect( | 		result = Ui::GrabWidget(this, QRect( | ||||||
| 			0, | 			0, | ||||||
| 			sectionTop, | 			sectionTop, | ||||||
| 			_dialogsWidth, | 			_dialogsWidth, | ||||||
|  | @ -2900,7 +2900,7 @@ QPixmap MainWidget::grabForShowAnimation(const Window::SectionSlideParams ¶m | ||||||
| 		if (_thirdShadow) { | 		if (_thirdShadow) { | ||||||
| 			_thirdShadow->hide(); | 			_thirdShadow->hide(); | ||||||
| 		} | 		} | ||||||
| 		result = myGrab(this, QRect( | 		result = Ui::GrabWidget(this, QRect( | ||||||
| 			_dialogsWidth, | 			_dialogsWidth, | ||||||
| 			sectionTop, | 			sectionTop, | ||||||
| 			width() - _dialogsWidth, | 			width() - _dialogsWidth, | ||||||
|  | @ -3001,10 +3001,15 @@ void MainWidget::showAnimated(const QPixmap &bgAnimCache, bool back) { | ||||||
| 	_a_show.finish(); | 	_a_show.finish(); | ||||||
| 
 | 
 | ||||||
| 	showAll(); | 	showAll(); | ||||||
| 	(_showBack ? _cacheUnder : _cacheOver) = myGrab(this); | 	(_showBack ? _cacheUnder : _cacheOver) = Ui::GrabWidget(this); | ||||||
| 	hideAll(); | 	hideAll(); | ||||||
| 
 | 
 | ||||||
| 	_a_show.start([this] { animationCallback(); }, 0., 1., st::slideDuration, Window::SlideAnimation::transition()); | 	_a_show.start( | ||||||
|  | 		[this] { animationCallback(); }, | ||||||
|  | 		0., | ||||||
|  | 		1., | ||||||
|  | 		st::slideDuration, | ||||||
|  | 		Window::SlideAnimation::transition()); | ||||||
| 
 | 
 | ||||||
| 	show(); | 	show(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -194,11 +194,11 @@ void MainWindow::clearWidgetsHook() { | ||||||
| QPixmap MainWindow::grabInner() { | QPixmap MainWindow::grabInner() { | ||||||
| 	QPixmap result; | 	QPixmap result; | ||||||
| 	if (_intro) { | 	if (_intro) { | ||||||
| 		result = myGrab(_intro); | 		result = Ui::GrabWidget(_intro); | ||||||
| 	} else if (_passcode) { | 	} else if (_passcode) { | ||||||
| 		result = myGrab(_passcode); | 		result = Ui::GrabWidget(_passcode); | ||||||
| 	} else if (_main) { | 	} else if (_main) { | ||||||
| 		result = myGrab(_main); | 		result = Ui::GrabWidget(_main); | ||||||
| 	} | 	} | ||||||
| 	return result; | 	return result; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -426,7 +426,7 @@ void Panel::startAnimation() { | ||||||
| 	auto to = _hiding ? 0. : 1.; | 	auto to = _hiding ? 0. : 1.; | ||||||
| 	if (_cache.isNull()) { | 	if (_cache.isNull()) { | ||||||
| 		showChildren(); | 		showChildren(); | ||||||
| 		_cache = myGrab(this); | 		_cache = Ui::GrabWidget(this); | ||||||
| 	} | 	} | ||||||
| 	hideChildren(); | 	hideChildren(); | ||||||
| 	_a_appearance.start([this] { appearanceCallback(); }, from, to, st::defaultInnerDropdown.duration); | 	_a_appearance.start([this] { appearanceCallback(); }, from, to, st::defaultInnerDropdown.duration); | ||||||
|  |  | ||||||
|  | @ -207,7 +207,7 @@ void VolumeWidget::startAnimation() { | ||||||
| 	auto to = _hiding ? 0. : 1.; | 	auto to = _hiding ? 0. : 1.; | ||||||
| 	if (_cache.isNull()) { | 	if (_cache.isNull()) { | ||||||
| 		showChildren(); | 		showChildren(); | ||||||
| 		_cache = myGrab(this); | 		_cache = Ui::GrabWidget(this); | ||||||
| 	} | 	} | ||||||
| 	hideChildren(); | 	hideChildren(); | ||||||
| 	_a_appearance.start([this] { appearanceCallback(); }, from, to, st::defaultInnerDropdown.duration); | 	_a_appearance.start([this] { appearanceCallback(); }, from, to, st::defaultInnerDropdown.duration); | ||||||
|  |  | ||||||
|  | @ -1634,7 +1634,7 @@ void MediaView::setClipControllerGeometry() { | ||||||
| 		controllerBottom - _clipController->height() - st::mediaviewCaptionPadding.bottom() - st::mediaviewCaptionMargin.height(), | 		controllerBottom - _clipController->height() - st::mediaviewCaptionPadding.bottom() - st::mediaviewCaptionMargin.height(), | ||||||
| 		st::mediaviewControllerSize.width(), | 		st::mediaviewControllerSize.width(), | ||||||
| 		st::mediaviewControllerSize.height()); | 		st::mediaviewControllerSize.height()); | ||||||
| 	myEnsureResized(_clipController); | 	Ui::SendPendingMoveResizeEvents(_clipController); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MediaView::onVideoPauseResume() { | void MediaView::onVideoPauseResume() { | ||||||
|  |  | ||||||
|  | @ -109,10 +109,15 @@ void PasscodeWidget::showAnimated(const QPixmap &bgAnimCache, bool back) { | ||||||
| 	showAll(); | 	showAll(); | ||||||
| 	setInnerFocus(); | 	setInnerFocus(); | ||||||
| 	_passcode->finishAnimating(); | 	_passcode->finishAnimating(); | ||||||
| 	(_showBack ? _cacheUnder : _cacheOver) = myGrab(this); | 	(_showBack ? _cacheUnder : _cacheOver) = Ui::GrabWidget(this); | ||||||
| 	hideAll(); | 	hideAll(); | ||||||
| 
 | 
 | ||||||
| 	_a_show.start([this] { animationCallback(); }, 0., 1., st::slideDuration, Window::SlideAnimation::transition()); | 	_a_show.start( | ||||||
|  | 		[this] { animationCallback(); }, | ||||||
|  | 		0., | ||||||
|  | 		1., | ||||||
|  | 		st::slideDuration, | ||||||
|  | 		Window::SlideAnimation::transition()); | ||||||
| 	show(); | 	show(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -91,10 +91,14 @@ void CoverDropArea::paintEvent(QPaintEvent *e) { | ||||||
| 
 | 
 | ||||||
| void CoverDropArea::setupAnimation() { | void CoverDropArea::setupAnimation() { | ||||||
| 	if (_cache.isNull()) { | 	if (_cache.isNull()) { | ||||||
| 		_cache = myGrab(this); | 		_cache = Ui::GrabWidget(this); | ||||||
| 	} | 	} | ||||||
| 	auto from = _hiding ? 1. : 0., to = _hiding ? 0. : 1.; | 	auto from = _hiding ? 1. : 0., to = _hiding ? 0. : 1.; | ||||||
| 	_a_appearance.start([this]() { update(); }, from, to, st::profileDropAreaDuration); | 	_a_appearance.start( | ||||||
|  | 		[this] { update(); }, | ||||||
|  | 		from, | ||||||
|  | 		to, | ||||||
|  | 		st::profileDropAreaDuration); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } // namespace Profile
 | } // namespace Profile
 | ||||||
|  |  | ||||||
|  | @ -74,7 +74,7 @@ void FadeAnimation::refreshCache() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QPixmap FadeAnimation::grabContent() { | QPixmap FadeAnimation::grabContent() { | ||||||
| 	myEnsureResized(_widget); | 	SendPendingMoveResizeEvents(_widget); | ||||||
| 	_size = _widget->size(); | 	_size = _widget->size(); | ||||||
| 	if (_size.isEmpty()) { | 	if (_size.isEmpty()) { | ||||||
| 		auto image = QImage( | 		auto image = QImage( | ||||||
|  | @ -84,7 +84,7 @@ QPixmap FadeAnimation::grabContent() { | ||||||
| 		image.fill(Qt::transparent); | 		image.fill(Qt::transparent); | ||||||
| 		return App::pixmapFromImageInPlace(std::move(image)); | 		return App::pixmapFromImageInPlace(std::move(image)); | ||||||
| 	} | 	} | ||||||
| 	auto widgetContent = myGrab(_widget); | 	auto widgetContent = GrabWidget(_widget); | ||||||
| 	if (_scale < 1.) { | 	if (_scale < 1.) { | ||||||
| 		auto result = QImage(kWideScale * _size * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | 		auto result = QImage(kWideScale * _size * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | ||||||
| 		result.setDevicePixelRatio(cRetinaFactor()); | 		result.setDevicePixelRatio(cRetinaFactor()); | ||||||
|  |  | ||||||
|  | @ -367,7 +367,10 @@ QPixmap SendButton::grabContent() { | ||||||
| 	result.fill(Qt::transparent); | 	result.fill(Qt::transparent); | ||||||
| 	{ | 	{ | ||||||
| 		Painter p(&result); | 		Painter p(&result); | ||||||
| 		p.drawPixmap((kWideScale - 1) / 2 * width(), (kWideScale - 1) / 2 * height(), myGrab(this)); | 		p.drawPixmap( | ||||||
|  | 			(kWideScale - 1) / 2 * width(), | ||||||
|  | 			(kWideScale - 1) / 2 * height(), | ||||||
|  | 			GrabWidget(this)); | ||||||
| 	} | 	} | ||||||
| 	return App::pixmapFromImageInPlace(std::move(result)); | 	return App::pixmapFromImageInPlace(std::move(result)); | ||||||
| } | } | ||||||
|  | @ -715,7 +718,7 @@ void UserpicButton::grabOldUserpic() { | ||||||
| 		countPhotoPosition(), | 		countPhotoPosition(), | ||||||
| 		QSize(_st.photoSize, _st.photoSize) | 		QSize(_st.photoSize, _st.photoSize) | ||||||
| 	); | 	); | ||||||
| 	_oldUserpic = myGrab(this, photoRect); | 	_oldUserpic = GrabWidget(this, photoRect); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void UserpicButton::startNewPhotoShowing() { | void UserpicButton::startNewPhotoShowing() { | ||||||
|  |  | ||||||
|  | @ -118,6 +118,7 @@ QString GetOverride(const QString &familyName) { | ||||||
| 
 | 
 | ||||||
| } // Fonts
 | } // Fonts
 | ||||||
| 
 | 
 | ||||||
|  | namespace Ui { | ||||||
| namespace { | namespace { | ||||||
| 
 | 
 | ||||||
| class WidgetCreator : public QWidget { | class WidgetCreator : public QWidget { | ||||||
|  | @ -182,48 +183,61 @@ void SendPendingEventsRecursive(QWidget *target, bool parentHiddenFlag) { | ||||||
| 
 | 
 | ||||||
| } // namespace
 | } // namespace
 | ||||||
| 
 | 
 | ||||||
| void myEnsureResized(QWidget *target) { | void SendPendingMoveResizeEvents(not_null<QWidget*> target) { | ||||||
| 	if (!target) { |  | ||||||
| 		return; |  | ||||||
| 	} |  | ||||||
| 	CreateWidgetStateRecursive(target); | 	CreateWidgetStateRecursive(target); | ||||||
| 	SendPendingEventsRecursive(target, !target->isVisible()); | 	SendPendingEventsRecursive(target, !target->isVisible()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QPixmap myGrab(TWidget *target, QRect rect, QColor bg) { | QPixmap GrabWidget(not_null<TWidget*> target, QRect rect, QColor bg) { | ||||||
| 	myEnsureResized(target); | 	SendPendingMoveResizeEvents(target); | ||||||
| 	if (rect.isNull()) rect = target->rect(); | 	if (rect.isNull()) { | ||||||
| 
 | 		rect = target->rect(); | ||||||
|     auto result = QPixmap(rect.size() * cIntRetinaFactor()); |  | ||||||
|     result.setDevicePixelRatio(cRetinaFactor()); |  | ||||||
| 	if (!target->testAttribute(Qt::WA_OpaquePaintEvent)) { |  | ||||||
| 		result.fill(bg); |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	target->grabStart(); | 	auto result = QPixmap(rect.size() * cIntRetinaFactor()); | ||||||
| 	target->render(&result, QPoint(0, 0), rect, QWidget::DrawChildren | QWidget::IgnoreMask); |  | ||||||
| 	target->grabFinish(); |  | ||||||
| 
 |  | ||||||
| 	return result; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| QImage myGrabImage(TWidget *target, QRect rect, QColor bg) { |  | ||||||
| 	myEnsureResized(target); |  | ||||||
| 	if (rect.isNull()) rect = target->rect(); |  | ||||||
| 
 |  | ||||||
| 	auto result = QImage(rect.size() * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); |  | ||||||
| 	result.setDevicePixelRatio(cRetinaFactor()); | 	result.setDevicePixelRatio(cRetinaFactor()); | ||||||
| 	if (!target->testAttribute(Qt::WA_OpaquePaintEvent)) { | 	if (!target->testAttribute(Qt::WA_OpaquePaintEvent)) { | ||||||
| 		result.fill(bg); | 		result.fill(bg); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	target->grabStart(); | 	target->grabStart(); | ||||||
| 	target->render(&result, QPoint(0, 0), rect, QWidget::DrawChildren | QWidget::IgnoreMask); | 	target->render( | ||||||
|  | 		&result, | ||||||
|  | 		QPoint(0, 0), | ||||||
|  | 		rect, | ||||||
|  | 		QWidget::DrawChildren | QWidget::IgnoreMask); | ||||||
| 	target->grabFinish(); | 	target->grabFinish(); | ||||||
| 
 | 
 | ||||||
| 	return result; | 	return result; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | QImage GrabWidgetToImage(not_null<TWidget*> target, QRect rect, QColor bg) { | ||||||
|  | 	Ui::SendPendingMoveResizeEvents(target); | ||||||
|  | 	if (rect.isNull()) { | ||||||
|  | 		rect = target->rect(); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	auto result = QImage( | ||||||
|  | 		rect.size() * cIntRetinaFactor(), | ||||||
|  | 		QImage::Format_ARGB32_Premultiplied); | ||||||
|  | 	result.setDevicePixelRatio(cRetinaFactor()); | ||||||
|  | 	if (!target->testAttribute(Qt::WA_OpaquePaintEvent)) { | ||||||
|  | 		result.fill(bg); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	target->grabStart(); | ||||||
|  | 	target->render( | ||||||
|  | 		&result, | ||||||
|  | 		QPoint(0, 0), | ||||||
|  | 		rect, | ||||||
|  | 		QWidget::DrawChildren | QWidget::IgnoreMask); | ||||||
|  | 	target->grabFinish(); | ||||||
|  | 
 | ||||||
|  | 	return result; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | } // namespace Ui
 | ||||||
|  | 
 | ||||||
| void sendSynteticMouseEvent(QWidget *widget, QEvent::Type type, Qt::MouseButton button, const QPoint &globalPoint) { | void sendSynteticMouseEvent(QWidget *widget, QEvent::Type type, Qt::MouseButton button, const QPoint &globalPoint) { | ||||||
| 	if (auto windowHandle = widget->window()->windowHandle()) { | 	if (auto windowHandle = widget->window()->windowHandle()) { | ||||||
| 		auto localPoint = windowHandle->mapFromGlobal(globalPoint); | 		auto localPoint = windowHandle->mapFromGlobal(globalPoint); | ||||||
|  |  | ||||||
|  | @ -29,6 +29,8 @@ QString GetOverride(const QString &familyName); | ||||||
| 
 | 
 | ||||||
| } // namespace
 | } // namespace
 | ||||||
| 
 | 
 | ||||||
|  | class TWidget; | ||||||
|  | 
 | ||||||
| template <typename Object> | template <typename Object> | ||||||
| class object_ptr; | class object_ptr; | ||||||
| 
 | 
 | ||||||
|  | @ -57,6 +59,17 @@ inline ChildWidget *AttachParentChild( | ||||||
| 	return nullptr; | 	return nullptr; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void SendPendingMoveResizeEvents(not_null<QWidget*> target); | ||||||
|  | 
 | ||||||
|  | QPixmap GrabWidget( | ||||||
|  | 	not_null<TWidget*> target, | ||||||
|  | 	QRect rect = QRect(), | ||||||
|  | 	QColor bg = QColor(255, 255, 255, 0)); | ||||||
|  | QImage GrabWidgetToImage( | ||||||
|  | 	not_null<TWidget*> target, | ||||||
|  | 	QRect rect = QRect(), | ||||||
|  | 	QColor bg = QColor(255, 255, 255, 0)); | ||||||
|  | 
 | ||||||
| } // namespace Ui
 | } // namespace Ui
 | ||||||
| 
 | 
 | ||||||
| enum class RectPart { | enum class RectPart { | ||||||
|  | @ -209,8 +222,6 @@ private: | ||||||
| 
 | 
 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class TWidget; |  | ||||||
| 
 |  | ||||||
| template <typename Base> | template <typename Base> | ||||||
| class TWidgetHelper : public Base { | class TWidgetHelper : public Base { | ||||||
| public: | public: | ||||||
|  | @ -444,10 +455,6 @@ QPointer<const Widget> make_weak(const Widget *object) { | ||||||
| 	return QPointer<const Widget>(object); | 	return QPointer<const Widget>(object); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void myEnsureResized(QWidget *target); |  | ||||||
| QPixmap myGrab(TWidget *target, QRect rect = QRect(), QColor bg = QColor(255, 255, 255, 0)); |  | ||||||
| QImage myGrabImage(TWidget *target, QRect rect = QRect(), QColor bg = QColor(255, 255, 255, 0)); |  | ||||||
| 
 |  | ||||||
| class SingleQueuedInvokation : public QObject { | class SingleQueuedInvokation : public QObject { | ||||||
| public: | public: | ||||||
| 	SingleQueuedInvokation(base::lambda<void()> callback) : _callback(callback) { | 	SingleQueuedInvokation(base::lambda<void()> callback) : _callback(callback) { | ||||||
|  |  | ||||||
|  | @ -247,7 +247,7 @@ void InnerDropdown::prepareCache() { | ||||||
| 	auto showAnimation = base::take(_a_show); | 	auto showAnimation = base::take(_a_show); | ||||||
| 	auto showAnimationData = base::take(_showAnimation); | 	auto showAnimationData = base::take(_showAnimation); | ||||||
| 	showChildren(); | 	showChildren(); | ||||||
| 	_cache = myGrab(this); | 	_cache = GrabWidget(this); | ||||||
| 	_showAnimation = base::take(showAnimationData); | 	_showAnimation = base::take(showAnimationData); | ||||||
| 	_a_show = base::take(showAnimation); | 	_a_show = base::take(showAnimation); | ||||||
| 	if (_a_show.animating()) { | 	if (_a_show.animating()) { | ||||||
|  | @ -305,7 +305,7 @@ void InnerDropdown::startShowAnimation() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QImage InnerDropdown::grabForPanelAnimation() { | QImage InnerDropdown::grabForPanelAnimation() { | ||||||
| 	myEnsureResized(this); | 	SendPendingMoveResizeEvents(this); | ||||||
| 	auto result = QImage(size() * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | 	auto result = QImage(size() * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | ||||||
| 	result.setDevicePixelRatio(cRetinaFactor()); | 	result.setDevicePixelRatio(cRetinaFactor()); | ||||||
| 	result.fill(Qt::transparent); | 	result.fill(Qt::transparent); | ||||||
|  |  | ||||||
|  | @ -244,7 +244,7 @@ bool FlatTextarea::heightAutoupdated() { | ||||||
| 	if (_minHeight < 0 || _maxHeight < 0 || _inHeightCheck) return false; | 	if (_minHeight < 0 || _maxHeight < 0 || _inHeightCheck) return false; | ||||||
| 	_inHeightCheck = true; | 	_inHeightCheck = true; | ||||||
| 
 | 
 | ||||||
| 	myEnsureResized(this); | 	SendPendingMoveResizeEvents(this); | ||||||
| 
 | 
 | ||||||
| 	int newh = ceil(document()->size().height()) + 2 * fakeMargin(); | 	int newh = ceil(document()->size().height()) + 2 * fakeMargin(); | ||||||
| 	if (newh > _maxHeight) { | 	if (newh > _maxHeight) { | ||||||
|  | @ -1824,7 +1824,7 @@ bool InputArea::heightAutoupdated() { | ||||||
| 	if (_st.heightMin < 0 || _st.heightMax < 0 || _inHeightCheck) return false; | 	if (_st.heightMin < 0 || _st.heightMax < 0 || _inHeightCheck) return false; | ||||||
| 	_inHeightCheck = true; | 	_inHeightCheck = true; | ||||||
| 
 | 
 | ||||||
| 	myEnsureResized(this); | 	SendPendingMoveResizeEvents(this); | ||||||
| 
 | 
 | ||||||
| 	int newh = qCeil(_inner->document()->size().height()) + _st.textMargins.top() + _st.textMargins.bottom(); | 	int newh = qCeil(_inner->document()->size().height()) + _st.textMargins.top() + _st.textMargins.bottom(); | ||||||
| 	if (newh > _st.heightMax) { | 	if (newh > _st.heightMax) { | ||||||
|  |  | ||||||
|  | @ -640,7 +640,12 @@ void FlatLabel::clickHandlerPressedChanged(const ClickHandlerPtr &action, bool a | ||||||
| 	update(); | 	update(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::unique_ptr<CrossFadeAnimation> FlatLabel::CrossFade(FlatLabel *from, FlatLabel *to, style::color bg, QPoint fromPosition, QPoint toPosition) { | std::unique_ptr<CrossFadeAnimation> FlatLabel::CrossFade( | ||||||
|  | 		not_null<FlatLabel*> from, | ||||||
|  | 		not_null<FlatLabel*> to, | ||||||
|  | 		style::color bg, | ||||||
|  | 		QPoint fromPosition, | ||||||
|  | 		QPoint toPosition) { | ||||||
| 	auto result = std::make_unique<CrossFadeAnimation>(bg); | 	auto result = std::make_unique<CrossFadeAnimation>(bg); | ||||||
| 
 | 
 | ||||||
| 	struct Data { | 	struct Data { | ||||||
|  | @ -649,9 +654,9 @@ std::unique_ptr<CrossFadeAnimation> FlatLabel::CrossFade(FlatLabel *from, FlatLa | ||||||
| 		int lineHeight = 0; | 		int lineHeight = 0; | ||||||
| 		int lineAddTop = 0; | 		int lineAddTop = 0; | ||||||
| 	}; | 	}; | ||||||
| 	auto prepareData = [&bg](FlatLabel *label) { | 	auto prepareData = [&bg](not_null<FlatLabel*> label) { | ||||||
| 		auto result = Data(); | 		auto result = Data(); | ||||||
| 		result.full = myGrabImage(label, QRect(), bg->c); | 		result.full = GrabWidgetToImage(label, QRect(), bg->c); | ||||||
| 		auto textWidth = label->width() - label->_st.margin.left() - label->_st.margin.right(); | 		auto textWidth = label->width() - label->_st.margin.left() - label->_st.margin.right(); | ||||||
| 		label->_text.countLineWidths(textWidth, &result.lineWidths); | 		label->_text.countLineWidths(textWidth, &result.lineWidths); | ||||||
| 		result.lineHeight = label->_st.style.font->height; | 		result.lineHeight = label->_st.style.font->height; | ||||||
|  |  | ||||||
|  | @ -128,7 +128,12 @@ public: | ||||||
| 	void clickHandlerActiveChanged(const ClickHandlerPtr &action, bool active) override; | 	void clickHandlerActiveChanged(const ClickHandlerPtr &action, bool active) override; | ||||||
| 	void clickHandlerPressedChanged(const ClickHandlerPtr &action, bool pressed) override; | 	void clickHandlerPressedChanged(const ClickHandlerPtr &action, bool pressed) override; | ||||||
| 
 | 
 | ||||||
| 	static std::unique_ptr<CrossFadeAnimation> CrossFade(FlatLabel *from, FlatLabel *to, style::color bg, QPoint fromPosition = QPoint(), QPoint toPosition = QPoint()); | 	static std::unique_ptr<CrossFadeAnimation> CrossFade( | ||||||
|  | 		not_null<FlatLabel*> from, | ||||||
|  | 		not_null<FlatLabel*> to, | ||||||
|  | 		style::color bg, | ||||||
|  | 		QPoint fromPosition = QPoint(), | ||||||
|  | 		QPoint toPosition = QPoint()); | ||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
| 	void paintEvent(QPaintEvent *e) override; | 	void paintEvent(QPaintEvent *e) override; | ||||||
|  |  | ||||||
|  | @ -320,7 +320,7 @@ void PopupMenu::prepareCache() { | ||||||
| 	auto showAnimation = base::take(_a_show); | 	auto showAnimation = base::take(_a_show); | ||||||
| 	auto showAnimationData = base::take(_showAnimation); | 	auto showAnimationData = base::take(_showAnimation); | ||||||
| 	showChildren(); | 	showChildren(); | ||||||
| 	_cache = myGrab(this); | 	_cache = GrabWidget(this); | ||||||
| 	_showAnimation = base::take(showAnimationData); | 	_showAnimation = base::take(showAnimationData); | ||||||
| 	_a_show = base::take(showAnimation); | 	_a_show = base::take(showAnimation); | ||||||
| } | } | ||||||
|  | @ -396,7 +396,7 @@ void PopupMenu::showAnimationCallback() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QImage PopupMenu::grabForPanelAnimation() { | QImage PopupMenu::grabForPanelAnimation() { | ||||||
| 	myEnsureResized(this); | 	SendPendingMoveResizeEvents(this); | ||||||
| 	auto result = QImage(size() * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | 	auto result = QImage(size() * cIntRetinaFactor(), QImage::Format_ARGB32_Premultiplied); | ||||||
| 	result.setDevicePixelRatio(cRetinaFactor()); | 	result.setDevicePixelRatio(cRetinaFactor()); | ||||||
| 	result.fill(Qt::transparent); | 	result.fill(Qt::transparent); | ||||||
|  |  | ||||||
|  | @ -359,7 +359,9 @@ void ScrollArea::touchDeaccelerate(int32 elapsed) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ScrollArea::onScrolled() { | void ScrollArea::onScrolled() { | ||||||
| 	myEnsureResized(widget()); | 	if (const auto inner = widget()) { | ||||||
|  | 		SendPendingMoveResizeEvents(inner); | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	bool em = false; | 	bool em = false; | ||||||
| 	int horizontalValue = horizontalScrollBar()->value(); | 	int horizontalValue = horizontalScrollBar()->value(); | ||||||
|  | @ -703,8 +705,10 @@ void ScrollArea::scrollToWidget(not_null<QWidget*> widget) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ScrollArea::scrollToY(int toTop, int toBottom) { | void ScrollArea::scrollToY(int toTop, int toBottom) { | ||||||
| 	myEnsureResized(widget()); | 	if (const auto inner = widget()) { | ||||||
| 	myEnsureResized(this); | 		SendPendingMoveResizeEvents(inner); | ||||||
|  | 	} | ||||||
|  | 	SendPendingMoveResizeEvents(this); | ||||||
| 
 | 
 | ||||||
| 	int toMin = 0, toMax = scrollTopMax(); | 	int toMin = 0, toMax = scrollTopMax(); | ||||||
| 	if (toTop < toMin) { | 	if (toTop < toMin) { | ||||||
|  |  | ||||||
|  | @ -89,8 +89,11 @@ void Shadow::paint(Painter &p, const QRect &box, int outerWidth, const style::Sh | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QPixmap Shadow::grab(TWidget *target, const style::Shadow &shadow, RectParts sides) { | QPixmap Shadow::grab( | ||||||
| 	myEnsureResized(target); | 		not_null<TWidget*> target, | ||||||
|  | 		const style::Shadow &shadow, | ||||||
|  | 		RectParts sides) { | ||||||
|  | 	SendPendingMoveResizeEvents(target); | ||||||
| 	auto rect = target->rect(); | 	auto rect = target->rect(); | ||||||
| 	auto extend = QMargins( | 	auto extend = QMargins( | ||||||
| 		(sides & RectPart::Left) ? shadow.extend.left() : 0, | 		(sides & RectPart::Left) ? shadow.extend.left() : 0, | ||||||
|  |  | ||||||
|  | @ -42,14 +42,26 @@ private: | ||||||
| 
 | 
 | ||||||
| class Shadow : public TWidget { | class Shadow : public TWidget { | ||||||
| public: | public: | ||||||
| 	Shadow(QWidget *parent, const style::Shadow &st, RectParts sides = RectPart::Left | RectPart::Top | RectPart::Right | RectPart::Bottom) : TWidget(parent) | 	Shadow( | ||||||
|  | 		QWidget *parent, | ||||||
|  | 		const style::Shadow &st, | ||||||
|  | 		RectParts sides = RectPart::AllSides) | ||||||
|  | 	: TWidget(parent) | ||||||
| 	, _st(st) | 	, _st(st) | ||||||
| 	, _sides(sides) { | 	, _sides(sides) { | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	static void paint(Painter &p, const QRect &box, int outerWidth, const style::Shadow &st, RectParts sides = RectPart::Left | RectPart::Top | RectPart::Right | RectPart::Bottom); | 	static void paint( | ||||||
|  | 		Painter &p, | ||||||
|  | 		const QRect &box, | ||||||
|  | 		int outerWidth, | ||||||
|  | 		const style::Shadow &st, | ||||||
|  | 		RectParts sides = RectPart::AllSides); | ||||||
| 
 | 
 | ||||||
| 	static QPixmap grab(TWidget *target, const style::Shadow &shadow, RectParts sides = RectPart::Left | RectPart::Top | RectPart::Right | RectPart::Bottom); | 	static QPixmap grab( | ||||||
|  | 		not_null<TWidget*> target, | ||||||
|  | 		const style::Shadow &shadow, | ||||||
|  | 		RectParts sides = RectPart::AllSides); | ||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
| 	void paintEvent(QPaintEvent *e) override; | 	void paintEvent(QPaintEvent *e) override; | ||||||
|  |  | ||||||
|  | @ -311,7 +311,7 @@ void ImportantTooltip::refreshAnimationCache() { | ||||||
| 		auto animation = base::take(_visibleAnimation); | 		auto animation = base::take(_visibleAnimation); | ||||||
| 		auto visible = std::exchange(_visible, true); | 		auto visible = std::exchange(_visible, true); | ||||||
| 		showChildren(); | 		showChildren(); | ||||||
| 		_cache = myGrab(this); | 		_cache = GrabWidget(this); | ||||||
| 		_visible = base::take(visible); | 		_visible = base::take(visible); | ||||||
| 		_visibleAnimation = base::take(animation); | 		_visibleAnimation = base::take(animation); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -122,7 +122,7 @@ void SlideWrap<RpWidget>::animationStep() { | ||||||
| 	if (shouldBeHidden != isHidden()) { | 	if (shouldBeHidden != isHidden()) { | ||||||
| 		setVisible(!shouldBeHidden); | 		setVisible(!shouldBeHidden); | ||||||
| 		if (shouldBeHidden) { | 		if (shouldBeHidden) { | ||||||
| 			myEnsureResized(this); | 			SendPendingMoveResizeEvents(this); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -405,7 +405,7 @@ void LayerStackWidget::setCacheImages() { | ||||||
| 	auto bodyCache = QPixmap(), mainMenuCache = QPixmap(); | 	auto bodyCache = QPixmap(), mainMenuCache = QPixmap(); | ||||||
| 	auto specialLayerCache = QPixmap(); | 	auto specialLayerCache = QPixmap(); | ||||||
| 	if (_specialLayer) { | 	if (_specialLayer) { | ||||||
| 		myEnsureResized(_specialLayer); | 		Ui::SendPendingMoveResizeEvents(_specialLayer); | ||||||
| 		auto sides = RectPart::Left | RectPart::Right; | 		auto sides = RectPart::Left | RectPart::Right; | ||||||
| 		if (_specialLayer->y() > 0) { | 		if (_specialLayer->y() > 0) { | ||||||
| 			sides |= RectPart::Top; | 			sides |= RectPart::Top; | ||||||
|  | @ -425,7 +425,7 @@ void LayerStackWidget::setCacheImages() { | ||||||
| 	if (_mainMenu) { | 	if (_mainMenu) { | ||||||
| 		setAttribute(Qt::WA_OpaquePaintEvent, false); | 		setAttribute(Qt::WA_OpaquePaintEvent, false); | ||||||
| 		hideChildren(); | 		hideChildren(); | ||||||
| 		bodyCache = myGrab(App::wnd()->bodyWidget()); | 		bodyCache = Ui::GrabWidget(App::wnd()->bodyWidget()); | ||||||
| 		showChildren(); | 		showChildren(); | ||||||
| 		mainMenuCache = Ui::Shadow::grab(_mainMenu, st::boxRoundShadow, RectPart::Right); | 		mainMenuCache = Ui::Shadow::grab(_mainMenu, st::boxRoundShadow, RectPart::Right); | ||||||
| 	} | 	} | ||||||
|  | @ -733,7 +733,7 @@ void LayerStackWidget::initChildLayer(LayerWidget *layer) { | ||||||
| 	layer->setClosedCallback([this, layer] { onLayerClosed(layer); }); | 	layer->setClosedCallback([this, layer] { onLayerClosed(layer); }); | ||||||
| 	layer->setResizedCallback([this] { onLayerResized(); }); | 	layer->setResizedCallback([this] { onLayerResized(); }); | ||||||
| 	connect(layer, SIGNAL(destroyed(QObject*)), this, SLOT(onLayerDestroyed(QObject*))); | 	connect(layer, SIGNAL(destroyed(QObject*)), this, SLOT(onLayerDestroyed(QObject*))); | ||||||
| 	myEnsureResized(layer); | 	Ui::SendPendingMoveResizeEvents(layer); | ||||||
| 	layer->parentResized(); | 	layer->parentResized(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -539,7 +539,7 @@ void Notification::refreshLang() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Notification::prepareActionsCache() { | void Notification::prepareActionsCache() { | ||||||
| 	auto replyCache = myGrab(_reply); | 	auto replyCache = Ui::GrabWidget(_reply); | ||||||
| 	auto fadeWidth = st::notifyFadeRight.width(); | 	auto fadeWidth = st::notifyFadeRight.width(); | ||||||
| 	auto actionsTop = st::notifyTextTop + st::msgNameFont->height; | 	auto actionsTop = st::notifyTextTop + st::msgNameFont->height; | ||||||
| 	auto replyRight = _replyPadding - st::notifyBorderWidth; | 	auto replyRight = _replyPadding - st::notifyBorderWidth; | ||||||
|  |  | ||||||
|  | @ -105,7 +105,7 @@ public: | ||||||
| 	// This can be used to grab with or without top bar shadow.
 | 	// This can be used to grab with or without top bar shadow.
 | ||||||
| 	// This will be protected when animation preparation will be done inside.
 | 	// This will be protected when animation preparation will be done inside.
 | ||||||
| 	virtual QPixmap grabForShowAnimation(const SectionSlideParams ¶ms) { | 	virtual QPixmap grabForShowAnimation(const SectionSlideParams ¶ms) { | ||||||
| 		return myGrab(this); | 		return Ui::GrabWidget(this); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Attempt to show the required section inside the existing one.
 | 	// Attempt to show the required section inside the existing one.
 | ||||||
|  |  | ||||||
|  | @ -136,8 +136,8 @@ void WarningWidget::startAnimation(bool hiding) { | ||||||
| 	_hiding = hiding; | 	_hiding = hiding; | ||||||
| 	if (_cache.isNull()) { | 	if (_cache.isNull()) { | ||||||
| 		showChildren(); | 		showChildren(); | ||||||
| 		myEnsureResized(this); | 		Ui::SendPendingMoveResizeEvents(this); | ||||||
| 		_cache = myGrab(this, _outer); | 		_cache = Ui::GrabWidget(this, _outer); | ||||||
| 	} | 	} | ||||||
| 	hideChildren(); | 	hideChildren(); | ||||||
| 	_animation.start([this] { | 	_animation.start([this] { | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue