X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=blender%2Fio_mspgl%2Fscene.py;h=70dbc8c9a7178d19470c5ba3d0ae5e1c2e142250;hb=308dc6b8f5ee1aa3bb8f205e2ed6464749eebbe5;hp=8f4f285b195d3af543b1a2b64c9ef592a626b6d3;hpb=9b371e56adc1d6be89f2d30881c3759a0d5f8eca;p=libs%2Fgl.git diff --git a/blender/io_mspgl/scene.py b/blender/io_mspgl/scene.py index 8f4f285b..70dbc8c9 100644 --- a/blender/io_mspgl/scene.py +++ b/blender/io_mspgl/scene.py @@ -13,7 +13,7 @@ class Instance: self.name = obj.name self.matrix_world = obj.matrix_world self.rotation_mode = obj.rotation_mode - self.prototype = prototype.name + self.prototype = prototype class Scene: def __init__(self, scene, obj_filter=None): @@ -25,6 +25,8 @@ class Scene: self.instances = [] self.blended_instances = [] self.lights = [] + self.realtime_sky = False + self.sun_light = None self.ambient_light = mathutils.Color((0.0, 0.0, 0.0)) self.exposure = scene.view_settings.exposure @@ -43,6 +45,12 @@ class Scene: s = surface_node.inputs["Strength"].default_value self.ambient_light = mathutils.Color(c[:3])*s + self.use_sky = scene.world.use_sky and scene.world.sun_light + self.sun_light = scene.world.sun_light + + self.use_shadow = False + self.use_ibl = False + objects = scene.objects[:] objects.sort(key=lambda o:o.name) if obj_filter: @@ -57,13 +65,19 @@ class Scene: clones = [c for c in objects if is_same_object(o, c)] self.prototypes.append(o) instance_list = self.instances - if o.material_slots and o.material_slots[0].material and o.material_slots[0].material.blend_method=='BLEND': - instance_list = self.blended_instances + if o.material_slots and o.material_slots[0].material: + mat = o.material_slots[0].material + if mat.blend_method=='BLEND': + instance_list = self.blended_instances + if mat.image_based_lighting: + self.use_ibl = True for c in clones: instance_list.append(Instance(c, o)) processed.add(c.name) elif o.type=='LIGHT': self.lights.append(o) + if o.data.use_shadow: + self.use_shadow = True def get_chain(self): result = [] @@ -78,7 +92,7 @@ def get_all_collections(collection): result += get_all_collections(c) return result -def create_scene_from_current(context, *, selected_only=False, visible_only=True): +def create_scene_from_current(ctx, *, selected_only=False, visible_only=True): obj_filters = [] if selected_only: @@ -86,7 +100,7 @@ def create_scene_from_current(context, *, selected_only=False, visible_only=True if visible_only: visible_names = set() - for c in get_all_collections(context.view_layer.layer_collection): + for c in get_all_collections(ctx.context.view_layer.layer_collection): if not c.hide_viewport and not c.collection.hide_viewport: visible_names.update(o.name for o in c.collection.objects) obj_filters.append(lambda o: o.name in visible_names) @@ -97,7 +111,7 @@ def create_scene_from_current(context, *, selected_only=False, visible_only=True if obj_filters: obj_filter = lambda o: all(f(o) for f in obj_filters) - return Scene(context.scene, obj_filter) + return Scene(ctx.context.scene, obj_filter) def create_scene(scene, *, visible_only=True): obj_filter = None