auto clean when edit shape

master
Christophe SEUX 2023-01-24 22:54:40 +01:00
parent 73e9fa2cd9
commit 32abe225f3
13 changed files with 30 additions and 26 deletions

View File

@ -314,6 +314,7 @@ class BW_OT_paste_bone_groups(Operator):
return {'FINISHED'} return {'FINISHED'}
class BW_OT_add_folder(Operator): class BW_OT_add_folder(Operator):
bl_idname = 'bonewidget.add_folder' bl_idname = 'bonewidget.add_folder'
bl_label = "Add Folder" bl_label = "Add Folder"
@ -421,10 +422,6 @@ class BW_OT_create_widget(Operator):
def poll(cls, context): def poll(cls, context):
return ctx.bone and ctx.active_widget return ctx.bone and ctx.active_widget
def invoke(self, context, event):
self.symmetrize = ctx.prefs.symmetrize
return self.execute(context)
def execute(self, context): def execute(self, context):
folder = ctx.active_folder folder = ctx.active_folder
blend = folder.get_widget_path(folder.active_widget) blend = folder.get_widget_path(folder.active_widget)
@ -488,6 +485,8 @@ class BW_OT_edit_widget(Operator):
bl_label = "Edit Widget" bl_label = "Edit Widget"
bl_options = {'REGISTER', 'UNDO'} bl_options = {'REGISTER', 'UNDO'}
clean: BoolProperty(name='Clean', default=True)
@classmethod @classmethod
def poll(cls, context): def poll(cls, context):
return ctx.bone and ctx.bone.custom_shape return ctx.bone and ctx.bone.custom_shape
@ -495,8 +494,12 @@ class BW_OT_edit_widget(Operator):
def execute(self, context): def execute(self, context):
#ctx._rig = ctx.rig #ctx._rig = ctx.rig
widgets = ctx.selected_widgets widgets = ctx.selected_widgets
bones = ctx.selected_bones
rig = ctx.rig rig = ctx.rig
prefs = ctx.prefs
if self.clean:
bpy.ops.bonewidget.clean_widget()
bpy.ops.object.mode_set(mode='OBJECT') bpy.ops.object.mode_set(mode='OBJECT')
bpy.ops.object.select_all(action='DESELECT') bpy.ops.object.select_all(action='DESELECT')
@ -507,10 +510,12 @@ class BW_OT_edit_widget(Operator):
ctx.widget_layer_col.exclude = False ctx.widget_layer_col.exclude = False
ctx.widget_layer_col.hide_viewport = False ctx.widget_layer_col.hide_viewport = False
for w in widgets: for bone in bones:
link_to_col(w, ctx.widget_col) if not bone.custom_shape:
w.select_set(True) continue
context.view_layer.objects.active = w #link_to_col(w, ctx.widget_col)
bone.custom_shape.select_set(True)
context.view_layer.objects.active = bone.custom_shape
bpy.ops.object.mode_set(mode='EDIT') bpy.ops.object.mode_set(mode='EDIT')
@ -523,10 +528,10 @@ class BW_OT_return_to_rig(Operator):
bl_label = "Return to rig" bl_label = "Return to rig"
bl_options = {'REGISTER', 'UNDO'} bl_options = {'REGISTER', 'UNDO'}
symmetrize: BoolProperty(name='Symmetrize', default=True) clean: BoolProperty(name='Clean', default=True)
def invoke(self, context, event): def invoke(self, context, event):
self.symmetrize = ctx.prefs.symmetrize self.symmetrize = ctx.prefs.auto_symmetrize
return self.execute(context) return self.execute(context)
def execute(self, context): def execute(self, context):
@ -553,9 +558,8 @@ class BW_OT_return_to_rig(Operator):
for b in rig.pose.bones: for b in rig.pose.bones:
b.bone.select = b in bones+[bone] b.bone.select = b in bones+[bone]
if self.symmetrize: if self.clean:
for b in bones: bpy.ops.bonewidget.clean_widget()
symmetrize_bone_shape(b, prefix=ctx.prefs.prefix)
return {'FINISHED'} return {'FINISHED'}
@ -703,7 +707,7 @@ class BW_OT_clean_widget(Operator):
return context.object and context.object.mode == 'POSE' return context.object and context.object.mode == 'POSE'
def invoke(self, context, event): def invoke(self, context, event):
self.symmetrize = ctx.prefs.symmetrize self.symmetrize = ctx.prefs.auto_symmetrize
return self.execute(context) return self.execute(context)
def execute(self, context): def execute(self, context):
@ -720,8 +724,8 @@ class BW_OT_clean_widget(Operator):
if not shape: if not shape:
continue continue
bone.custom_shape = get_clean_shape(bone, shape, separate=True, bone.custom_shape = get_clean_shape(bone, shape, separate=prefs.auto_separate,
rename=prefs.rename, col=ctx.widget_col, prefix=prefs.prefix) rename=prefs.auto_rename, col=ctx.widget_col, prefix=prefs.prefix, match=prefs.auto_match_transform)
if self.symmetrize: if self.symmetrize:
symmetrize_bone_shape(bone, prefix=ctx.prefs.prefix) symmetrize_bone_shape(bone, prefix=ctx.prefs.prefix)

