From 4f12a1befc1dd0ff5594fc65bddd0cec9759890c Mon Sep 17 00:00:00 2001 From: ahcorde Date: Tue, 22 Dec 2020 22:34:53 +0100 Subject: [PATCH 1/5] Added render_order to material Signed-off-by: ahcorde --- include/sdf/Material.hh | 8 ++++++++ sdf/1.7/material.sdf | 4 ++++ src/Material.cc | 19 +++++++++++++++++++ src/Material_TEST.cc | 14 ++++++++++++++ test/integration/visual_dom.cc | 1 + test/sdf/material.sdf | 3 ++- 6 files changed, 48 insertions(+), 1 deletion(-) diff --git a/include/sdf/Material.hh b/include/sdf/Material.hh index ac6cb86ef..f95f006eb 100644 --- a/include/sdf/Material.hh +++ b/include/sdf/Material.hh @@ -124,6 +124,14 @@ namespace sdf /// \param[in] _color Emissive color. public: void SetEmissive(const ignition::math::Color &_color) const; + /// \brief Get render order + /// \return Render order + public: float RenderOrder() const; + + /// \brief Set render order + /// \param[in] _renderOrder render order + public: void SetRenderOrder(const float _renderOrder); + /// \brief Get whether dynamic lighting is enabled. The default /// value is true. /// \return False if dynamic lighting should be disabled. diff --git a/sdf/1.7/material.sdf b/sdf/1.7/material.sdf index be398d366..e39497644 100644 --- a/sdf/1.7/material.sdf +++ b/sdf/1.7/material.sdf @@ -25,6 +25,10 @@ + + Set render order for coplanar polygons + + If false, dynamic lighting will be disabled diff --git a/src/Material.cc b/src/Material.cc index df060e9e4..41bf0a0f2 100644 --- a/src/Material.cc +++ b/src/Material.cc @@ -57,6 +57,9 @@ class sdf::MaterialPrivate /// \brief Emissive color public: ignition::math::Color emissive {0, 0, 0, 1}; + /// \brief Render order + public: float renderOrder = 0; + /// \brief Physically Based Rendering (PBR) properties public: std::unique_ptr pbr; @@ -89,6 +92,7 @@ Material::Material(const Material &_material) this->dataPtr->shader = _material.dataPtr->shader; this->dataPtr->normalMap = _material.dataPtr->normalMap; this->dataPtr->lighting = _material.dataPtr->lighting; + this->dataPtr->renderOrder = _material.dataPtr->renderOrder; this->dataPtr->doubleSided = _material.dataPtr->doubleSided; this->dataPtr->ambient = _material.dataPtr->ambient; this->dataPtr->diffuse = _material.dataPtr->diffuse; @@ -207,6 +211,9 @@ Errors Material::Load(sdf::ElementPtr _sdf) } } + this->dataPtr->renderOrder = _sdf->Get("render_order", + this->dataPtr->renderOrder).first; + this->dataPtr->ambient = _sdf->Get("ambient", this->dataPtr->ambient).first; @@ -284,6 +291,18 @@ void Material::SetEmissive(const ignition::math::Color &_color) const this->dataPtr->emissive = _color; } +////////////////////////////////////////////////// +float Material::RenderOrder() const +{ + return this->dataPtr->renderOrder; +} + +////////////////////////////////////////////////// +void Material::SetRenderOrder(const float _renderOrder) +{ + this->dataPtr->renderOrder = _renderOrder; +} + ////////////////////////////////////////////////// bool Material::Lighting() const { diff --git a/src/Material_TEST.cc b/src/Material_TEST.cc index 4f4972c1f..2e1c4b8a8 100644 --- a/src/Material_TEST.cc +++ b/src/Material_TEST.cc @@ -30,6 +30,7 @@ TEST(DOMMaterial, Construction) EXPECT_EQ(ignition::math::Color(0, 0, 0, 1), material.Specular()); EXPECT_EQ(ignition::math::Color(0, 0, 0, 1), material.Emissive()); EXPECT_TRUE(material.Lighting()); + EXPECT_EQ(0, material.RenderOrder()); EXPECT_FALSE(material.DoubleSided()); EXPECT_EQ(nullptr, material.Element()); EXPECT_EQ("", material.ScriptUri()); @@ -49,6 +50,7 @@ TEST(DOMMaterial, MoveConstructor) material.SetSpecular(ignition::math::Color(0.3f, 0.4f, 0.5f, 0.7f)); material.SetEmissive(ignition::math::Color(0.4f, 0.5f, 0.6f, 0.8f)); material.SetLighting(false); + material.SetRenderOrder(2); material.SetDoubleSided(true); material.SetScriptUri("banana"); material.SetScriptName("orange"); @@ -65,6 +67,7 @@ TEST(DOMMaterial, MoveConstructor) material2.Emissive()); EXPECT_FALSE(material2.Lighting()); EXPECT_TRUE(material2.DoubleSided()); + EXPECT_EQ(2, material2.RenderOrder()); EXPECT_EQ("banana", material2.ScriptUri()); EXPECT_EQ("orange", material2.ScriptName()); EXPECT_EQ(sdf::ShaderType::VERTEX, material2.Shader()); @@ -82,6 +85,7 @@ TEST(DOMMaterial, CopyConstructor) material.SetSpecular(ignition::math::Color(0.3f, 0.4f, 0.5f, 0.7f)); material.SetEmissive(ignition::math::Color(0.4f, 0.5f, 0.6f, 0.8f)); material.SetLighting(false); + material.SetRenderOrder(4); material.SetDoubleSided(true); material.SetScriptUri("banana"); material.SetScriptName("orange"); @@ -98,6 +102,7 @@ TEST(DOMMaterial, CopyConstructor) material2.Emissive()); EXPECT_FALSE(material2.Lighting()); EXPECT_TRUE(material2.DoubleSided()); + EXPECT_EQ(4, material2.RenderOrder()); EXPECT_EQ("banana", material2.ScriptUri()); EXPECT_EQ("orange", material2.ScriptName()); EXPECT_EQ(sdf::ShaderType::VERTEX, material2.Shader()); @@ -115,6 +120,7 @@ TEST(DOMMaterial, AssignmentOperator) material.SetSpecular(ignition::math::Color(0.3f, 0.4f, 0.5f, 0.7f)); material.SetEmissive(ignition::math::Color(0.4f, 0.5f, 0.6f, 0.8f)); material.SetLighting(false); + material.SetRenderOrder(4); material.SetDoubleSided(true); material.SetScriptUri("banana"); material.SetScriptName("orange"); @@ -132,6 +138,7 @@ TEST(DOMMaterial, AssignmentOperator) material2.Emissive()); EXPECT_FALSE(material2.Lighting()); EXPECT_TRUE(material2.DoubleSided()); + EXPECT_EQ(4, material2.RenderOrder()); EXPECT_EQ("banana", material2.ScriptUri()); EXPECT_EQ("orange", material2.ScriptName()); EXPECT_EQ(sdf::ShaderType::VERTEX, material2.Shader()); @@ -149,6 +156,7 @@ TEST(DOMMaterial, MoveAssignmentOperator) material.SetSpecular(ignition::math::Color(0.3f, 0.4f, 0.5f, 0.7f)); material.SetEmissive(ignition::math::Color(0.4f, 0.5f, 0.6f, 0.8f)); material.SetLighting(false); + material.SetRenderOrder(4); material.SetDoubleSided(true); material.SetScriptUri("banana"); material.SetScriptName("orange"); @@ -165,6 +173,7 @@ TEST(DOMMaterial, MoveAssignmentOperator) material2.Emissive()); EXPECT_FALSE(material2.Lighting()); EXPECT_TRUE(material2.DoubleSided()); + EXPECT_EQ(4, material2.RenderOrder()); EXPECT_EQ("banana", material2.ScriptUri()); EXPECT_EQ("orange", material2.ScriptName()); EXPECT_EQ(sdf::ShaderType::VERTEX, material2.Shader()); @@ -215,6 +224,10 @@ TEST(DOMMaterial, Set) material.SetLighting(false); EXPECT_FALSE(material.Lighting()); + EXPECT_EQ(0, material.RenderOrder()); + material.SetRenderOrder(5); + EXPECT_EQ(5, material.RenderOrder()); + EXPECT_FALSE(material.DoubleSided()); material.SetDoubleSided(true); EXPECT_TRUE(material.DoubleSided()); @@ -256,6 +269,7 @@ TEST(DOMMaterial, Set) EXPECT_EQ(ignition::math::Color(0.3f, 0.4f, 0.5f, 0.7f), moved.Specular()); EXPECT_EQ(ignition::math::Color(0.4f, 0.5f, 0.6f, 0.8f), moved.Emissive()); EXPECT_FALSE(moved.Lighting()); + EXPECT_EQ(5, moved.RenderOrder()); EXPECT_TRUE(moved.DoubleSided()); EXPECT_EQ("uri", moved.ScriptUri()); EXPECT_EQ("name", moved.ScriptName()); diff --git a/test/integration/visual_dom.cc b/test/integration/visual_dom.cc index dd7d27fcc..c45f21d41 100644 --- a/test/integration/visual_dom.cc +++ b/test/integration/visual_dom.cc @@ -122,6 +122,7 @@ TEST(DOMVisual, Material) EXPECT_EQ(ignition::math::Color(1.0f, 0.0f, 0.2f, 1.0f), mat->Emissive()); EXPECT_FALSE(mat->Lighting()); EXPECT_TRUE(mat->DoubleSided()); + EXPECT_FLOAT_EQ(5.1, mat->RenderOrder()); EXPECT_EQ(sdf::ShaderType::VERTEX, mat->Shader()); EXPECT_EQ("myuri", mat->ScriptUri()); EXPECT_EQ("myname", mat->ScriptName()); diff --git a/test/sdf/material.sdf b/test/sdf/material.sdf index f43e4e6ed..106e5afdc 100644 --- a/test/sdf/material.sdf +++ b/test/sdf/material.sdf @@ -1,5 +1,5 @@ - + @@ -9,6 +9,7 @@ 0.7 0.3 0.5 0.9 1.0 0.0 0.2 1.0 false + 5.1 true From 3ebeb1bbcbb0c15b21ce42454a19bd1f00528468 Mon Sep 17 00:00:00 2001 From: ahcorde Date: Tue, 22 Dec 2020 22:43:29 +0100 Subject: [PATCH 2/5] Improved description of render order Signed-off-by: ahcorde --- sdf/1.7/material.sdf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sdf/1.7/material.sdf b/sdf/1.7/material.sdf index e39497644..5e861b847 100644 --- a/sdf/1.7/material.sdf +++ b/sdf/1.7/material.sdf @@ -26,7 +26,7 @@ - Set render order for coplanar polygons + Set render order for coplanar polygons. The higher value will be rendered on top of the other coplanar polygons From 16e7c99a914a06758d71dad18259163d4d9241fe Mon Sep 17 00:00:00 2001 From: ahcorde Date: Tue, 22 Dec 2020 23:40:31 +0100 Subject: [PATCH 3/5] Fix compiler warnings Signed-off-by: ahcorde --- src/Material_TEST.cc | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/Material_TEST.cc b/src/Material_TEST.cc index 2e1c4b8a8..115a56849 100644 --- a/src/Material_TEST.cc +++ b/src/Material_TEST.cc @@ -30,7 +30,7 @@ TEST(DOMMaterial, Construction) EXPECT_EQ(ignition::math::Color(0, 0, 0, 1), material.Specular()); EXPECT_EQ(ignition::math::Color(0, 0, 0, 1), material.Emissive()); EXPECT_TRUE(material.Lighting()); - EXPECT_EQ(0, material.RenderOrder()); + EXPECT_FLOAT_EQ(0, material.RenderOrder()); EXPECT_FALSE(material.DoubleSided()); EXPECT_EQ(nullptr, material.Element()); EXPECT_EQ("", material.ScriptUri()); @@ -67,7 +67,7 @@ TEST(DOMMaterial, MoveConstructor) material2.Emissive()); EXPECT_FALSE(material2.Lighting()); EXPECT_TRUE(material2.DoubleSided()); - EXPECT_EQ(2, material2.RenderOrder()); + EXPECT_FLOAT_EQ(2.0, material2.RenderOrder()); EXPECT_EQ("banana", material2.ScriptUri()); EXPECT_EQ("orange", material2.ScriptName()); EXPECT_EQ(sdf::ShaderType::VERTEX, material2.Shader()); @@ -102,7 +102,7 @@ TEST(DOMMaterial, CopyConstructor) material2.Emissive()); EXPECT_FALSE(material2.Lighting()); EXPECT_TRUE(material2.DoubleSided()); - EXPECT_EQ(4, material2.RenderOrder()); + EXPECT_FLOAT_EQ(4, material2.RenderOrder()); EXPECT_EQ("banana", material2.ScriptUri()); EXPECT_EQ("orange", material2.ScriptName()); EXPECT_EQ(sdf::ShaderType::VERTEX, material2.Shader()); @@ -138,7 +138,7 @@ TEST(DOMMaterial, AssignmentOperator) material2.Emissive()); EXPECT_FALSE(material2.Lighting()); EXPECT_TRUE(material2.DoubleSided()); - EXPECT_EQ(4, material2.RenderOrder()); + EXPECT_FLOAT_EQ(4, material2.RenderOrder()); EXPECT_EQ("banana", material2.ScriptUri()); EXPECT_EQ("orange", material2.ScriptName()); EXPECT_EQ(sdf::ShaderType::VERTEX, material2.Shader()); @@ -173,7 +173,7 @@ TEST(DOMMaterial, MoveAssignmentOperator) material2.Emissive()); EXPECT_FALSE(material2.Lighting()); EXPECT_TRUE(material2.DoubleSided()); - EXPECT_EQ(4, material2.RenderOrder()); + EXPECT_FLOAT_EQ(4, material2.RenderOrder()); EXPECT_EQ("banana", material2.ScriptUri()); EXPECT_EQ("orange", material2.ScriptName()); EXPECT_EQ(sdf::ShaderType::VERTEX, material2.Shader()); @@ -224,9 +224,9 @@ TEST(DOMMaterial, Set) material.SetLighting(false); EXPECT_FALSE(material.Lighting()); - EXPECT_EQ(0, material.RenderOrder()); + EXPECT_FLOAT_EQ(0, material.RenderOrder()); material.SetRenderOrder(5); - EXPECT_EQ(5, material.RenderOrder()); + EXPECT_FLOAT_EQ(5, material.RenderOrder()); EXPECT_FALSE(material.DoubleSided()); material.SetDoubleSided(true); @@ -269,7 +269,7 @@ TEST(DOMMaterial, Set) EXPECT_EQ(ignition::math::Color(0.3f, 0.4f, 0.5f, 0.7f), moved.Specular()); EXPECT_EQ(ignition::math::Color(0.4f, 0.5f, 0.6f, 0.8f), moved.Emissive()); EXPECT_FALSE(moved.Lighting()); - EXPECT_EQ(5, moved.RenderOrder()); + EXPECT_FLOAT_EQ(5, moved.RenderOrder()); EXPECT_TRUE(moved.DoubleSided()); EXPECT_EQ("uri", moved.ScriptUri()); EXPECT_EQ("name", moved.ScriptName()); From 7058431f588a98eb41601f3cfabeac38e2bcbaeb Mon Sep 17 00:00:00 2001 From: ahcorde Date: Tue, 22 Dec 2020 23:40:45 +0100 Subject: [PATCH 4/5] Fixed render order type Signed-off-by: ahcorde --- sdf/1.7/material.sdf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sdf/1.7/material.sdf b/sdf/1.7/material.sdf index 5e861b847..285b476ee 100644 --- a/sdf/1.7/material.sdf +++ b/sdf/1.7/material.sdf @@ -25,7 +25,7 @@ - + Set render order for coplanar polygons. The higher value will be rendered on top of the other coplanar polygons From 430e76f5f9a234b41a452ed0adfa137bb1761def Mon Sep 17 00:00:00 2001 From: ahcorde Date: Wed, 23 Dec 2020 11:52:16 +0100 Subject: [PATCH 5/5] Fixed windows warning Signed-off-by: ahcorde --- test/integration/visual_dom.cc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/integration/visual_dom.cc b/test/integration/visual_dom.cc index c45f21d41..eae5306c7 100644 --- a/test/integration/visual_dom.cc +++ b/test/integration/visual_dom.cc @@ -122,7 +122,7 @@ TEST(DOMVisual, Material) EXPECT_EQ(ignition::math::Color(1.0f, 0.0f, 0.2f, 1.0f), mat->Emissive()); EXPECT_FALSE(mat->Lighting()); EXPECT_TRUE(mat->DoubleSided()); - EXPECT_FLOAT_EQ(5.1, mat->RenderOrder()); + EXPECT_FLOAT_EQ(5.1f, mat->RenderOrder()); EXPECT_EQ(sdf::ShaderType::VERTEX, mat->Shader()); EXPECT_EQ("myuri", mat->ScriptUri()); EXPECT_EQ("myname", mat->ScriptName());