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--release/scripts/modules/bpy_extras/object_utils.py5
-rw-r--r--source/blender/makesrna/intern/rna_space_api.c57
2 files changed, 62 insertions, 0 deletions
diff --git a/release/scripts/modules/bpy_extras/object_utils.py b/release/scripts/modules/bpy_extras/object_utils.py
index 5f3d6fbc50f..f020431c6bb 100644
--- a/release/scripts/modules/bpy_extras/object_utils.py
+++ b/release/scripts/modules/bpy_extras/object_utils.py
@@ -133,6 +133,11 @@ def object_data_add(context, obdata, operator=None, name=None):
obj_new.select_set(True)
obj_new.matrix_world = add_object_align_init(context, operator)
+ space_data = context.space_data
+ if space_data.type == 'VIEW_3D':
+ if space_data.local_view:
+ space_data.region_3d.local_view_add(obj_new)
+
if obj_act and obj_act.mode == 'EDIT' and obj_act.type == obj_new.type:
bpy.ops.mesh.select_all(action='DESELECT')
obj_act.select_set(True)
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)