summaryrefslogtreecommitdiff
path: root/game/scenary
diff options
context:
space:
mode:
authorDan Goodliffe <dan@randomdan.homeip.net>2023-04-23 21:46:21 +0100
committerDan Goodliffe <dan@randomdan.homeip.net>2023-04-26 00:07:19 +0100
commite751ab465bbbf1365ec6e108c64dafd03ce42f1d (patch)
treed0c6dc9cd16ea6cdedc89e575af7b012d935d4cb /game/scenary
parentHandle rendering of RailVehicles through RailVehicleClass instancing (diff)
downloadilt-e751ab465bbbf1365ec6e108c64dafd03ce42f1d.tar.bz2
ilt-e751ab465bbbf1365ec6e108c64dafd03ce42f1d.tar.xz
ilt-e751ab465bbbf1365ec6e108c64dafd03ce42f1d.zip
Pop and complete instanced shadow support
Diffstat (limited to 'game/scenary')
-rw-r--r--game/scenary/foliage.cpp9
1 files changed, 8 insertions, 1 deletions
diff --git a/game/scenary/foliage.cpp b/game/scenary/foliage.cpp
index 35be051..e54dfbd 100644
--- a/game/scenary/foliage.cpp
+++ b/game/scenary/foliage.cpp
@@ -34,6 +34,13 @@ Foliage::render(const SceneShader & shader) const
}
void
-Foliage::shadows(const ShadowMapper &) const
+Foliage::shadows(const ShadowMapper & mapper) const
{
+ if (const auto count = instances.count()) {
+ mapper.dynamicPointInst.use();
+ glBindVertexArray(instanceVAO);
+ glDrawElementsInstanced(
+ bodyMesh->type(), bodyMesh->count(), GL_UNSIGNED_INT, nullptr, static_cast<GLsizei>(count));
+ glBindVertexArray(0);
+ }
}