mirror of
				https://github.com/luanti-org/luanti.git
				synced 2025-10-25 05:35:25 +02:00 
			
		
		
		
	Allow shaders with disabled post processing pipeline (#14338)
- Allow disabling of the post processing pipeline while leaving shaders enabled - Also disable post processing on Android by default
This commit is contained in:
		| @@ -401,7 +401,8 @@ anisotropic_filter (Anisotropic filtering) bool false | |||||||
| # | # | ||||||
| #    * None - No antialiasing (default) | #    * None - No antialiasing (default) | ||||||
| # | # | ||||||
| #    * FSAA - Hardware-provided full-screen antialiasing (incompatible with shaders) | #    * FSAA - Hardware-provided full-screen antialiasing | ||||||
|  | #             (incompatible with Post Processing and Undersampling) | ||||||
| #             A.K.A multi-sample antialiasing (MSAA) | #             A.K.A multi-sample antialiasing (MSAA) | ||||||
| #             Smoothens out block edges but does not affect the insides of textures. | #             Smoothens out block edges but does not affect the insides of textures. | ||||||
| #             A restart is required to change this option. | #             A restart is required to change this option. | ||||||
| @@ -557,12 +558,17 @@ shadow_sky_body_orbit_tilt (Sky Body Orbit Tilt) float 0.0 -60.0 60.0 | |||||||
|  |  | ||||||
| [**Post Processing] | [**Post Processing] | ||||||
|  |  | ||||||
|  | #    Enables the post processing pipeline. | ||||||
|  | # | ||||||
|  | #    Requires: shaders | ||||||
|  | enable_post_processing (Enable Post Processing) bool true | ||||||
|  |  | ||||||
| #    Enables Hable's 'Uncharted 2' filmic tone mapping. | #    Enables Hable's 'Uncharted 2' filmic tone mapping. | ||||||
| #    Simulates the tone curve of photographic film and how this approximates the | #    Simulates the tone curve of photographic film and how this approximates the | ||||||
| #    appearance of high dynamic range images. Mid-range contrast is slightly | #    appearance of high dynamic range images. Mid-range contrast is slightly | ||||||
| #    enhanced, highlights and shadows are gradually compressed. | #    enhanced, highlights and shadows are gradually compressed. | ||||||
| # | # | ||||||
| #    Requires: shaders | #    Requires: shaders, enable_post_processing | ||||||
| tone_mapping (Filmic tone mapping) bool false | tone_mapping (Filmic tone mapping) bool false | ||||||
|  |  | ||||||
| #    Enable automatic exposure correction | #    Enable automatic exposure correction | ||||||
| @@ -570,14 +576,14 @@ tone_mapping (Filmic tone mapping) bool false | |||||||
| #    automatically adjust to the brightness of the scene, | #    automatically adjust to the brightness of the scene, | ||||||
| #    simulating the behavior of human eye. | #    simulating the behavior of human eye. | ||||||
| # | # | ||||||
| #    Requires: shaders | #    Requires: shaders, enable_post_processing | ||||||
| enable_auto_exposure (Enable Automatic Exposure) bool false | enable_auto_exposure (Enable Automatic Exposure) bool false | ||||||
|  |  | ||||||
| #    Set the exposure compensation in EV units. | #    Set the exposure compensation in EV units. | ||||||
| #    Value of 0.0 (default) means no exposure compensation. | #    Value of 0.0 (default) means no exposure compensation. | ||||||
| #    Range: from -1 to 1.0 | #    Range: from -1 to 1.0 | ||||||
| # | # | ||||||
| #    Requires: shaders, enable_auto_exposure | #    Requires: shaders, enable_post_processing, enable_auto_exposure | ||||||
| exposure_compensation (Exposure compensation) float 0.0 -1.0 1.0 | exposure_compensation (Exposure compensation) float 0.0 -1.0 1.0 | ||||||
|  |  | ||||||
| [**Bloom] | [**Bloom] | ||||||
| @@ -585,7 +591,7 @@ exposure_compensation (Exposure compensation) float 0.0 -1.0 1.0 | |||||||
| #    Set to true to enable bloom effect. | #    Set to true to enable bloom effect. | ||||||
| #    Bright colors will bleed over the neighboring objects. | #    Bright colors will bleed over the neighboring objects. | ||||||
| # | # | ||||||
| #    Requires: shaders | #    Requires: shaders, enable_post_processing | ||||||
| enable_bloom (Enable Bloom) bool false | enable_bloom (Enable Bloom) bool false | ||||||
|  |  | ||||||
| #    Set to true to render debugging breakdown of the bloom effect. | #    Set to true to render debugging breakdown of the bloom effect. | ||||||
| @@ -593,27 +599,27 @@ enable_bloom (Enable Bloom) bool false | |||||||
| #    top-left - processed base image, top-right - final image | #    top-left - processed base image, top-right - final image | ||||||
| #    bottom-left - raw base image, bottom-right - bloom texture. | #    bottom-left - raw base image, bottom-right - bloom texture. | ||||||
| # | # | ||||||
| #    Requires: shaders, enable_bloom | #    Requires: shaders, enable_post_processing, enable_bloom | ||||||
| enable_bloom_debug (Enable Bloom Debug) bool false | enable_bloom_debug (Enable Bloom Debug) bool false | ||||||
|  |  | ||||||
| #    Defines how much bloom is applied to the rendered image | #    Defines how much bloom is applied to the rendered image | ||||||
| #    Smaller values make bloom more subtle | #    Smaller values make bloom more subtle | ||||||
| #    Range: from 0.01 to 1.0, default: 0.05 | #    Range: from 0.01 to 1.0, default: 0.05 | ||||||
| # | # | ||||||
| #    Requires: shaders, enable_bloom | #    Requires: shaders, enable_post_processing, enable_bloom | ||||||
| bloom_intensity (Bloom Intensity) float 0.05 0.01 1.0 | bloom_intensity (Bloom Intensity) float 0.05 0.01 1.0 | ||||||
|  |  | ||||||
| #    Defines the magnitude of bloom overexposure. | #    Defines the magnitude of bloom overexposure. | ||||||
| #    Range: from 0.1 to 10.0, default: 1.0 | #    Range: from 0.1 to 10.0, default: 1.0 | ||||||
| # | # | ||||||
| #    Requires: shaders, enable_bloom | #    Requires: shaders, enable_post_processing, enable_bloom | ||||||
| bloom_strength_factor (Bloom Strength Factor) float 1.0 0.1 10.0 | bloom_strength_factor (Bloom Strength Factor) float 1.0 0.1 10.0 | ||||||
|  |  | ||||||
| #    Logical value that controls how far the bloom effect spreads | #    Logical value that controls how far the bloom effect spreads | ||||||
| #    from the bright objects. | #    from the bright objects. | ||||||
| #    Range: from 0.1 to 8, default: 1 | #    Range: from 0.1 to 8, default: 1 | ||||||
| # | # | ||||||
| #    Requires: shaders, enable_bloom | #    Requires: shaders, enable_post_processing, enable_bloom | ||||||
| bloom_radius (Bloom Radius) float 1 0.1 8 | bloom_radius (Bloom Radius) float 1 0.1 8 | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -106,7 +106,7 @@ void UpscaleStep::run(PipelineContext &context) | |||||||
| std::unique_ptr<RenderStep> create3DStage(Client *client, v2f scale) | std::unique_ptr<RenderStep> create3DStage(Client *client, v2f scale) | ||||||
| { | { | ||||||
| 	RenderStep *step = new Draw3D(); | 	RenderStep *step = new Draw3D(); | ||||||
| 	if (g_settings->getBool("enable_shaders")) { | 	if (g_settings->getBool("enable_shaders") && g_settings->getBool("enable_post_processing")) { | ||||||
| 		RenderPipeline *pipeline = new RenderPipeline(); | 		RenderPipeline *pipeline = new RenderPipeline(); | ||||||
| 		pipeline->addStep(pipeline->own(std::unique_ptr<RenderStep>(step))); | 		pipeline->addStep(pipeline->own(std::unique_ptr<RenderStep>(step))); | ||||||
| 
 | 
 | ||||||
| @@ -131,7 +131,7 @@ RenderStep* addUpscaling(RenderPipeline *pipeline, RenderStep *previousStep, v2f | |||||||
| 		return previousStep; | 		return previousStep; | ||||||
| 
 | 
 | ||||||
| 	// When shaders are enabled, post-processing pipeline takes care of rescaling
 | 	// When shaders are enabled, post-processing pipeline takes care of rescaling
 | ||||||
| 	if (g_settings->getBool("enable_shaders")) | 	if (g_settings->getBool("enable_shaders") && g_settings->getBool("enable_post_processing")) | ||||||
| 		return previousStep; | 		return previousStep; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -248,6 +248,7 @@ void set_default_settings() | |||||||
| 	settings->setDefault("minimap_double_scan_height", "true"); | 	settings->setDefault("minimap_double_scan_height", "true"); | ||||||
| 
 | 
 | ||||||
| 	// Effects
 | 	// Effects
 | ||||||
|  | 	settings->setDefault("enable_post_processing", "true"); | ||||||
| 	settings->setDefault("directional_colored_fog", "true"); | 	settings->setDefault("directional_colored_fog", "true"); | ||||||
| 	settings->setDefault("inventory_items_animations", "false"); | 	settings->setDefault("inventory_items_animations", "false"); | ||||||
| 	settings->setDefault("mip_map", "false"); | 	settings->setDefault("mip_map", "false"); | ||||||
| @@ -497,6 +498,7 @@ void set_default_settings() | |||||||
| 	settings->setDefault("active_block_range", "2"); | 	settings->setDefault("active_block_range", "2"); | ||||||
| 	settings->setDefault("viewing_range", "50"); | 	settings->setDefault("viewing_range", "50"); | ||||||
| 	settings->setDefault("leaves_style", "simple"); | 	settings->setDefault("leaves_style", "simple"); | ||||||
|  | 	settings->setDefault("enable_post_processing", "false"); | ||||||
| 	settings->setDefault("curl_verify_cert", "false"); | 	settings->setDefault("curl_verify_cert", "false"); | ||||||
| 
 | 
 | ||||||
| 	// Apply settings according to screen size
 | 	// Apply settings according to screen size
 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user