Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Screen space effects + 16× MSAA cause blurry screen #50992

Open
everythingandnothingdev opened this issue Jul 28, 2021 · 6 comments
Open

Screen space effects + 16× MSAA cause blurry screen #50992

everythingandnothingdev opened this issue Jul 28, 2021 · 6 comments

Comments

@everythingandnothingdev
Copy link

everythingandnothingdev commented Jul 28, 2021

Godot version

3.3.2.stable

System information

Windows 10, Vulkan, RTX 2080

Issue description

MSAA appears to mistakenly cause blurry screen when screen space effects are enabled. FXAA does not have the same problem.

MSAA 16x, SSAO OFF, SS Reflections OFF

image

MSAA 16x, SSAO ON, SS Reflections OFF

image

MSAA 16x, SSAO OFF, SS Reflections ON

image

Steps to reproduce

  1. Enable MSAA to 16x in project settings
  2. Add a WorldEnvironment node to scene
  3. Either enable Ssao or Ss Reflections

Minimal reproduction project

No response

@Calinou
Copy link
Member

Calinou commented Jul 29, 2021

Due to how it's implemented as a combination of 4× MSAA and 4× SSAA by the graphics driver, 16× MSAA causes various issues and will likely be removed. This leaves 8× MSAA as the highest supported option, which is very demanding already (given the overall higher requirements of the Vulkan renderer compared to Godot 3.x's GLES3 and GLES2). It's surprising that the editor doesn't freeze completely on your end 🙂

For performing offline rendering (e.g. for promotional media), it's a better idea to use 8× MSAA, render at a higher resolution then downscale the image/video manually. This is effectively a form of supersampling, and will also smooth out transparency/specular aliasing in a way that MSAA doesn't.

@everythingandnothingdev
Copy link
Author

This bug is for 3.3.2, not Vulkan.

@SirQuartz
Copy link
Contributor

SirQuartz commented Jul 29, 2021

This bug is for 3.3.2, not Vulkan.

The outcome is the same regardless of whether or not you use Vulkan, GLES3, DirectX, or any 3D rendering API. Because of how 16x MSAA works, it's extremely excessive and expensive to render in real-time, not to mention it causes a lot of issues. MSAA is a method of supersampling, which by its very nature, is expensive. 16x MSAA should definitely be removed as an option altogether, it's basically redundant anyway. With 16x MSAA you're effectively rendering at 16x the resolution in some parts of the image, so if your game is at a 1080p resolution of 1920x1080, and you're using 16x MSAA you're actually effectively rendering at 30720x17280 in some parts of the image, which is just ridiculous.

I think there are other options for anti-aliasing that the engine could add like TAA, which is in almost every game out there these days. It's a more modern implementation of anti-aliasing and uses a fraction of the rendering power that MSAA does while also providing near-identical quality in parts of the picture with no motion. SMAA would also be a nice addition.

@Calinou
Copy link
Member

Calinou commented Jul 29, 2021

With 16x MSAA you're effectively rendering at 16x the resolution in some parts of the image, so if your game is at a 1080p resolution of 1920x1080, and you're using 16x MSAA you're actually effectively rendering at 30720x17280 in some parts of the image, which is just ridiculous.

16× MSAA is internally 4× SSAA + 4× MSAA in most graphics drivers, so it would internally render at 3840×2160 (+ 4× MSAA on top), not 30720x17280.

Some graphics drivers allow choosing 2× SSAA + 8× MSAA as a cheaper alternative, but it's never the default when using "16× MSAA" in an application in my experience.

I think there are other options for anti-aliasing that the engine could add like TAA, which is in almost every game out there these days. It's a more modern implementation of anti-aliasing and uses a fraction of the rendering power that MSAA does while also providing near-identical quality in parts of the picture with no motion. SMAA would also be a nice addition.

See godotengine/godot-proposals#2779. TAA is planned in a future 4.x release, but not 4.0 as it requires significant changes to the renderer to expose motion vectors.

Edit: TAA was added in 4.0 by #61319.

@Calinou
Copy link
Member

Calinou commented Oct 7, 2021

@everythingandnothingdev Can you reproduce this when using 8× MSAA instead of 16× MSAA?

@everythingandnothingdev
Copy link
Author

No, like you said it only happens on 16x

@Calinou Calinou modified the milestones: 4.0, 3.5 Oct 8, 2021
@Calinou Calinou modified the milestones: 3.5, 3.x Dec 2, 2022
@Calinou Calinou added documentation and removed bug labels Dec 2, 2022
@Calinou Calinou changed the title Screen space effects + MSAA cause blurry screen Screen space effects + 16× MSAA cause blurry screen Dec 2, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants