|  | @@ -1306,47 +1306,47 @@ Error Main::setup(const char *execpath, int argc, char *argv[], bool p_second_ph
 | 
	
		
			
				|  |  |  	// always convert to lower case for consistency in the code
 | 
	
		
			
				|  |  |  	rendering_driver = rendering_driver.to_lower();
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	GLOBAL_DEF_BASIC("display/window/size/width", 1024);
 | 
	
		
			
				|  |  | -	ProjectSettings::get_singleton()->set_custom_property_info("display/window/size/width",
 | 
	
		
			
				|  |  | -			PropertyInfo(Variant::INT, "display/window/size/width",
 | 
	
		
			
				|  |  | +	GLOBAL_DEF_BASIC("display/window/size/viewport_width", 1024);
 | 
	
		
			
				|  |  | +	ProjectSettings::get_singleton()->set_custom_property_info("display/window/size/viewport_width",
 | 
	
		
			
				|  |  | +			PropertyInfo(Variant::INT, "display/window/size/viewport_width",
 | 
	
		
			
				|  |  |  					PROPERTY_HINT_RANGE,
 | 
	
		
			
				|  |  |  					"0,7680,or_greater")); // 8K resolution
 | 
	
		
			
				|  |  | -	GLOBAL_DEF_BASIC("display/window/size/height", 600);
 | 
	
		
			
				|  |  | -	ProjectSettings::get_singleton()->set_custom_property_info("display/window/size/height",
 | 
	
		
			
				|  |  | -			PropertyInfo(Variant::INT, "display/window/size/height",
 | 
	
		
			
				|  |  | +	GLOBAL_DEF_BASIC("display/window/size/viewport_height", 600);
 | 
	
		
			
				|  |  | +	ProjectSettings::get_singleton()->set_custom_property_info("display/window/size/viewport_height",
 | 
	
		
			
				|  |  | +			PropertyInfo(Variant::INT, "display/window/size/viewport_height",
 | 
	
		
			
				|  |  |  					PROPERTY_HINT_RANGE,
 | 
	
		
			
				|  |  |  					"0,4320,or_greater")); // 8K resolution
 | 
	
		
			
				|  |  |  	GLOBAL_DEF_BASIC("display/window/size/resizable", true);
 | 
	
		
			
				|  |  |  	GLOBAL_DEF_BASIC("display/window/size/borderless", false);
 | 
	
		
			
				|  |  |  	GLOBAL_DEF_BASIC("display/window/size/fullscreen", false);
 | 
	
		
			
				|  |  |  	GLOBAL_DEF("display/window/size/always_on_top", false);
 | 
	
		
			
				|  |  | -	GLOBAL_DEF("display/window/size/test_width", 0);
 | 
	
		
			
				|  |  | -	ProjectSettings::get_singleton()->set_custom_property_info("display/window/size/test_width",
 | 
	
		
			
				|  |  | +	GLOBAL_DEF("display/window/size/window_width_override", 0);
 | 
	
		
			
				|  |  | +	ProjectSettings::get_singleton()->set_custom_property_info("display/window/size/window_width_override",
 | 
	
		
			
				|  |  |  			PropertyInfo(Variant::INT,
 | 
	
		
			
				|  |  | -					"display/window/size/test_width",
 | 
	
		
			
				|  |  | +					"display/window/size/window_width_override",
 | 
	
		
			
				|  |  |  					PROPERTY_HINT_RANGE,
 | 
	
		
			
				|  |  |  					"0,7680,or_greater")); // 8K resolution
 | 
	
		
			
				|  |  | -	GLOBAL_DEF("display/window/size/test_height", 0);
 | 
	
		
			
				|  |  | -	ProjectSettings::get_singleton()->set_custom_property_info("display/window/size/test_height",
 | 
	
		
			
				|  |  | +	GLOBAL_DEF("display/window/size/window_height_override", 0);
 | 
	
		
			
				|  |  | +	ProjectSettings::get_singleton()->set_custom_property_info("display/window/size/window_height_override",
 | 
	
		
			
				|  |  |  			PropertyInfo(Variant::INT,
 | 
	
		
			
				|  |  | -					"display/window/size/test_height",
 | 
	
		
			
				|  |  | +					"display/window/size/window_height_override",
 | 
	
		
			
				|  |  |  					PROPERTY_HINT_RANGE,
 | 
	
		
			
				|  |  |  					"0,4320,or_greater")); // 8K resolution
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	if (use_custom_res) {
 | 
	
		
			
				|  |  |  		if (!force_res) {
 | 
	
		
			
				|  |  | -			window_size.width = GLOBAL_GET("display/window/size/width");
 | 
	
		
			
				|  |  | -			window_size.height = GLOBAL_GET("display/window/size/height");
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -			if (globals->has_setting("display/window/size/test_width") &&
 | 
	
		
			
				|  |  | -					globals->has_setting("display/window/size/test_height")) {
 | 
	
		
			
				|  |  | -				int tw = globals->get("display/window/size/test_width");
 | 
	
		
			
				|  |  | -				if (tw > 0) {
 | 
	
		
			
				|  |  | -					window_size.width = tw;
 | 
	
		
			
				|  |  | +			window_size.width = GLOBAL_GET("display/window/size/viewport_width");
 | 
	
		
			
				|  |  | +			window_size.height = GLOBAL_GET("display/window/size/viewport_height");
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +			if (globals->has_setting("display/window/size/window_width_override") &&
 | 
	
		
			
				|  |  | +					globals->has_setting("display/window/size/window_height_override")) {
 | 
	
		
			
				|  |  | +				int desired_width = globals->get("display/window/size/window_width_override");
 | 
	
		
			
				|  |  | +				if (desired_width > 0) {
 | 
	
		
			
				|  |  | +					window_size.width = desired_width;
 | 
	
		
			
				|  |  |  				}
 | 
	
		
			
				|  |  | -				int th = globals->get("display/window/size/test_height");
 | 
	
		
			
				|  |  | -				if (th > 0) {
 | 
	
		
			
				|  |  | -					window_size.height = th;
 | 
	
		
			
				|  |  | +				int desired_height = globals->get("display/window/size/window_height_override");
 | 
	
		
			
				|  |  | +				if (desired_height > 0) {
 | 
	
		
			
				|  |  | +					window_size.height = desired_height;
 | 
	
		
			
				|  |  |  				}
 | 
	
		
			
				|  |  |  			}
 | 
	
		
			
				|  |  |  		}
 | 
	
	
		
			
				|  | @@ -2348,8 +2348,8 @@ bool Main::start() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  			String stretch_mode = GLOBAL_DEF_BASIC("display/window/stretch/mode", "disabled");
 | 
	
		
			
				|  |  |  			String stretch_aspect = GLOBAL_DEF_BASIC("display/window/stretch/aspect", "keep");
 | 
	
		
			
				|  |  | -			Size2i stretch_size = Size2i(GLOBAL_DEF_BASIC("display/window/size/width", 0),
 | 
	
		
			
				|  |  | -					GLOBAL_DEF_BASIC("display/window/size/height", 0));
 | 
	
		
			
				|  |  | +			Size2i stretch_size = Size2i(GLOBAL_DEF_BASIC("display/window/size/viewport_width", 0),
 | 
	
		
			
				|  |  | +					GLOBAL_DEF_BASIC("display/window/size/viewport_height", 0));
 | 
	
		
			
				|  |  |  			real_t stretch_scale = GLOBAL_DEF_BASIC("display/window/stretch/scale", 1.0);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  			Window::ContentScaleMode cs_sm = Window::CONTENT_SCALE_MODE_DISABLED;
 |