- # Add a colorcurve with linear response to convert into sRGB color space
- ss = Statement("colorcurve")
- ss.sub.append(Statement("brightness_response", 1.0))
- ss.sub.append(Statement("srgb"))
- seq_res.statements.append(ss)
+ scene_res = resources[scene.name+".scene"]
+ lighting_res = resources[scene.name+".lightn"]
+
+ any_opaque = False
+ any_blended = False
+ s = scene
+ while s:
+ if s.instances:
+ any_opaque = True
+ if s.blended_instances:
+ any_blended = True
+ s = s.background_set
+
+ if any_opaque:
+ ss = Statement("step", "", "content")
+ ss.sub.append(Statement("depth_test", Token("LEQUAL")))
+ ss.sub.append(seq_res.create_reference_statement("lighting", lighting_res))
+ ss.sub.append(seq_res.create_reference_statement("scene", scene_res))
+ seq_res.statements.append(ss)
+
+ if any_blended:
+ ss = Statement("step", "blended", "content")
+ ss.sub.append(Statement("depth_test", Token("LEQUAL")))
+ ss.sub.append(seq_res.create_reference_statement("lighting", lighting_res))
+ ss.sub.append(seq_res.create_reference_statement("scene", scene_res))
+ seq_res.statements.append(ss)
+
+ if scene.use_ao:
+ ss = Statement("ambient_occlusion")
+ ss.sub.append(Statement("occlusion_radius", scene.ao_distance))
+ ss.sub.append(Statement("samples", scene.ao_samples))
+ seq_res.statements.append(ss)
+
+ if scene.use_hdr:
+ seq_res.statements.append(Statement("bloom"))
+ ss = Statement("colorcurve")
+ ss.sub.append(Statement("exposure_adjust", scene.exposure))
+ ss.sub.append(Statement("srgb"))
+ seq_res.statements.append(ss)
+ else:
+ # Add a colorcurve with linear response to convert into sRGB color space
+ ss = Statement("colorcurve")
+ ss.sub.append(Statement("brightness_response", 1.0))
+ ss.sub.append(Statement("srgb"))
+ seq_res.statements.append(ss)