View File

@ -34,7 +34,7 @@ def transform_widgets(self, context):
transform_mesh(shape.data, self.loc, self.rot, self.scale, transform_mesh(shape.data, self.loc, self.rot, self.scale,
self.xz_scale, self.size, self.slide, coords=coords) self.xz_scale, self.size, self.slide, coords=coords)
if ctx.prefs.symmetrize: if ctx.prefs.auto_symmetrize:
for bone in ctx.selected_bones: for bone in ctx.selected_bones:
flipped_bone = get_flipped_bone(bone) flipped_bone = get_flipped_bone(bone)
if flipped_bone and flipped_bone.custom_shape in shapes: if flipped_bone and flipped_bone.custom_shape in shapes:
@ -212,10 +212,10 @@ class BW_prefs(AddonPreferences):
prefix: StringProperty(name='Prefix', default='WGT-', description='Prefix for the shape object and data name') prefix: StringProperty(name='Prefix', default='WGT-', description='Prefix for the shape object and data name')
category: StringProperty(name='Tab', default='Rigging', update=lambda s,c: update_tab()) category: StringProperty(name='Tab', default='Rigging', update=lambda s,c: update_tab())
symmetrize: BoolProperty(name='Symmetrize', default=True, update=undo_redo) auto_symmetrize: BoolProperty(name='Symmetrize', default=True, update=undo_redo)
separate: BoolProperty(default=True, name="Separate", update=undo_redo) auto_separate: BoolProperty(default=True, name="Separate", update=undo_redo)
match_transform: BoolProperty(default=True, name="Match Transform", update=undo_redo) auto_match_transform: BoolProperty(default=True, name="Match Transform", update=undo_redo)
rename: BoolProperty(default=True, name="Rename", update=undo_redo) auto_rename: BoolProperty(default=True, name="Rename", update=undo_redo)
show_transforms: BoolProperty(default=False) show_transforms: BoolProperty(default=False)
show_preferences: BoolProperty(default=False) show_preferences: BoolProperty(default=False)

8
ui.py
View File

@ -84,12 +84,12 @@ def draw_prefs(layout):
split.label(text='Auto:') split.label(text='Auto:')
col = split.column(align=True) col = split.column(align=True)
add_bool_row(col, 'symmetrize', name='Symmetrize', icon='MOD_MIRROR') add_bool_row(col, 'auto_symmetrize', name='Symmetrize', icon='MOD_MIRROR')
add_bool_row(col, 'separate', name='Separate', icon='UNLINKED') add_bool_row(col, 'auto_separate', name='Separate', icon='UNLINKED')
#col = row.column(align=True) #col = row.column(align=True)
add_bool_row(col, 'match_transform', name='Match Transform', icon='TRANSFORM_ORIGINS') add_bool_row(col, 'auto_match_transform', name='Match Transform', icon='TRANSFORM_ORIGINS')
add_bool_row(col, 'rename', name='Rename', icon='SYNTAX_OFF') add_bool_row(col, 'auto_rename', name='Rename', icon='SYNTAX_OFF')
#bpy.ops.wm.save_userpref() #bpy.ops.wm.save_userpref()
prefs_unsaved = bpy.context.preferences.is_dirty prefs_unsaved = bpy.context.preferences.is_dirty

Binary file not shown.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.2 KiB

After

Width:  |  Height:  |  Size: 1.6 KiB

Binary file not shown.

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.2 KiB

Binary file not shown.

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

Binary file not shown.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.7 KiB

Binary file not shown.

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 KiB