diff options
author | Dan Goodliffe <dan@randomdan.homeip.net> | 2023-04-23 21:46:21 +0100 |
---|---|---|
committer | Dan Goodliffe <dan@randomdan.homeip.net> | 2023-04-26 00:07:19 +0100 |
commit | e751ab465bbbf1365ec6e108c64dafd03ce42f1d (patch) | |
tree | d0c6dc9cd16ea6cdedc89e575af7b012d935d4cb /game/scenary/foliage.cpp | |
parent | Handle rendering of RailVehicles through RailVehicleClass instancing (diff) | |
download | ilt-e751ab465bbbf1365ec6e108c64dafd03ce42f1d.tar.bz2 ilt-e751ab465bbbf1365ec6e108c64dafd03ce42f1d.tar.xz ilt-e751ab465bbbf1365ec6e108c64dafd03ce42f1d.zip |
Pop and complete instanced shadow support
Diffstat (limited to 'game/scenary/foliage.cpp')
-rw-r--r-- | game/scenary/foliage.cpp | 9 |
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); + } } |