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:
authorBrecht Van Lommel <brechtvanlommel@gmail.com>2019-02-21 13:32:52 +0300
committerBrecht Van Lommel <brechtvanlommel@gmail.com>2019-02-21 14:08:01 +0300
commitd542c6a5f3ea7b668c46d9dade20d0af23c090b2 (patch)
tree2dd6446a3ed898c4bcb9b69b45c4ef79f82bbae0 /source/blender/editors/space_view3d/view3d_view.c
parent1bfbfa281046b9d600a1604794fce3aadd7f5cf7 (diff)
Fix T61786: local view not exiting correctly after recent changes.
Diffstat (limited to 'source/blender/editors/space_view3d/view3d_view.c')
-rw-r--r--source/blender/editors/space_view3d/view3d_view.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/source/blender/editors/space_view3d/view3d_view.c b/source/blender/editors/space_view3d/view3d_view.c
index 03965aed5b9..43f8a966ea0 100644
--- a/source/blender/editors/space_view3d/view3d_view.c
+++ b/source/blender/editors/space_view3d/view3d_view.c
@@ -1266,18 +1266,23 @@ static void view3d_localview_exit(
const Depsgraph *depsgraph,
wmWindowManager *wm,
wmWindow *win,
+ ViewLayer *view_layer,
ScrArea *sa,
const bool frame_selected,
const int smooth_viewtx)
{
- ARegion *ar;
View3D *v3d = sa->spacedata.first;
- Object *camera_old, *camera_new;
if (v3d->localvd == NULL) return;
- camera_old = v3d->camera;
- camera_new = v3d->localvd->camera;
+ for (Base *base = FIRSTBASE(view_layer); base; base = base->next) {
+ if (base->local_view_bits & v3d->local_view_uuid) {
+ base->local_view_bits &= ~v3d->local_view_uuid;
+ }
+ }
+
+ Object *camera_old = v3d->camera;
+ Object *camera_new = v3d->localvd->camera;
v3d->local_view_uuid = 0;
v3d->camera = v3d->localvd->camera;
@@ -1285,7 +1290,7 @@ static void view3d_localview_exit(
MEM_freeN(v3d->localvd);
v3d->localvd = NULL;
- for (ar = sa->regionbase.first; ar; ar = ar->next) {
+ for (ARegion *ar = sa->regionbase.first; ar; ar = ar->next) {
if (ar->regiontype == RGN_TYPE_WINDOW) {
RegionView3D *rv3d = ar->regiondata;
@@ -1335,7 +1340,7 @@ static int localview_exec(bContext *C, wmOperator *op)
bool changed;
if (v3d->localvd) {
- view3d_localview_exit(depsgraph, wm, win, sa, frame_selected, smooth_viewtx);
+ view3d_localview_exit(depsgraph, wm, win, view_layer, sa, frame_selected, smooth_viewtx);
changed = true;
}
else {