|  | @@ -246,7 +246,7 @@ std::shared_ptr<const ISharedImage> SDLImageShared::scaleInteger(int factor, SDL
 | 
											
												
													
														|  |  	else
 |  |  	else
 | 
											
												
													
														|  |  		algorithm = EScalingAlgorithm::XBRZ_ALPHA;
 |  |  		algorithm = EScalingAlgorithm::XBRZ_ALPHA;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	auto result = std::make_shared<SDLImageShared>(this, factor, algorithm);
 |  | 
 | 
											
												
													
														|  | 
 |  | +	auto result = SDLImageShared::createScaled(this, factor, algorithm);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	if (surf->format->palette)
 |  |  	if (surf->format->palette)
 | 
											
												
													
														|  |  		SDL_SetSurfacePalette(surf, originalPalette);
 |  |  		SDL_SetSurfacePalette(surf, originalPalette);
 | 
											
										
											
												
													
														|  | @@ -254,28 +254,31 @@ std::shared_ptr<const ISharedImage> SDLImageShared::scaleInteger(int factor, SDL
 | 
											
												
													
														|  |  	return result;
 |  |  	return result;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -SDLImageShared::SDLImageShared(const SDLImageShared * from, int integerScaleFactor, EScalingAlgorithm algorithm)
 |  | 
 | 
											
												
													
														|  | 
 |  | +std::shared_ptr<SDLImageShared> SDLImageShared::createScaled(const SDLImageShared * from, int integerScaleFactor, EScalingAlgorithm algorithm)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  | 
 |  | +	auto self = std::make_shared<SDLImageShared>(nullptr);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  	static tbb::task_arena upscalingArena;
 |  |  	static tbb::task_arena upscalingArena;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	upscalingInProgress = true;
 |  | 
 | 
											
												
													
														|  | 
 |  | +	self->upscalingInProgress = true;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	auto scaler = std::make_shared<SDLImageScaler>(from->surf, Rect(from->margins, from->fullSize), true);
 |  |  	auto scaler = std::make_shared<SDLImageScaler>(from->surf, Rect(from->margins, from->fullSize), true);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	const auto & scalingTask = [this, algorithm, scaler]()
 |  | 
 | 
											
												
													
														|  | 
 |  | +	const auto & scalingTask = [self, algorithm, scaler]()
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  |  		scaler->scaleSurfaceIntegerFactor(GH.screenHandler().getScalingFactor(), algorithm);
 |  |  		scaler->scaleSurfaceIntegerFactor(GH.screenHandler().getScalingFactor(), algorithm);
 | 
											
												
													
														|  | -		surf = scaler->acquireResultSurface();
 |  | 
 | 
											
												
													
														|  | -		fullSize = scaler->getResultDimensions().dimensions();
 |  | 
 | 
											
												
													
														|  | -		margins = scaler->getResultDimensions().topLeft();
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -		upscalingInProgress = false;
 |  | 
 | 
											
												
													
														|  | 
 |  | +		self->surf = scaler->acquireResultSurface();
 | 
											
												
													
														|  | 
 |  | +		self->fullSize = scaler->getResultDimensions().dimensions();
 | 
											
												
													
														|  | 
 |  | +		self->margins = scaler->getResultDimensions().topLeft();
 | 
											
												
													
														|  | 
 |  | +		self->upscalingInProgress = false;
 | 
											
												
													
														|  |  	};
 |  |  	};
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	if(settings["video"]["asyncUpscaling"].Bool())
 |  |  	if(settings["video"]["asyncUpscaling"].Bool())
 | 
											
												
													
														|  |  		upscalingArena.enqueue(scalingTask);
 |  |  		upscalingArena.enqueue(scalingTask);
 | 
											
												
													
														|  |  	else
 |  |  	else
 | 
											
												
													
														|  |  		scalingTask();
 |  |  		scalingTask();
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	return self;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  bool SDLImageShared::isLoading() const
 |  |  bool SDLImageShared::isLoading() const
 | 
											
										
											
												
													
														|  | @@ -352,9 +355,10 @@ Rect SDLImageShared::contentRect() const
 | 
											
												
													
														|  |  	if(upscalingInProgress)
 |  |  	if(upscalingInProgress)
 | 
											
												
													
														|  |  		throw std::runtime_error("Attempt to access images that is still being loaded!");
 |  |  		throw std::runtime_error("Attempt to access images that is still being loaded!");
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	auto tmpMargins = margins;
 |  | 
 | 
											
												
													
														|  | -	auto tmpSize = Point(surf->w, surf->h);
 |  | 
 | 
											
												
													
														|  | -	return Rect(tmpMargins, tmpSize);
 |  | 
 | 
											
												
													
														|  | 
 |  | +	if (!surf)
 | 
											
												
													
														|  | 
 |  | +		return Rect();
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	return Rect(margins, Point(surf->w, surf->h));
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  const SDL_Palette * SDLImageShared::getPalette() const
 |  |  const SDL_Palette * SDLImageShared::getPalette() const
 |