Merge pull request #44668 from clayjohn/VULKAN-downsample

Use cubemap downsampler for reflection mipmaps
This commit is contained in:
Rémi Verschelde 2021-01-20 20:41:47 +01:00 committed by GitHub
commit a9b151c664
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -183,13 +183,11 @@ void RendererSceneRenderRD::_create_reflection_importance_sample(ReflectionData
void RendererSceneRenderRD::_update_reflection_mipmaps(ReflectionData &rd, int p_start, int p_end) { void RendererSceneRenderRD::_update_reflection_mipmaps(ReflectionData &rd, int p_start, int p_end) {
for (int i = p_start; i < p_end; i++) { for (int i = p_start; i < p_end; i++) {
for (int j = 0; j < rd.layers[i].mipmaps.size() - 1; j++) { for (int j = 0; j < rd.layers[i].views.size() - 1; j++) {
for (int k = 0; k < 6; k++) { RID view = rd.layers[i].views[j];
RID view = rd.layers[i].mipmaps[j].views[k]; RID texture = rd.layers[i].views[j + 1];
RID texture = rd.layers[i].mipmaps[j + 1].views[k]; Size2i size = rd.layers[i].mipmaps[j + 1].size;
Size2i size = rd.layers[i].mipmaps[j + 1].size; storage->get_effects()->cubemap_downsample(view, texture, size);
storage->get_effects()->make_mipmap(view, texture, size);
}
} }
} }
} }