Community Challenge: Post-processing effects

It is about time that we announce another community challenge! This time we’d like to challenge you to create some cool looking post-processing effects. Post-processing effects can be used to control the overall look and feel of the game by rendering the game world and applying various effects in sequence to produce the final result.

Share your post-processing effects here (must be open source) and in January we’ll pick three projects and award the authors with Steam Gift Cards.

Examples of post-processing effects

  • Blur - full screen blur effect (Shadertoy)
  • Vignette - fades the image out towards the edges (Shadertoy)
  • Scanlines - simulates the visible scanlines of an old display (Shadertoy)
  • Chromatic aberration - simulate defects and color shifts in real-world cameras (Shadertoy)
  • Color grading - adjust the color palette to achieve a certain mood or scenario such as time of day (Defold tutorial)
  • Grain - emulate the imperfections of analog film
  • Unreal Engine manual on post-processing effects
  • KinoGlitch video glitch effects for Unity (link)

Post-processing example project by @jhonny.goransson (https://github.com/Jhonnyg/my-public-defold-examples/tree/master/postprocessing). Normal vs Blur example:

Crash course in Defold rendering

In Defold the default render script will draw all components (sprites, tilemaps, particle effects etc) directly to the screen by copying the pixels from the atlas/tilesource texture to the screen using the default materials. From the default render script:

-- render sprites, tilemaps, particle effects etc
render.enable_state(graphics.STATE_BLEND)
render.draw(predicates.tile, camera_world.frustum)
render.draw(predicates.particle, camera_world.frustum)
render.disable_state(graphics.STATE_DEPTH_TEST)

When applying post-processing effects an additional step is introduced where the components are first drawn to an off-screen buffer (a render target) before drawing the entire off-screen buffer to the screen using a mesh (quad) which covers the screen and a custom material which applies the post-processing effect. Example:

-- step 1: render sprites, tilemaps, particle effects etc to a render target named 'my_render_target'
render.set_render_target(my_render_target)
render.enable_state(graphics.STATE_BLEND)
render.draw(predicates.tile, camera_world.frustum)
render.draw(predicates.particle, camera_world.frustum)
render.disable_state(graphics.STATE_DEPTH_TEST)
render.set_render_target(render.RENDER_TARGET_DEFAULT)

-- step 2: render 'my_render_target'  using 'my_material' to a model quad with a material with tag 'my_predicate'
render.enable_texture(0, my_render_target, graphics.BUFFER_TYPE_COLOR0_BIT)
render.enable_material(my_material)
render.draw(my_predicate)
render.disable_material()
render.disable_texture0)

Tutorials and sample projects

Here’s a collection of tutorials and sample projects to get you started:

23 Likes

I would love if this would be extended a bit, because I was very busy lately and there were also Holidays, which instead of ensuring some more time postponed everything :sweat_smile: I am preparing few shaders and maybe few other people have the same as me? :wink:

Yes, sure, let’s extend it to Friday. Did anyone else try this challenge?

I had half forgotten this at times. Could have used a pin job. :pushpin:

I didn’t have any good ideas nor much time but I did manage to make something and more or less learned how post-processing and render targets work along way. This was very helpful: Mastering Render Targets.

After figuring out how to use Lumiere (very nice btw). I ported this cool rain thing from shadertoy to work with it.

HTML5: community-challenges 1.0

I also tried to port rain shader example over but after a lot of trial and error I gave up. :man_shrugging:

7 Likes

Just linking this simple GUI shader example as my entry here:

Will add more post-processing useful for games later on :smiley:

2 Likes

I might not be able to complete it until Friday, but yes, I’m preparing my pixel art post-processing effect.

10 Likes