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:
authorDalai Felinto <dfelinto@gmail.com>2019-03-12 23:28:45 +0300
committerDalai Felinto <dfelinto@gmail.com>2019-03-12 23:28:45 +0300
commit9054b39b27c4198f436329f78af43fe3f3175508 (patch)
tree02312a157f6c3baa167c3a7660fdfb088f59118b /source/blender/makesrna
parentdb5ca11d802ef987c34fd24f14db1b1427f5898e (diff)
Fix T62436: New added Torus won't appear in Local View
I had to add a region3d.local_view_add(ob) for the API.
Diffstat (limited to 'source/blender/makesrna')
-rw-r--r--source/blender/makesrna/intern/rna_space_api.c57
1 files changed, 57 insertions, 0 deletions
diff --git a/source/blender/makesrna/intern/rna_space_api.c b/source/blender/makesrna/intern/rna_space_api.c
index 947eff8c73b..db5467d2802 100644
--- a/source/blender/makesrna/intern/rna_space_api.c
+++ b/source/blender/makesrna/intern/rna_space_api.c
@@ -26,6 +26,8 @@
#ifdef RNA_RUNTIME
#include "BKE_global.h"
+#include "BKE_layer.h"
+#include "BKE_report.h"
#include "ED_screen.h"
#include "ED_text.h"
@@ -57,6 +59,54 @@ static void rna_RegionView3D_update(ID *id, RegionView3D *rv3d, bContext *C)
}
}
+static void rna_RegionView3D_local_view_add(
+ ID *id, RegionView3D *rv3d,
+ bContext *C,
+ ReportList *reports,
+ Object *ob)
+{
+ bScreen *sc = (bScreen *)id;
+
+ ScrArea *sa;
+ ARegion *ar;
+
+ area_region_from_regiondata(sc, rv3d, &sa, &ar);
+
+ if (sa && ar && sa->spacetype == SPACE_VIEW3D) {
+ View3D *v3d = sa->spacedata.first;
+
+ if (v3d->localvd == NULL) {
+ BKE_report(reports, RPT_ERROR, "3D Viewport not in local view");
+ return;
+ }
+
+ wmWindowManager *wm = CTX_wm_manager(C);
+ wmWindow *win;
+
+ for (win = wm->windows.first; win; win = win->next) {
+ if (WM_window_get_active_screen(win) == sc) {
+ Scene *scene = WM_window_get_active_scene(win);
+ ViewLayer *view_layer = WM_window_get_active_view_layer(win);
+
+ Base *base = BKE_view_layer_base_find(view_layer, ob);
+ if (base) {
+ base->local_view_bits |= v3d->local_view_uuid;
+ ED_area_tag_redraw(sa);
+ DEG_id_tag_update(&scene->id, ID_RECALC_BASE_FLAGS);
+ }
+ else {
+ BKE_reportf(reports,
+ RPT_WARNING,
+ "Object %s not in view layer %s",
+ ob->id.name + 2,
+ view_layer->name);
+ }
+ break;
+ }
+ }
+ }
+}
+
static void rna_SpaceTextEditor_region_location_from_cursor(
ID *id, SpaceText *st,
int line, int column, int r_pixel_pos[2])
@@ -75,10 +125,17 @@ static void rna_SpaceTextEditor_region_location_from_cursor(
void RNA_api_region_view3d(StructRNA *srna)
{
FunctionRNA *func;
+ PropertyRNA *parm;
func = RNA_def_function(srna, "update", "rna_RegionView3D_update");
RNA_def_function_flag(func, FUNC_USE_SELF_ID | FUNC_USE_CONTEXT);
RNA_def_function_ui_description(func, "Recalculate the view matrices");
+
+ func = RNA_def_function(srna, "local_view_add", "rna_RegionView3D_local_view_add");
+ RNA_def_function_flag(func, FUNC_USE_SELF_ID | FUNC_USE_CONTEXT | FUNC_USE_REPORTS);
+ parm = RNA_def_pointer(func, "object", "Object", "Object", "Object to add to current local view");
+ RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
+ RNA_def_function_ui_description(func, "Add object to viewport's local view");
}
void RNA_api_space_node(StructRNA *srna)