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
path: root/source
diff options
context:
space:
mode:
authorCampbell Barton <ideasman42@gmail.com>2007-03-19 08:09:56 +0300
committerCampbell Barton <ideasman42@gmail.com>2007-03-19 08:09:56 +0300
commit4f5065ac98bc135c20dfc04cf596d6dd19cb214e (patch)
tree7cc2816b6e9c1ac92f7a7f2bd783a0501269be83 /source
parent9477a7bc5c30019dcb1c4b2a3ec646c3b712146f (diff)
addad e new macro - BASE_SELECTABLE for checking if an object is selectable (restrict visible and restrict selected are off and its in the current view layer)
Made "Select Grouped" functions and "Select Linked" use BASE_SELECTABLE macro so they wont select objects they shouldent. Made "Select Grouped" push an undo Made "Select Grouped" and "Select Linked" only push add an UNDO if they make a change to the selection. Fix for own bug. "Select Group" -> Hooks option could crash blender if an objetc hook was in another scene.
Diffstat (limited to 'source')
-rw-r--r--source/blender/include/blendef.h1
-rw-r--r--source/blender/src/editobject.c28
-rw-r--r--source/blender/src/space.c146
3 files changed, 114 insertions, 61 deletions
diff --git a/source/blender/include/blendef.h b/source/blender/include/blendef.h
index 33d3d7fa4c6..20b5f4a5da6 100644
--- a/source/blender/include/blendef.h
+++ b/source/blender/include/blendef.h
@@ -97,6 +97,7 @@
#define TESTBASE(base) ( ((base)->flag & SELECT) && ((base)->lay & G.vd->lay) )
#define TESTBASELIB(base) ( ((base)->flag & SELECT) && ((base)->lay & G.vd->lay) && ((base)->object->id.lib==0))
+#define BASE_SELECTABLE(base) ((base->lay & G.vd->lay) && !(base->object->restrictflag & OB_RESTRICT_SELECT) && !(base->object->restrictflag & OB_RESTRICT_VIEW))
#define FIRSTBASE G.scene->base.first
#define LASTBASE G.scene->base.last
#define BASACT (G.scene->basact)
diff --git a/source/blender/src/editobject.c b/source/blender/src/editobject.c
index 33958b9bcb5..2c0fa20593a 100644
--- a/source/blender/src/editobject.c
+++ b/source/blender/src/editobject.c
@@ -5007,12 +5007,13 @@ void selectlinks(int nr)
Material *mat = NULL, *mat1;
Tex *tex=0;
int a, b;
-
+ short changed = 0;
/* events (nr):
* Object Ipo: 1
* ObData: 2
* Current Material: 3
* Current Texture: 4
+ * DupliGroup: 5
*/
@@ -5042,12 +5043,14 @@ void selectlinks(int nr)
base= FIRSTBASE;
while(base) {
- if(base->lay & G.vd->lay) {
+ if (BASE_SELECTABLE(base) && !(base->flag & SELECT)) {
if(nr==1) {
if(base->object->ipo==ipo) base->flag |= SELECT;
+ changed = 1;
}
else if(nr==2) {
if(base->object->data==obdata) base->flag |= SELECT;
+ changed = 1;
}
else if(nr==3 || nr==4) {
ob= base->object;
@@ -5056,28 +5059,37 @@ void selectlinks(int nr)
mat1= give_current_material(ob, a);
if(nr==3) {
if(mat1==mat) base->flag |= SELECT;
+ changed = 1;
}
else if(mat1 && nr==4) {
for(b=0; b<MAX_MTEX; b++) {
if(mat1->mtex[b]) {
- if(tex==mat1->mtex[b]->tex) base->flag |= SELECT;
+ if(tex==mat1->mtex[b]->tex) {
+ base->flag |= SELECT;
+ changed = 1;
+ }
}
}
}
}
}
else if(nr==5) {
- if(base->object->dup_group==ob->dup_group) base->flag |= SELECT;
+ if(base->object->dup_group==ob->dup_group) {
+ base->flag |= SELECT;
+ changed = 1;
+ }
}
base->object->flag= base->flag;
}
base= base->next;
}
- allqueue(REDRAWVIEW3D, 0);
- allqueue(REDRAWDATASELECT, 0);
- allqueue(REDRAWOOPS, 0);
- BIF_undo_push("Select links");
+ if (changed) {
+ allqueue(REDRAWVIEW3D, 0);
+ allqueue(REDRAWDATASELECT, 0);
+ allqueue(REDRAWOOPS, 0);
+ BIF_undo_push("Select linked");
+ }
}
void image_aspect(void)
diff --git a/source/blender/src/space.c b/source/blender/src/space.c
index 79d0840550c..8404e997486 100644
--- a/source/blender/src/space.c
+++ b/source/blender/src/space.c
@@ -169,7 +169,7 @@
#include "SYS_System.h" /* for the user def menu ... should move elsewhere. */
-
+/* maybe we need this defined somewhere else */
extern void StartKetsjiShell(ScrArea *area, char* startscenename, struct Main* maggie, struct SpaceIpo* sipo,int always_use_expand_framing);
extern void StartKetsjiShellSimulation(ScrArea *area, char* startscenename, struct Main* maggie, struct SpaceIpo* sipo,int always_use_expand_framing);//rcruiz
@@ -652,23 +652,33 @@ static void align_view_to_selected(View3D *v3d)
}
}
-static void select_children(Object *ob, int recursive)
+
+static short select_children(Object *ob, int recursive)
{
+ short changed = 0;
Base *base;
-
- for (base= FIRSTBASE; base; base= base->next)
+
+ for (base= FIRSTBASE; base; base= base->next) {
if (ob == base->object->parent) {
- base->flag |= SELECT;
- base->object->flag |= SELECT;
- if (recursive) select_children(base->object, 1);
+ if (BASE_SELECTABLE(base) && !(base->flag & SELECT)) {
+ base->flag |= SELECT;
+ base->object->flag |= SELECT;
+ changed = 1;
+ }
+
+ if (recursive)
+ changed |= select_children(base->object, 1);
}
+ }
+ return changed;
}
-static void select_parent(void) /* Makes parent active and de-selected OBACT */
+static short select_parent(void) /* Makes parent active and de-selected OBACT */
{
+ short changed = 0;
Base *base, *startbase, *basact=NULL, *oldbasact;
- if (!(OBACT) || !(OBACT->parent)) return;
+ if (!(OBACT) || !(OBACT->parent)) return 0;
BASACT->flag &= (~SELECT);
BASACT->object->flag &= (~SELECT);
startbase= FIRSTBASE;
@@ -689,13 +699,16 @@ static void select_parent(void) /* Makes parent active and de-selected OBACT */
basact->object->flag= basact->flag;
set_active_base(basact);
+ changed = 1;
}
+ return changed;
}
#define GROUP_MENU_MAX 24
-static void select_same_group(Object *ob) /* Select objects in the same group as the active */
+static short select_same_group(Object *ob) /* Select objects in the same group as the active */
{
+ short changed = 0;
Base *base;
Group *group, *ob_groups[GROUP_MENU_MAX];
char str[10 + (24*GROUP_MENU_MAX)];
@@ -703,7 +716,7 @@ static void select_same_group(Object *ob) /* Select objects in the same group as
int group_count=0, menu, i;
if (!ob)
- return;
+ return 0;
for ( group=G.main->group.first;
group && group_count < GROUP_MENU_MAX;
@@ -716,17 +729,18 @@ static void select_same_group(Object *ob) /* Select objects in the same group as
}
if (!group_count)
- return;
+ return 0;
else if (group_count == 1) {
group = ob_groups[0];
for (base= FIRSTBASE; base; base= base->next) {
- if (!(base->flag & SELECT) && object_in_group(base->object, group)) {
+ if (BASE_SELECTABLE(base) && !(base->flag & SELECT) && object_in_group(base->object, group)) {
base->flag |= SELECT;
base->object->flag |= SELECT;
+ changed = 1;
}
}
- return;
+ return changed;
}
/* build the menu. */
@@ -738,94 +752,120 @@ static void select_same_group(Object *ob) /* Select objects in the same group as
menu = pupmenu (str);
if (menu == -1)
- return;
+ return 0;
group = ob_groups[menu];
for (base= FIRSTBASE; base; base= base->next) {
if (!(base->flag & SELECT) && object_in_group(base->object, group)) {
base->flag |= SELECT;
base->object->flag |= SELECT;
+ changed = 1;
}
}
+ return changed;
}
-static void select_object_hooks(Object *ob) /* Select objects in the same group as the active */
+static short select_object_hooks(Object *ob)
{
+ short changed = 0;
Base *base;
ModifierData *md;
HookModifierData *hmd;
if (!ob)
- return;
+ return 0;
for (md = ob->modifiers.first; md; md=md->next) {
if (md->type==eModifierType_Hook) {
hmd= (HookModifierData*) md;
if (hmd->object && !(hmd->object->flag & SELECT)) {
base= object_in_scene(hmd->object, G.scene);
- base->flag |= SELECT;
- base->object->flag |= SELECT;
+ if (base && BASE_SELECTABLE(base)) {
+ base->flag |= SELECT;
+ base->object->flag |= SELECT;
+ changed = 1;
+ }
}
}
}
+ return changed;
}
-static void select_same_parent(Object *ob) /* Select objects woth the same parent as the active (siblings), parent can be NULL also */
+/* Select objects woth the same parent as the active (siblings),
+ * parent can be NULL also */
+static short select_same_parent(Object *ob)
{
+ short changed = 0;
Base *base;
if (!ob)
- return;
+ return 0;
- for (base= FIRSTBASE; base; base= base->next)
- if (base->object->parent==ob->parent) {
+ for (base= FIRSTBASE; base; base= base->next) {
+ if (BASE_SELECTABLE(base) && (base->object->parent==ob->parent) && !(base->flag & SELECT)) {
base->flag |= SELECT;
base->object->flag |= SELECT;
+ changed = 1;
}
+ }
+ return changed;
}
-static void select_same_type(Object *ob) /* Select objects woth the same parent as the active (siblings), parent can be NULL also */
+static short select_same_type(Object *ob)
{
+ short changed = 0;
Base *base;
if (!ob)
- return;
+ return 0;
- for (base= FIRSTBASE; base; base= base->next)
- if (base->object->type==ob->type) {
+ for (base= FIRSTBASE; base; base= base->next) {
+ if (BASE_SELECTABLE(base) && (base->object->type == ob->type) && !(base->flag & SELECT)) {
base->flag |= SELECT;
base->object->flag |= SELECT;
+ changed = 1;
}
+ }
+ return changed;
}
-void select_object_grouped(short nr)
+static short select_same_layer(Object *ob)
{
- Base *base;
+ char changed = 0;
+ Base *base = FIRSTBASE;
- if(nr==6) {
- base= FIRSTBASE;
- while(base) {
- if (base->lay & OBACT->lay) {
- base->flag |= SELECT;
- base->object->flag |= SELECT;
- }
- base= base->next;
+ if (!ob)
+ return 0;
+
+ while(base) {
+ if (BASE_SELECTABLE(base) && (base->lay & ob->lay) && !(base->flag & SELECT)) {
+ base->flag |= SELECT;
+ base->object->flag |= SELECT;
+ changed = 1;
}
+ base= base->next;
+ }
+ return changed;
+}
+
+void select_object_grouped(short nr)
+{
+ short changed = 0;
+ if(nr==1) changed = select_children(OBACT, 1);
+ else if(nr==2) changed = select_children(OBACT, 0);
+ else if(nr==3) changed = select_parent();
+ else if(nr==4) changed = select_same_parent(OBACT);
+ else if(nr==5) changed = select_same_type(OBACT);
+ else if(nr==6) changed = select_same_layer(OBACT);
+ else if(nr==7) changed = select_same_group(OBACT);
+ else if(nr==8) changed = select_object_hooks(OBACT);
+
+ if (changed) {
+ countall();
+ allqueue(REDRAWVIEW3D, 0);
+ allqueue(REDRAWBUTSOBJECT, 0);
+ allspace(REMAKEIPO, 0);
+ allqueue(REDRAWIPO, 0);
+ BIF_undo_push("Select Grouped");
}
- else if(nr==1) select_children(OBACT, 1);
- else if(nr==2) select_children(OBACT, 0);
- else if(nr==3) select_parent();
- else if(nr==4) select_same_parent(OBACT);
- else if(nr==5) select_same_type(OBACT);
- else if(nr==7) select_same_group(OBACT);
- else if(nr==8) select_object_hooks(OBACT);
-
-
-
-
- countall();
- allqueue(REDRAWVIEW3D, 0);
- allqueue(REDRAWBUTSOBJECT, 0);
- allspace(REMAKEIPO, 0);
- allqueue(REDRAWIPO, 0);
}
static void select_object_grouped_menu(void)