Allow stopping LimitedLoopsEmoji on last frame.
This commit is contained in:
		
							parent
							
								
									6e3cc8c769
								
							
						
					
					
						commit
						335f8050d9
					
				
					 3 changed files with 32 additions and 8 deletions
				
			
		|  | @ -383,20 +383,28 @@ PaintFrameResult Cache::paintCurrentFrame( | |||
| 		return {}; | ||||
| 	} | ||||
| 	const auto first = context.internal.forceFirstFrame; | ||||
| 	if (!first) { | ||||
| 	auto last = context.internal.forceLastFrame; | ||||
| 	if (!first && !last) { | ||||
| 		const auto now = context.paused ? 0 : context.now; | ||||
| 		const auto finishes = now ? currentFrameFinishes() : 0; | ||||
| 		if (finishes && now >= finishes) { | ||||
| 			++_frame; | ||||
| 			if (_finished && _frame == _frames) { | ||||
| 				_frame = 0; | ||||
| 				if (context.internal.overrideFirstWithLastFrame) { | ||||
| 					last = true; | ||||
| 				} | ||||
| 			} | ||||
| 			_shown = now; | ||||
| 		} else if (!_shown) { | ||||
| 			_shown = now; | ||||
| 		} | ||||
| 	} | ||||
| 	const auto index = first ? 0 : std::min(_frame, _frames - 1); | ||||
| 	const auto index = first | ||||
| 		? 0 | ||||
| 		: last | ||||
| 		? (_frames - 1) | ||||
| 		: std::min(_frame, _frames - 1); | ||||
| 	const auto info = frame(index); | ||||
| 	const auto size = _size / style::DevicePixelRatio(); | ||||
| 	const auto rect = QRect(context.position, QSize(size, size)); | ||||
|  |  | |||
|  | @ -70,9 +70,11 @@ bool FirstFrameEmoji::readyInDefaultState() { | |||
| 
 | ||||
| LimitedLoopsEmoji::LimitedLoopsEmoji( | ||||
| 	std::unique_ptr<CustomEmoji> wrapped, | ||||
| 	int limit) | ||||
| 	int limit, | ||||
| 	bool stopOnLast) | ||||
| : _wrapped(std::move(wrapped)) | ||||
| , _limit(limit) { | ||||
| , _limit(limit) | ||||
| , _stopOnLast(stopOnLast) { | ||||
| } | ||||
| 
 | ||||
| QString LimitedLoopsEmoji::entityData() { | ||||
|  | @ -91,10 +93,18 @@ void LimitedLoopsEmoji::paint(QPainter &p, const Context &context) { | |||
| 		} | ||||
| 	} | ||||
| 	if (_played == _limit) { | ||||
| 		const auto was = context.internal.forceFirstFrame; | ||||
| 		context.internal.forceFirstFrame = true; | ||||
| 		const auto wasFirst = context.internal.forceFirstFrame; | ||||
| 		const auto wasLast = context.internal.forceLastFrame; | ||||
| 		(_stopOnLast | ||||
| 			? context.internal.forceLastFrame | ||||
| 			: context.internal.forceFirstFrame) = true; | ||||
| 		_wrapped->paint(p, context); | ||||
| 		context.internal.forceFirstFrame = was; | ||||
| 		context.internal.forceFirstFrame = wasFirst; | ||||
| 		context.internal.forceLastFrame = wasLast; | ||||
| 	} else if (_played + 1 == _limit && _inLoop && _stopOnLast) { | ||||
| 		const auto wasLast = context.internal.overrideFirstWithLastFrame; | ||||
| 		_wrapped->paint(p, context); | ||||
| 		context.internal.overrideFirstWithLastFrame = wasLast; | ||||
| 	} else { | ||||
| 		_wrapped->paint(p, context); | ||||
| 	} | ||||
|  |  | |||
|  | @ -31,6 +31,8 @@ struct CustomEmojiPaintContext { | |||
| 	mutable struct { | ||||
| 		bool colorized = false; | ||||
| 		bool forceFirstFrame = false; | ||||
| 		bool forceLastFrame = false; | ||||
| 		bool overrideFirstWithLastFrame = false; | ||||
| 	} internal; | ||||
| }; | ||||
| 
 | ||||
|  | @ -85,7 +87,10 @@ private: | |||
| 
 | ||||
| class LimitedLoopsEmoji final : public CustomEmoji { | ||||
| public: | ||||
| 	LimitedLoopsEmoji(std::unique_ptr<CustomEmoji> wrapped, int limit); | ||||
| 	LimitedLoopsEmoji( | ||||
| 		std::unique_ptr<CustomEmoji> wrapped, | ||||
| 		int limit, | ||||
| 		bool stopOnLast = false); | ||||
| 
 | ||||
| 	QString entityData() override; | ||||
| 	void paint(QPainter &p, const Context &context) override; | ||||
|  | @ -98,6 +103,7 @@ private: | |||
| 	const int _limit = 0; | ||||
| 	int _played = 0; | ||||
| 	bool _inLoop = false; | ||||
| 	bool _stopOnLast = false; | ||||
| 
 | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 John Preston
						John Preston