pgraph: fix LightAttrib.compose resulting in wrong on_light values

This commit is contained in:
rdb 2018-01-26 14:30:21 +01:00
parent f2cf391a2e
commit d6cf575225
2 changed files with 77 additions and 0 deletions

View File

@ -841,6 +841,9 @@ compose_impl(const RenderAttrib *other) const {
lobj->attrib_ref();
}
// This is needed since _sorted_on_lights is not yet populated.
new_attrib->_sort_seq = UpdateSeq::old();
return return_new(new_attrib);
}

View File

@ -0,0 +1,74 @@
from panda3d import core
# Some dummy lights we can use for our light attributes.
spot = core.NodePath(core.Spotlight("spot"))
point = core.NodePath(core.PointLight("point"))
ambient = core.NodePath(core.AmbientLight("ambient"))
def test_lightattrib_compose_add():
# Tests a case in which a child node adds another light.
lattr1 = core.LightAttrib.make()
lattr1 = lattr1.add_on_light(spot)
lattr2 = core.LightAttrib.make()
lattr2 = lattr2.add_on_light(point)
lattr3 = lattr1.compose(lattr2)
assert lattr3.get_num_on_lights() == 2
assert spot in lattr3.on_lights
assert point in lattr3.on_lights
def test_lightattrib_compose_subtract():
# Tests a case in which a child node disables a light.
lattr1 = core.LightAttrib.make()
lattr1 = lattr1.add_on_light(spot)
lattr1 = lattr1.add_on_light(point)
lattr2 = core.LightAttrib.make()
lattr2 = lattr2.add_off_light(ambient)
lattr2 = lattr2.add_off_light(point)
lattr3 = lattr1.compose(lattr2)
assert lattr3.get_num_on_lights() == 1
assert spot in lattr3.on_lights
assert point not in lattr3.on_lights
assert ambient not in lattr3.on_lights
def test_lightattrib_compose_both():
# Tests a case in which a child node both enables and disables a light.
lattr1 = core.LightAttrib.make()
lattr1 = lattr1.add_on_light(spot)
lattr1 = lattr1.add_on_light(point)
lattr2 = core.LightAttrib.make()
lattr2 = lattr2.add_on_light(ambient)
lattr2 = lattr2.add_on_light(spot)
lattr2 = lattr2.add_off_light(point)
lattr3 = lattr1.compose(lattr2)
assert lattr3.get_num_on_lights() == 2
assert spot in lattr3.on_lights
assert point not in lattr3.on_lights
assert ambient in lattr3.on_lights
def test_lightattrib_compose_alloff():
# Tests a case in which a child node disables all lights.
lattr1 = core.LightAttrib.make()
lattr1 = lattr1.add_on_light(spot)
lattr1 = lattr1.add_on_light(point)
assert lattr1.get_num_on_lights() == 2
lattr2 = core.LightAttrib.make_all_off()
assert lattr2.has_all_off()
lattr3 = lattr1.compose(lattr2)
assert lattr3.get_num_on_lights() == 0
assert lattr3.get_num_off_lights() == 0
assert lattr3.has_all_off()