Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--source/blender/blenkernel/intern/depsgraph.c29
-rw-r--r--source/blender/makesrna/intern/rna_screen.c6
2 files changed, 30 insertions, 5 deletions
diff --git a/source/blender/blenkernel/intern/depsgraph.c b/source/blender/blenkernel/intern/depsgraph.c
index ed396fb32e3..c6cfaaf2bcb 100644
--- a/source/blender/blenkernel/intern/depsgraph.c
+++ b/source/blender/blenkernel/intern/depsgraph.c
@@ -2088,17 +2088,36 @@ static void dag_current_scene_layers(Main *bmain, ListBase *lb)
for (win = wm->windows.first; win; win = win->next) {
if (win->screen && win->screen->scene->theDag) {
Scene *scene = win->screen->scene;
-
+ DagSceneLayer *dsl;
+
if (scene->id.flag & LIB_DOIT) {
- DagSceneLayer *dsl = MEM_mallocN(sizeof(DagSceneLayer), "dag scene layer");
-
+ dsl = MEM_mallocN(sizeof(DagSceneLayer), "dag scene layer");
+
BLI_addtail(lb, dsl);
-
+
dsl->scene = scene;
dsl->layer = BKE_screen_visible_layers(win->screen, scene);
-
+
scene->id.flag &= ~LIB_DOIT;
}
+ else {
+ /* It is possible that multiple windows shares the same scene
+ * and have different layers visible.
+ *
+ * Here we deal with such cases by squashing layers bits from
+ * multiple windoew to the DagSceneLayer.
+ *
+ * TODO(sergey): Such a lookup could be optimized perhaps,
+ * however should be fine for now since we usually have only
+ * few open windows.
+ */
+ for (dsl = lb->first; dsl; dsl = dsl->next) {
+ if (dsl->scene == scene) {
+ dsl->layer |= BKE_screen_visible_layers(win->screen, scene);
+ break;
+ }
+ }
+ }
}
}
}
diff --git a/source/blender/makesrna/intern/rna_screen.c b/source/blender/makesrna/intern/rna_screen.c
index 85d57811187..5f652601637 100644
--- a/source/blender/makesrna/intern/rna_screen.c
+++ b/source/blender/makesrna/intern/rna_screen.c
@@ -56,6 +56,7 @@ EnumPropertyItem region_type_items[] = {
#ifdef RNA_RUNTIME
#include "BKE_global.h"
+#include "BKE_depsgraph.h"
#include "UI_view2d.h"
@@ -141,6 +142,11 @@ static void rna_Area_type_update(bContext *C, PointerRNA *ptr)
ED_area_newspace(C, sa, sa->butspacetype);
ED_area_tag_redraw(sa);
+ /* It is possible that new layers becomes visible. */
+ if (sa->spacetype == SPACE_VIEW3D) {
+ DAG_on_visible_update(CTX_data_main(C), FALSE);
+ }
+
CTX_wm_window_set(C, prevwin);
CTX_wm_area_set(C, prevsa);
CTX_wm_region_set(C, prevar);