|  | @@ -1944,12 +1944,15 @@ Vector<uint8_t> Image::get_data() const {
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void Image::create(int p_width, int p_height, bool p_use_mipmaps, Format p_format) {
 | 
	
		
			
				|  |  | -	ERR_FAIL_COND_MSG(p_width <= 0, "Image width must be greater than 0.");
 | 
	
		
			
				|  |  | -	ERR_FAIL_COND_MSG(p_height <= 0, "Image height must be greater than 0.");
 | 
	
		
			
				|  |  | -	ERR_FAIL_COND_MSG(p_width > MAX_WIDTH, "Image width cannot be greater than " + itos(MAX_WIDTH) + ".");
 | 
	
		
			
				|  |  | -	ERR_FAIL_COND_MSG(p_height > MAX_HEIGHT, "Image height cannot be greater than " + itos(MAX_HEIGHT) + ".");
 | 
	
		
			
				|  |  | -	ERR_FAIL_COND_MSG(p_width * p_height > MAX_PIXELS, "Too many pixels for image, maximum is " + itos(MAX_PIXELS));
 | 
	
		
			
				|  |  | -	ERR_FAIL_INDEX_MSG(p_format, FORMAT_MAX, "Image format out of range, please see Image's Format enum.");
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND_MSG(p_width <= 0, "The Image width specified (" + itos(p_width) + " pixels) must be greater than 0 pixels.");
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND_MSG(p_height <= 0, "The Image height specified (" + itos(p_height) + " pixels) must be greater than 0 pixels.");
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND_MSG(p_width > MAX_WIDTH,
 | 
	
		
			
				|  |  | +			"The Image width specified (" + itos(p_width) + " pixels) cannot be greater than " + itos(MAX_WIDTH) + "pixels.");
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND_MSG(p_height > MAX_HEIGHT,
 | 
	
		
			
				|  |  | +			"The Image height specified (" + itos(p_height) + " pixels) cannot be greater than " + itos(MAX_HEIGHT) + "pixels.");
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND_MSG(p_width * p_height > MAX_PIXELS,
 | 
	
		
			
				|  |  | +			"Too many pixels for Image. Maximum is " + itos(MAX_WIDTH) + "x" + itos(MAX_HEIGHT) + " = " + itos(MAX_PIXELS) + "pixels.");
 | 
	
		
			
				|  |  | +	ERR_FAIL_INDEX_MSG(p_format, FORMAT_MAX, "The Image format specified (" + itos(p_format) + ") is out of range. See Image's Format enum.");
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	int mm = 0;
 | 
	
		
			
				|  |  |  	int size = _get_dst_image_size(p_width, p_height, p_format, mm, p_use_mipmaps ? -1 : 0);
 | 
	
	
		
			
				|  | @@ -1967,17 +1970,34 @@ void Image::create(int p_width, int p_height, bool p_use_mipmaps, Format p_forma
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void Image::create(int p_width, int p_height, bool p_use_mipmaps, Format p_format, const Vector<uint8_t> &p_data) {
 | 
	
		
			
				|  |  | -	ERR_FAIL_COND_MSG(p_width <= 0, "Image width must be greater than 0.");
 | 
	
		
			
				|  |  | -	ERR_FAIL_COND_MSG(p_height <= 0, "Image height must be greater than 0.");
 | 
	
		
			
				|  |  | -	ERR_FAIL_COND_MSG(p_width > MAX_WIDTH, "Image width cannot be greater than " + itos(MAX_WIDTH) + ".");
 | 
	
		
			
				|  |  | -	ERR_FAIL_COND_MSG(p_height > MAX_HEIGHT, "Image height cannot be greater than " + itos(MAX_HEIGHT) + ".");
 | 
	
		
			
				|  |  | -	ERR_FAIL_COND_MSG(p_width * p_height > MAX_PIXELS, "Too many pixels for image, maximum is " + itos(MAX_PIXELS));
 | 
	
		
			
				|  |  | -	ERR_FAIL_INDEX_MSG(p_format, FORMAT_MAX, "Image format out of range, please see Image's Format enum.");
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND_MSG(p_width <= 0, "The Image width specified (" + itos(p_width) + " pixels) must be greater than 0 pixels.");
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND_MSG(p_height <= 0, "The Image height specified (" + itos(p_height) + " pixels) must be greater than 0 pixels.");
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND_MSG(p_width > MAX_WIDTH,
 | 
	
		
			
				|  |  | +			"The Image width specified (" + itos(p_width) + " pixels) cannot be greater than " + itos(MAX_WIDTH) + " pixels.");
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND_MSG(p_height > MAX_HEIGHT,
 | 
	
		
			
				|  |  | +			"The Image height specified (" + itos(p_height) + " pixels) cannot be greater than " + itos(MAX_HEIGHT) + " pixels.");
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND_MSG(p_width * p_height > MAX_PIXELS,
 | 
	
		
			
				|  |  | +			"Too many pixels for Image. Maximum is " + itos(MAX_WIDTH) + "x" + itos(MAX_HEIGHT) + " = " + itos(MAX_PIXELS) + "pixels .");
 | 
	
		
			
				|  |  | +	ERR_FAIL_INDEX_MSG(p_format, FORMAT_MAX, "The Image format specified (" + itos(p_format) + ") is out of range. See Image's Format enum.");
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	int mm;
 | 
	
		
			
				|  |  |  	int size = _get_dst_image_size(p_width, p_height, p_format, mm, p_use_mipmaps ? -1 : 0);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	ERR_FAIL_COND_MSG(p_data.size() != size, "Expected data size of " + itos(size) + " bytes in Image::create(), got instead " + itos(p_data.size()) + " bytes.");
 | 
	
		
			
				|  |  | +	if (unlikely(p_data.size() != size)) {
 | 
	
		
			
				|  |  | +		String description_mipmaps;
 | 
	
		
			
				|  |  | +		if (p_use_mipmaps) {
 | 
	
		
			
				|  |  | +			const int num_mipmaps = get_image_required_mipmaps(p_width, p_height, p_format);
 | 
	
		
			
				|  |  | +			if (num_mipmaps != 1) {
 | 
	
		
			
				|  |  | +				description_mipmaps = vformat("with %d mipmaps", num_mipmaps);
 | 
	
		
			
				|  |  | +			} else {
 | 
	
		
			
				|  |  | +				description_mipmaps = "with 1 mipmap";
 | 
	
		
			
				|  |  | +			}
 | 
	
		
			
				|  |  | +		} else {
 | 
	
		
			
				|  |  | +			description_mipmaps = "without mipmaps";
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +		const String description = vformat("%dx%dx%d (%s)", p_width, p_height, get_format_pixel_size(p_format), description_mipmaps);
 | 
	
		
			
				|  |  | +		ERR_FAIL_MSG(vformat("Expected Image data size of %s = %d bytes, got %d bytes instead.", description, size, p_data.size()));
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	height = p_height;
 | 
	
		
			
				|  |  |  	width = p_width;
 |