summaryrefslogtreecommitdiffstats
path: root/modules/webxr
diff options
context:
space:
mode:
authorDavid Snopek <dsnopek@gmail.com>2023-11-08 14:54:29 -0600
committerDavid Snopek <dsnopek@gmail.com>2023-12-11 09:01:24 -0600
commit275c496bc87f6cf973cfa70bc1bf4a35ecd60d1e (patch)
treea706a50c6db17a1eaf6f4df9f36d305f33c3835b /modules/webxr
parenta311a4b162364d032b03ddf2a0e603ba40615ad7 (diff)
downloadredot-engine-275c496bc87f6cf973cfa70bc1bf4a35ecd60d1e.tar.gz
Add MSAA support for WebXR
Diffstat (limited to 'modules/webxr')
-rw-r--r--modules/webxr/webxr_interface_js.cpp38
1 files changed, 12 insertions, 26 deletions
diff --git a/modules/webxr/webxr_interface_js.cpp b/modules/webxr/webxr_interface_js.cpp
index 47f20ce1a3..828476edfb 100644
--- a/modules/webxr/webxr_interface_js.cpp
+++ b/modules/webxr/webxr_interface_js.cpp
@@ -309,7 +309,7 @@ void WebXRInterfaceJS::uninitialize() {
godot_webxr_uninitialize();
- GLES3::TextureStorage *texture_storage = dynamic_cast<GLES3::TextureStorage *>(RSG::texture_storage);
+ GLES3::TextureStorage *texture_storage = GLES3::TextureStorage::get_singleton();
if (texture_storage != nullptr) {
for (KeyValue<unsigned int, RID> &E : texture_cache) {
// Forcibly mark as not part of a render target so we can free it.
@@ -438,16 +438,11 @@ Projection WebXRInterfaceJS::get_projection_for_view(uint32_t p_view, double p_a
}
bool WebXRInterfaceJS::pre_draw_viewport(RID p_render_target) {
- GLES3::TextureStorage *texture_storage = dynamic_cast<GLES3::TextureStorage *>(RSG::texture_storage);
+ GLES3::TextureStorage *texture_storage = GLES3::TextureStorage::get_singleton();
if (texture_storage == nullptr) {
return false;
}
- GLES3::RenderTarget *rt = texture_storage->get_render_target(p_render_target);
- if (rt == nullptr) {
- return false;
- }
-
// Cache the resources so we don't have to get them from JS twice.
color_texture = _get_color_texture();
depth_texture = _get_depth_texture();
@@ -460,23 +455,9 @@ bool WebXRInterfaceJS::pre_draw_viewport(RID p_render_target) {
//
// See: https://immersive-web.github.io/layers/#xropaquetextures
//
- // This is why we're doing this sort of silly check: if the color and depth
- // textures are the same this frame as last frame, we need to attach them
- // again, despite the fact that the GLuint for them hasn't changed.
- if (rt->overridden.is_overridden && rt->overridden.color == color_texture && rt->overridden.depth == depth_texture) {
- GLES3::Config *config = GLES3::Config::get_singleton();
- bool use_multiview = rt->view_count > 1 && config->multiview_supported;
-
- glBindFramebuffer(GL_FRAMEBUFFER, rt->fbo);
- if (use_multiview) {
- glFramebufferTextureMultiviewOVR(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, rt->color, 0, 0, rt->view_count);
- glFramebufferTextureMultiviewOVR(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, rt->depth, 0, 0, rt->view_count);
- } else {
- glFramebufferTexture2D(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, rt->color, 0);
- glFramebufferTexture2D(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_TEXTURE_2D, rt->depth, 0);
- }
- glBindFramebuffer(GL_FRAMEBUFFER, texture_storage->system_fbo);
- }
+ // So, even if the color and depth textures have the same GLuint as the last
+ // frame, we need to re-attach them again.
+ texture_storage->render_target_set_reattach_textures(p_render_target, true);
return true;
}
@@ -484,7 +465,12 @@ bool WebXRInterfaceJS::pre_draw_viewport(RID p_render_target) {
Vector<BlitToScreen> WebXRInterfaceJS::post_draw_viewport(RID p_render_target, const Rect2 &p_screen_rect) {
Vector<BlitToScreen> blit_to_screen;
- // We don't need to do anything here.
+ GLES3::TextureStorage *texture_storage = GLES3::TextureStorage::get_singleton();
+ if (texture_storage == nullptr) {
+ return blit_to_screen;
+ }
+
+ texture_storage->render_target_set_reattach_textures(p_render_target, false);
return blit_to_screen;
};
@@ -513,7 +499,7 @@ RID WebXRInterfaceJS::_get_texture(unsigned int p_texture_id) {
return cache->get();
}
- GLES3::TextureStorage *texture_storage = dynamic_cast<GLES3::TextureStorage *>(RSG::texture_storage);
+ GLES3::TextureStorage *texture_storage = GLES3::TextureStorage::get_singleton();
if (texture_storage == nullptr) {
return RID();
}