diff options
author | Dan Goodliffe <dan@randomdan.homeip.net> | 2023-03-05 01:59:16 +0000 |
---|---|---|
committer | Dan Goodliffe <dan@randomdan.homeip.net> | 2023-03-05 01:59:16 +0000 |
commit | d4c073a18adaed73973f34c6c39fc15664d9211d (patch) | |
tree | 44536af3af0284ab75eae79ef81a5e4452019269 /assetFactory/style.cpp | |
parent | Add helper operator to perform vec3*mat4 and perspective divide (diff) | |
parent | Remove old hard coded asset factory test, run entirely from XML load and rend... (diff) | |
download | ilt-d4c073a18adaed73973f34c6c39fc15664d9211d.tar.bz2 ilt-d4c073a18adaed73973f34c6c39fc15664d9211d.tar.xz ilt-d4c073a18adaed73973f34c6c39fc15664d9211d.zip |
Merge branch 'model-factory'
Diffstat (limited to 'assetFactory/style.cpp')
-rw-r--r-- | assetFactory/style.cpp | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/assetFactory/style.cpp b/assetFactory/style.cpp new file mode 100644 index 0000000..fc5c34e --- /dev/null +++ b/assetFactory/style.cpp @@ -0,0 +1,46 @@ +#include "style.h" +#include "assetFactory.h" + +void +Style::applyStyle(ModelFactoryMesh & mesh, const StyleStack & parents, const Shape::CreatedFaces & faces) const +{ + if (const auto effectiveColour = getProperty(parents, &Style::colour, + [](auto && style) { + return style->colour.a > 0; + }); + effectiveColour.has_value()) { + for (const auto & face : faces) { + mesh.set_color(face.second, effectiveColour->get()); + } + } +} + +void +Style::applyStyle(ModelFactoryMesh & mesh, const StyleStack & parents, const ModelFactoryMesh::FaceHandle & face) const +{ + if (const auto effectiveColour = getProperty(parents, &Style::colour, + [](auto && style) { + return style->colour.a > 0; + }); + effectiveColour.has_value()) { + mesh.set_color(face, effectiveColour->get()); + } +} + +bool +Style::persist(Persistence::PersistenceStore & store) +{ + struct ColourParser : public Persistence::SelectionV<ColourAlpha> { + using Persistence::SelectionV<ColourAlpha>::SelectionV; + using Persistence::SelectionV<ColourAlpha>::setValue; + void + setValue(std::string && str) override + { + if (auto mf = Persistence::ParseBase::getShared<const AssetFactory>("assetFactory")) { + v = mf->parseColour(str); + } + } + }; + + return STORE_HELPER(colour, ColourParser); +} |