Adding the render target, cant see a noticeable difference visually.
const renderTarget = new WebGLRenderTarget(width, height);
const composer = new EffectComposer(renderer, renderTarget);
const normalRender = new RenderPass(scene, cameraManager.camera);
const adaptiveToneMapping = new AdaptiveToneMappingPass(true, width);
adaptiveToneMapping.needsSwap = true;
const gamma = new ShaderPass(GammaCorrectionShader);
composer.addPass(normalRender);
composer.addPass(adaptiveToneMapping);
composer.addPass(bloomPass);
Adding GammaCorrectionShader causes banding and looks like a toonshader, without GammaCorrectionShader the scene looks very dark.
Adding AdaptiveToneMapping doesnt do anything. Scene still looks dark.
I should add I was using Varunesc postprocessing npm package before switching back to THREE after an update, should I switch back? Is the THREE effect composer pipeline buggy?
Sorry to necro, finding a load of dead ends on this when using Bloom Pass I also noticed the colour banding then when I tried Gamma Correction Pass on its own I also found colour banding. Seems the stack is bugged out…
Thanks, just switched to it and now my colour space looks correct, no more hideous colour banding with Bloom or Gamma Correction pass. The post processing stack in Three.js should be replaced by pmndrs post processing stack imo!
The key thing in getting rid of banding (or the easiest way, at least) is to ensure all render targets use >=16 bits of precision. By default they use 8 bits, and it’s more efficient for older devices but also much harder to avoid precision problems.
I’m a big fan of what Raoul is doing with pmndrs/postprocessing, it’s good work. The project is still evolving actively though, with a bunch of breaking changes (compared to the original EffectComposer API) planned for v7 – including requiring WebGL 2. I think it would be best to leave the base three.js post-processing alone until pmndrs/postprocessing v7 has stabilized, and decide next steps from there.
vanruesc is currently adding a new pipeline API for V7, he’s been working on adding MRT for while now.
at some point i think it would make sense for threejs to recognize postprocessing. this project is doing good, this is an actively maintained composer with a clear roadmap and obvious benefits (not just the uber shader, per mesh selection, alpha background, color management, stencil, there are numerous improvements currently). whatever the plan is for 2023, i hope you all can get in touch.
There is no official discussion at Github yet but I personally favor the new node material as the basis for the upcoming post processing. sunag has already done some terrific work with the node material this year and I believe we can expand the new system towards post-processing like the former node material.
The idea is to use the new node syntax to define passes similar to how we define lights now. Meaning without any specific shader language and depedencies to the actual 3D API. The respective WebGL or WebGPU node builder can then construct the final shader based on the material and post processing definitions. Expect to see some examples of this next year.
I’d love to have this discussion (on GitHub or elsewhere), yes.
I suspect that composing shaders with NodeMaterial, and composing passes with the proposed render pipelines in pmndrs/postprocessing, are two orthogonal features and we can do both if we choose.
I do worry that the official EffectComposer does not get the fixes and features it needs lately, and there is no one investing in it enough to make hard decisions about improving its API. Support for HDR, color management, WebXR, etc. are just not moving at all (and that’s no one’s fault, it all takes time). Raoul is putting in work here, and I think it’s worth trying to support that if we can.
FWIW I have been making issues and pull requests to pmndrs/postprocessing, and building three-filmic on top of its EffectPass. It has a clear roadmap that I’m excited about.
I personally favor the new node material as the basis for the upcoming post processing. sunag has already done some terrific work with the node material this year and I believe we can expand the new system towards post-processing like the former node material.
I’m looking forward to node materials, but I’m worried about the prospect of post processing getting integrated deeper into three. I think that node materials and post processing are different and complex enough to be separate systems. Is there any thread that explains the reasoning behind mixing them together?
The idea is to use the new node syntax to define passes similar to how we define lights now. Meaning without any specific shader language and depedencies to the actual 3D API. The respective WebGL or WebGPU node builder can then construct the final shader based on the material and post processing definitions. Expect to see some examples of this next year.
I’m excited for the demos and curious to see what the post processing definitions will look like. However, I don’t think node materials can truly be language-agnostic when WebGPU and WebGL support different feature sets.
I don’t want to appear overbearing, but I think that foundational libraries like three should be flexible, open and extensible. Integrating complex systems like post processing into three seems wrong to me because it goes against the principle of separation of concerns. The same applies to WebXR and dynamic shadows. In my opinion, those systems should be modular components with the option to replace them with something else. Not only would this further encourage community efforts to build great plugins for three, but it would allow three to focus on providing a solid API that covers abstractions for all WebGL/WebGPU features. Three could, of course, still provide default solutions for advanced modules, but those should be built on top of it, not into it.
Ah ok, I thought it might be the FloatType and HalfFloatType constants but wasn’t sure. I guess it’s a problem in my shader then thank you so much for the quick reply!