forked from bartvdbraak/blender
white space commit (spaces -> tabs and clearing whitespace)
This commit is contained in:
parent
53f94f92a1
commit
f4fa39a551
@ -450,7 +450,7 @@ def generate_rig(context, obj_orig, prefix="ORG-"):
|
|||||||
|
|
||||||
if bone_name not in bone_typeinfos:
|
if bone_name not in bone_typeinfos:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
bone_def_dict = bone_definitions[bone_name]
|
bone_def_dict = bone_definitions[bone_name]
|
||||||
|
|
||||||
# Only blend results from the same submodule, eg.
|
# Only blend results from the same submodule, eg.
|
||||||
|
@ -64,7 +64,7 @@ def metarig_definition(obj, orig_bone_name):
|
|||||||
mt.update()
|
mt.update()
|
||||||
|
|
||||||
mt.shoulder_p = mt.arm_p.parent
|
mt.shoulder_p = mt.arm_p.parent
|
||||||
|
|
||||||
if not mt.shoulder_p:
|
if not mt.shoulder_p:
|
||||||
raise Exception("could not find 'arm' parent, skipping:", orig_bone_name)
|
raise Exception("could not find 'arm' parent, skipping:", orig_bone_name)
|
||||||
print(mt.shoulder_p)
|
print(mt.shoulder_p)
|
||||||
|
@ -86,14 +86,14 @@ def main(obj, bone_definition, base_names):
|
|||||||
del child_pbone
|
del child_pbone
|
||||||
|
|
||||||
bpy.ops.object.mode_set(mode='OBJECT')
|
bpy.ops.object.mode_set(mode='OBJECT')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Move the child bone to the deltas location
|
# Move the child bone to the deltas location
|
||||||
obj.animation_data_create()
|
obj.animation_data_create()
|
||||||
delta_pbone = obj.pose.bones[delta_name]
|
delta_pbone = obj.pose.bones[delta_name]
|
||||||
# child_pbone = obj.pose.bones[child_name]
|
# child_pbone = obj.pose.bones[child_name]
|
||||||
|
|
||||||
# ------------------- drivers
|
# ------------------- drivers
|
||||||
|
|
||||||
delta_pbone.rotation_mode = 'XYZ'
|
delta_pbone.rotation_mode = 'XYZ'
|
||||||
|
@ -161,7 +161,7 @@ def main(obj, bone_definition, base_names):
|
|||||||
neck_e_parent.head = neck_e.head
|
neck_e_parent.head = neck_e.head
|
||||||
neck_e_parent.tail = neck_e.head + ((mt.head_e.tail - mt.head_e.head).normalize() * neck_chain_segment_length / 2.0)
|
neck_e_parent.tail = neck_e.head + ((mt.head_e.tail - mt.head_e.head).normalize() * neck_chain_segment_length / 2.0)
|
||||||
neck_e_parent.roll = neck_e.roll
|
neck_e_parent.roll = neck_e.roll
|
||||||
|
|
||||||
|
|
||||||
orig_parent = neck_e.parent
|
orig_parent = neck_e.parent
|
||||||
neck_e.connected = False
|
neck_e.connected = False
|
||||||
@ -221,7 +221,7 @@ def main(obj, bone_definition, base_names):
|
|||||||
head_driver_path = mt.head_p.path_to_id()
|
head_driver_path = mt.head_p.path_to_id()
|
||||||
|
|
||||||
target_names = [("b%.2d" % (i + 1)) for i in range(len(neck_chain))]
|
target_names = [("b%.2d" % (i + 1)) for i in range(len(neck_chain))]
|
||||||
|
|
||||||
mt.head_p["bend_tot"] = 0.0
|
mt.head_p["bend_tot"] = 0.0
|
||||||
fcurve = mt.head_p.driver_add('["bend_tot"]', 0)
|
fcurve = mt.head_p.driver_add('["bend_tot"]', 0)
|
||||||
driver = fcurve.driver
|
driver = fcurve.driver
|
||||||
@ -234,7 +234,7 @@ def main(obj, bone_definition, base_names):
|
|||||||
tar.id_type = 'OBJECT'
|
tar.id_type = 'OBJECT'
|
||||||
tar.id = obj
|
tar.id = obj
|
||||||
tar.rna_path = head_driver_path + ('["bend_%.2d"]' % (i + 1))
|
tar.rna_path = head_driver_path + ('["bend_%.2d"]' % (i + 1))
|
||||||
|
|
||||||
|
|
||||||
for i, attr in enumerate(mt_chain.attr_names):
|
for i, attr in enumerate(mt_chain.attr_names):
|
||||||
neck_p = getattr(mt_chain, attr + "_p")
|
neck_p = getattr(mt_chain, attr + "_p")
|
||||||
@ -264,9 +264,9 @@ def main(obj, bone_definition, base_names):
|
|||||||
driver = fcurve.driver
|
driver = fcurve.driver
|
||||||
driver.type = 'SCRIPTED'
|
driver.type = 'SCRIPTED'
|
||||||
driver.expression = "bend/bend_tot"
|
driver.expression = "bend/bend_tot"
|
||||||
|
|
||||||
fcurve.modifiers.remove(0) # grr dont need a modifier
|
fcurve.modifiers.remove(0) # grr dont need a modifier
|
||||||
|
|
||||||
|
|
||||||
# add target
|
# add target
|
||||||
tar = driver.targets.new()
|
tar = driver.targets.new()
|
||||||
@ -274,7 +274,7 @@ def main(obj, bone_definition, base_names):
|
|||||||
tar.id_type = 'OBJECT'
|
tar.id_type = 'OBJECT'
|
||||||
tar.id = obj
|
tar.id = obj
|
||||||
tar.rna_path = head_driver_path + ('["bend_tot"]')
|
tar.rna_path = head_driver_path + ('["bend_tot"]')
|
||||||
|
|
||||||
tar = driver.targets.new()
|
tar = driver.targets.new()
|
||||||
tar.name = "bend"
|
tar.name = "bend"
|
||||||
tar.id_type = 'OBJECT'
|
tar.id_type = 'OBJECT'
|
||||||
|
@ -85,7 +85,7 @@ def metarig_definition(obj, orig_bone_name):
|
|||||||
[pinky, ring... etc]
|
[pinky, ring... etc]
|
||||||
'''
|
'''
|
||||||
arm = obj.data
|
arm = obj.data
|
||||||
|
|
||||||
palm_bone = arm.bones[orig_bone_name]
|
palm_bone = arm.bones[orig_bone_name]
|
||||||
palm_parent = palm_bone.parent
|
palm_parent = palm_bone.parent
|
||||||
palm_base = palm_bone.basename
|
palm_base = palm_bone.basename
|
||||||
|
@ -110,7 +110,7 @@ def metarig_definition(obj, orig_bone_name):
|
|||||||
raise Exception("expected the ribcage to have only 1 child.")
|
raise Exception("expected the ribcage to have only 1 child.")
|
||||||
|
|
||||||
child = children[0]
|
child = children[0]
|
||||||
|
|
||||||
bone_definition = [pelvis.name, ribcage.name, child.name]
|
bone_definition = [pelvis.name, ribcage.name, child.name]
|
||||||
bone_definition.extend([child.name for child in child.children_recursive_basename])
|
bone_definition.extend([child.name for child in child.children_recursive_basename])
|
||||||
return bone_definition
|
return bone_definition
|
||||||
@ -389,7 +389,7 @@ def main(obj, bone_definition, base_names):
|
|||||||
driver = fcurve.driver
|
driver = fcurve.driver
|
||||||
driver.type = 'SUM'
|
driver.type = 'SUM'
|
||||||
fcurve.modifiers.remove(0) # grr dont need a modifier
|
fcurve.modifiers.remove(0) # grr dont need a modifier
|
||||||
|
|
||||||
for i in range(spine_chain_len - 1):
|
for i in range(spine_chain_len - 1):
|
||||||
tar = driver.targets.new()
|
tar = driver.targets.new()
|
||||||
tar.name = target_names[i]
|
tar.name = target_names[i]
|
||||||
@ -422,9 +422,9 @@ def main(obj, bone_definition, base_names):
|
|||||||
driver = fcurve.driver
|
driver = fcurve.driver
|
||||||
driver.type = 'SCRIPTED'
|
driver.type = 'SCRIPTED'
|
||||||
driver.expression = "bend/bend_tot"
|
driver.expression = "bend/bend_tot"
|
||||||
|
|
||||||
fcurve.modifiers.remove(0) # grr dont need a modifier
|
fcurve.modifiers.remove(0) # grr dont need a modifier
|
||||||
|
|
||||||
|
|
||||||
# add target
|
# add target
|
||||||
tar = driver.targets.new()
|
tar = driver.targets.new()
|
||||||
@ -432,13 +432,13 @@ def main(obj, bone_definition, base_names):
|
|||||||
tar.id_type = 'OBJECT'
|
tar.id_type = 'OBJECT'
|
||||||
tar.id = obj
|
tar.id = obj
|
||||||
tar.rna_path = rib_driver_path + ('["bend_tot"]')
|
tar.rna_path = rib_driver_path + ('["bend_tot"]')
|
||||||
|
|
||||||
tar = driver.targets.new()
|
tar = driver.targets.new()
|
||||||
tar.name = "bend"
|
tar.name = "bend"
|
||||||
tar.id_type = 'OBJECT'
|
tar.id_type = 'OBJECT'
|
||||||
tar.id = obj
|
tar.id = obj
|
||||||
tar.rna_path = rib_driver_path + ('["%s"]' % prop_name)
|
tar.rna_path = rib_driver_path + ('["%s"]' % prop_name)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# original bone drivers
|
# original bone drivers
|
||||||
|
@ -217,7 +217,7 @@ class WM_OT_properties_edit(bpy.types.Operator):
|
|||||||
|
|
||||||
wm.invoke_props_popup(self, event)
|
wm.invoke_props_popup(self, event)
|
||||||
return ('RUNNING_MODAL',)
|
return ('RUNNING_MODAL',)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class WM_OT_properties_add(bpy.types.Operator):
|
class WM_OT_properties_add(bpy.types.Operator):
|
||||||
|
@ -20,167 +20,167 @@ import bpy
|
|||||||
|
|
||||||
|
|
||||||
class DOPESHEET_HT_header(bpy.types.Header):
|
class DOPESHEET_HT_header(bpy.types.Header):
|
||||||
bl_space_type = 'DOPESHEET_EDITOR'
|
bl_space_type = 'DOPESHEET_EDITOR'
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
st = context.space_data
|
st = context.space_data
|
||||||
|
|
||||||
row = layout.row(align=True)
|
row = layout.row(align=True)
|
||||||
row.template_header()
|
row.template_header()
|
||||||
|
|
||||||
if context.area.show_menus:
|
if context.area.show_menus:
|
||||||
sub = row.row(align=True)
|
sub = row.row(align=True)
|
||||||
|
|
||||||
sub.menu("DOPESHEET_MT_view")
|
sub.menu("DOPESHEET_MT_view")
|
||||||
sub.menu("DOPESHEET_MT_select")
|
sub.menu("DOPESHEET_MT_select")
|
||||||
|
|
||||||
if st.mode == 'DOPESHEET' or (st.mode == 'ACTION' and st.action != None):
|
if st.mode == 'DOPESHEET' or (st.mode == 'ACTION' and st.action != None):
|
||||||
sub.menu("DOPESHEET_MT_channel")
|
sub.menu("DOPESHEET_MT_channel")
|
||||||
elif st.mode == 'GPENCIL':
|
elif st.mode == 'GPENCIL':
|
||||||
# gpencil Channel menu
|
# gpencil Channel menu
|
||||||
pass
|
pass
|
||||||
|
|
||||||
if st.mode != 'GPENCIL':
|
if st.mode != 'GPENCIL':
|
||||||
sub.menu("DOPESHEET_MT_key")
|
sub.menu("DOPESHEET_MT_key")
|
||||||
|
|
||||||
layout.prop(st, "mode", text="")
|
layout.prop(st, "mode", text="")
|
||||||
layout.prop(st.dopesheet, "display_summary", text="Summary")
|
layout.prop(st.dopesheet, "display_summary", text="Summary")
|
||||||
|
|
||||||
if st.mode == 'DOPESHEET':
|
if st.mode == 'DOPESHEET':
|
||||||
layout.template_dopesheet_filter(st.dopesheet)
|
layout.template_dopesheet_filter(st.dopesheet)
|
||||||
elif st.mode == 'ACTION':
|
elif st.mode == 'ACTION':
|
||||||
layout.template_ID(st, "action", new="action.new")
|
layout.template_ID(st, "action", new="action.new")
|
||||||
|
|
||||||
if st.mode != 'GPENCIL':
|
if st.mode != 'GPENCIL':
|
||||||
layout.prop(st, "autosnap", text="")
|
layout.prop(st, "autosnap", text="")
|
||||||
|
|
||||||
row = layout.row(align=True)
|
row = layout.row(align=True)
|
||||||
row.operator("action.copy", text="", icon='ICON_COPYDOWN')
|
row.operator("action.copy", text="", icon='ICON_COPYDOWN')
|
||||||
row.operator("action.paste", text="", icon='ICON_PASTEDOWN')
|
row.operator("action.paste", text="", icon='ICON_PASTEDOWN')
|
||||||
|
|
||||||
|
|
||||||
class DOPESHEET_MT_view(bpy.types.Menu):
|
class DOPESHEET_MT_view(bpy.types.Menu):
|
||||||
bl_label = "View"
|
bl_label = "View"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
st = context.space_data
|
st = context.space_data
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
|
|
||||||
layout.prop(st, "show_cframe_indicator")
|
layout.prop(st, "show_cframe_indicator")
|
||||||
layout.prop(st, "show_sliders")
|
layout.prop(st, "show_sliders")
|
||||||
layout.prop(st, "automerge_keyframes")
|
layout.prop(st, "automerge_keyframes")
|
||||||
|
|
||||||
if st.show_seconds:
|
if st.show_seconds:
|
||||||
layout.operator("anim.time_toggle", text="Show Frames")
|
layout.operator("anim.time_toggle", text="Show Frames")
|
||||||
else:
|
else:
|
||||||
layout.operator("anim.time_toggle", text="Show Seconds")
|
layout.operator("anim.time_toggle", text="Show Seconds")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("anim.previewrange_set")
|
layout.operator("anim.previewrange_set")
|
||||||
layout.operator("anim.previewrange_clear")
|
layout.operator("anim.previewrange_clear")
|
||||||
layout.operator("action.previewrange_set")
|
layout.operator("action.previewrange_set")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("action.frame_jump")
|
layout.operator("action.frame_jump")
|
||||||
layout.operator("action.view_all")
|
layout.operator("action.view_all")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("screen.area_dupli")
|
layout.operator("screen.area_dupli")
|
||||||
layout.operator("screen.screen_full_area")
|
layout.operator("screen.screen_full_area")
|
||||||
|
|
||||||
|
|
||||||
class DOPESHEET_MT_select(bpy.types.Menu):
|
class DOPESHEET_MT_select(bpy.types.Menu):
|
||||||
bl_label = "Select"
|
bl_label = "Select"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
# This is a bit misleading as the operator's default text is "Select All" while it actually *toggles* All/None
|
# This is a bit misleading as the operator's default text is "Select All" while it actually *toggles* All/None
|
||||||
layout.operator("action.select_all_toggle")
|
layout.operator("action.select_all_toggle")
|
||||||
layout.operator("action.select_all_toggle", text="Invert Selection").invert = True
|
layout.operator("action.select_all_toggle", text="Invert Selection").invert = True
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("action.select_border")
|
layout.operator("action.select_border")
|
||||||
layout.operator("action.select_border", text="Border Axis Range").axis_range = True
|
layout.operator("action.select_border", text="Border Axis Range").axis_range = True
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("action.select_column", text="Columns on Selected Keys").mode = 'KEYS'
|
layout.operator("action.select_column", text="Columns on Selected Keys").mode = 'KEYS'
|
||||||
layout.operator("action.select_column", text="Column on Current Frame").mode = 'CFRA'
|
layout.operator("action.select_column", text="Column on Current Frame").mode = 'CFRA'
|
||||||
|
|
||||||
layout.operator("action.select_column", text="Columns on Selected Markers").mode = 'MARKERS_COLUMN'
|
layout.operator("action.select_column", text="Columns on Selected Markers").mode = 'MARKERS_COLUMN'
|
||||||
layout.operator("action.select_column", text="Between Selected Markers").mode = 'MARKERS_BETWEEN'
|
layout.operator("action.select_column", text="Between Selected Markers").mode = 'MARKERS_BETWEEN'
|
||||||
|
|
||||||
|
|
||||||
class DOPESHEET_MT_channel(bpy.types.Menu):
|
class DOPESHEET_MT_channel(bpy.types.Menu):
|
||||||
bl_label = "Channel"
|
bl_label = "Channel"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
layout.operator("anim.channels_setting_toggle")
|
layout.operator("anim.channels_setting_toggle")
|
||||||
layout.operator("anim.channels_setting_enable")
|
layout.operator("anim.channels_setting_enable")
|
||||||
layout.operator("anim.channels_setting_disable")
|
layout.operator("anim.channels_setting_disable")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("anim.channels_editable_toggle")
|
layout.operator("anim.channels_editable_toggle")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("anim.channels_expand")
|
layout.operator("anim.channels_expand")
|
||||||
layout.operator("anim.channels_collapse")
|
layout.operator("anim.channels_collapse")
|
||||||
|
|
||||||
|
|
||||||
class DOPESHEET_MT_key(bpy.types.Menu):
|
class DOPESHEET_MT_key(bpy.types.Menu):
|
||||||
bl_label = "Key"
|
bl_label = "Key"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
layout.menu("DOPESHEET_MT_key_transform", text="Transform")
|
layout.menu("DOPESHEET_MT_key_transform", text="Transform")
|
||||||
|
|
||||||
layout.operator_menu_enum("action.snap", property="type", text="Snap")
|
layout.operator_menu_enum("action.snap", property="type", text="Snap")
|
||||||
layout.operator_menu_enum("action.mirror", property="type", text="Mirror")
|
layout.operator_menu_enum("action.mirror", property="type", text="Mirror")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
# Inconsistent naming? act/action
|
# Inconsistent naming? act/action
|
||||||
layout.operator("act.keyframe_insert")
|
layout.operator("act.keyframe_insert")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("action.duplicate")
|
layout.operator("action.duplicate")
|
||||||
layout.operator("action.delete")
|
layout.operator("action.delete")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator_menu_enum("action.keyframe_type", property="type", text="Keyframe Type")
|
layout.operator_menu_enum("action.keyframe_type", property="type", text="Keyframe Type")
|
||||||
layout.operator_menu_enum("action.handle_type", property="type", text="Handle Type")
|
layout.operator_menu_enum("action.handle_type", property="type", text="Handle Type")
|
||||||
layout.operator_menu_enum("action.interpolation_type", property="type", text="Interpolation Mode")
|
layout.operator_menu_enum("action.interpolation_type", property="type", text="Interpolation Mode")
|
||||||
layout.operator_menu_enum("action.extrapolation_type", property="type", text="Extrapolation Mode")
|
layout.operator_menu_enum("action.extrapolation_type", property="type", text="Extrapolation Mode")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("action.clean")
|
layout.operator("action.clean")
|
||||||
layout.operator("action.sample")
|
layout.operator("action.sample")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("action.copy")
|
layout.operator("action.copy")
|
||||||
layout.operator("action.paste")
|
layout.operator("action.paste")
|
||||||
|
|
||||||
|
|
||||||
class DOPESHEET_MT_key_transform(bpy.types.Menu):
|
class DOPESHEET_MT_key_transform(bpy.types.Menu):
|
||||||
bl_label = "Transform"
|
bl_label = "Transform"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
layout.operator("tfm.translate", text="Grab/Move")
|
layout.operator("tfm.translate", text="Grab/Move")
|
||||||
layout.operator("tfm.transform", text="Extend").mode = 'TIME_EXTEND'
|
layout.operator("tfm.transform", text="Extend").mode = 'TIME_EXTEND'
|
||||||
layout.operator("tfm.resize", text="Scale")
|
layout.operator("tfm.resize", text="Scale")
|
||||||
|
|
||||||
|
|
||||||
bpy.types.register(DOPESHEET_HT_header) # header/menu classes
|
bpy.types.register(DOPESHEET_HT_header) # header/menu classes
|
||||||
|
@ -20,171 +20,171 @@ import bpy
|
|||||||
|
|
||||||
|
|
||||||
class GRAPH_HT_header(bpy.types.Header):
|
class GRAPH_HT_header(bpy.types.Header):
|
||||||
bl_space_type = 'GRAPH_EDITOR'
|
bl_space_type = 'GRAPH_EDITOR'
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
st = context.space_data
|
st = context.space_data
|
||||||
|
|
||||||
row = layout.row(align=True)
|
row = layout.row(align=True)
|
||||||
row.template_header()
|
row.template_header()
|
||||||
|
|
||||||
if context.area.show_menus:
|
if context.area.show_menus:
|
||||||
sub = row.row(align=True)
|
sub = row.row(align=True)
|
||||||
|
|
||||||
sub.menu("GRAPH_MT_view")
|
sub.menu("GRAPH_MT_view")
|
||||||
sub.menu("GRAPH_MT_select")
|
sub.menu("GRAPH_MT_select")
|
||||||
sub.menu("GRAPH_MT_channel")
|
sub.menu("GRAPH_MT_channel")
|
||||||
sub.menu("GRAPH_MT_key")
|
sub.menu("GRAPH_MT_key")
|
||||||
|
|
||||||
layout.prop(st, "mode", text="")
|
layout.prop(st, "mode", text="")
|
||||||
|
|
||||||
layout.template_dopesheet_filter(st.dopesheet)
|
layout.template_dopesheet_filter(st.dopesheet)
|
||||||
|
|
||||||
layout.prop(st, "autosnap", text="")
|
layout.prop(st, "autosnap", text="")
|
||||||
layout.prop(st, "pivot_point", text="", icon_only=True)
|
layout.prop(st, "pivot_point", text="", icon_only=True)
|
||||||
|
|
||||||
row = layout.row(align=True)
|
row = layout.row(align=True)
|
||||||
row.operator("graph.copy", text="", icon='ICON_COPYDOWN')
|
row.operator("graph.copy", text="", icon='ICON_COPYDOWN')
|
||||||
row.operator("graph.paste", text="", icon='ICON_PASTEDOWN')
|
row.operator("graph.paste", text="", icon='ICON_PASTEDOWN')
|
||||||
|
|
||||||
row = layout.row(align=True)
|
row = layout.row(align=True)
|
||||||
if st.has_ghost_curves:
|
if st.has_ghost_curves:
|
||||||
row.operator("graph.ghost_curves_clear", text="", icon='ICON_GHOST_DISABLED')
|
row.operator("graph.ghost_curves_clear", text="", icon='ICON_GHOST_DISABLED')
|
||||||
else:
|
else:
|
||||||
row.operator("graph.ghost_curves_create", text="", icon='ICON_GHOST_ENABLED')
|
row.operator("graph.ghost_curves_create", text="", icon='ICON_GHOST_ENABLED')
|
||||||
|
|
||||||
|
|
||||||
class GRAPH_MT_view(bpy.types.Menu):
|
class GRAPH_MT_view(bpy.types.Menu):
|
||||||
bl_label = "View"
|
bl_label = "View"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
st = context.space_data
|
st = context.space_data
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("graph.properties", icon="ICON_MENU_PANEL")
|
layout.operator("graph.properties", icon="ICON_MENU_PANEL")
|
||||||
|
|
||||||
layout.prop(st, "show_cframe_indicator")
|
layout.prop(st, "show_cframe_indicator")
|
||||||
layout.prop(st, "show_cursor")
|
layout.prop(st, "show_cursor")
|
||||||
layout.prop(st, "show_sliders")
|
layout.prop(st, "show_sliders")
|
||||||
layout.prop(st, "automerge_keyframes")
|
layout.prop(st, "automerge_keyframes")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
if st.show_handles:
|
if st.show_handles:
|
||||||
layout.operator("graph.handles_view_toggle", icon="ICON_CHECKBOX_HLT", text="Show All Handles")
|
layout.operator("graph.handles_view_toggle", icon="ICON_CHECKBOX_HLT", text="Show All Handles")
|
||||||
else:
|
else:
|
||||||
layout.operator("graph.handles_view_toggle", icon="ICON_CHECKBOX_DEHLT", text="Show All Handles")
|
layout.operator("graph.handles_view_toggle", icon="ICON_CHECKBOX_DEHLT", text="Show All Handles")
|
||||||
layout.prop(st, "only_selected_curves_handles")
|
layout.prop(st, "only_selected_curves_handles")
|
||||||
layout.prop(st, "only_selected_keyframe_handles")
|
layout.prop(st, "only_selected_keyframe_handles")
|
||||||
layout.operator("anim.time_toggle")
|
layout.operator("anim.time_toggle")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("anim.previewrange_set")
|
layout.operator("anim.previewrange_set")
|
||||||
layout.operator("anim.previewrange_clear")
|
layout.operator("anim.previewrange_clear")
|
||||||
layout.operator("graph.previewrange_set")
|
layout.operator("graph.previewrange_set")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("graph.frame_jump")
|
layout.operator("graph.frame_jump")
|
||||||
layout.operator("graph.view_all")
|
layout.operator("graph.view_all")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("screen.area_dupli")
|
layout.operator("screen.area_dupli")
|
||||||
layout.operator("screen.screen_full_area")
|
layout.operator("screen.screen_full_area")
|
||||||
|
|
||||||
|
|
||||||
class GRAPH_MT_select(bpy.types.Menu):
|
class GRAPH_MT_select(bpy.types.Menu):
|
||||||
bl_label = "Select"
|
bl_label = "Select"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
# This is a bit misleading as the operator's default text is "Select All" while it actually *toggles* All/None
|
# This is a bit misleading as the operator's default text is "Select All" while it actually *toggles* All/None
|
||||||
layout.operator("graph.select_all_toggle")
|
layout.operator("graph.select_all_toggle")
|
||||||
layout.operator("graph.select_all_toggle", text="Invert Selection").invert = True
|
layout.operator("graph.select_all_toggle", text="Invert Selection").invert = True
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("graph.select_border")
|
layout.operator("graph.select_border")
|
||||||
layout.operator("graph.select_border", text="Border Axis Range").axis_range = True
|
layout.operator("graph.select_border", text="Border Axis Range").axis_range = True
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("graph.select_column", text="Columns on Selected Keys").mode = 'KEYS'
|
layout.operator("graph.select_column", text="Columns on Selected Keys").mode = 'KEYS'
|
||||||
layout.operator("graph.select_column", text="Column on Current Frame").mode = 'CFRA'
|
layout.operator("graph.select_column", text="Column on Current Frame").mode = 'CFRA'
|
||||||
|
|
||||||
layout.operator("graph.select_column", text="Columns on Selected Markers").mode = 'MARKERS_COLUMN'
|
layout.operator("graph.select_column", text="Columns on Selected Markers").mode = 'MARKERS_COLUMN'
|
||||||
layout.operator("graph.select_column", text="Between Selected Markers").mode = 'MARKERS_BETWEEN'
|
layout.operator("graph.select_column", text="Between Selected Markers").mode = 'MARKERS_BETWEEN'
|
||||||
|
|
||||||
|
|
||||||
class GRAPH_MT_channel(bpy.types.Menu):
|
class GRAPH_MT_channel(bpy.types.Menu):
|
||||||
bl_label = "Channel"
|
bl_label = "Channel"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
layout.operator("anim.channels_setting_toggle")
|
layout.operator("anim.channels_setting_toggle")
|
||||||
layout.operator("anim.channels_setting_enable")
|
layout.operator("anim.channels_setting_enable")
|
||||||
layout.operator("anim.channels_setting_disable")
|
layout.operator("anim.channels_setting_disable")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("anim.channels_editable_toggle")
|
layout.operator("anim.channels_editable_toggle")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("anim.channels_expand")
|
layout.operator("anim.channels_expand")
|
||||||
layout.operator("anim.channels_collapse")
|
layout.operator("anim.channels_collapse")
|
||||||
|
|
||||||
|
|
||||||
class GRAPH_MT_key(bpy.types.Menu):
|
class GRAPH_MT_key(bpy.types.Menu):
|
||||||
bl_label = "Key"
|
bl_label = "Key"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
layout.menu("GRAPH_MT_key_transform", text="Transform")
|
layout.menu("GRAPH_MT_key_transform", text="Transform")
|
||||||
|
|
||||||
layout.operator_menu_enum("graph.snap", property="type", text="Snap")
|
layout.operator_menu_enum("graph.snap", property="type", text="Snap")
|
||||||
layout.operator_menu_enum("graph.mirror", property="type", text="Mirror")
|
layout.operator_menu_enum("graph.mirror", property="type", text="Mirror")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("graph.keyframe_insert")
|
layout.operator("graph.keyframe_insert")
|
||||||
layout.operator("graph.fmodifier_add")
|
layout.operator("graph.fmodifier_add")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("graph.duplicate")
|
layout.operator("graph.duplicate")
|
||||||
layout.operator("graph.delete")
|
layout.operator("graph.delete")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator_menu_enum("graph.handle_type", property="type", text="Handle Type")
|
layout.operator_menu_enum("graph.handle_type", property="type", text="Handle Type")
|
||||||
layout.operator_menu_enum("graph.interpolation_type", property="type", text="Interpolation Mode")
|
layout.operator_menu_enum("graph.interpolation_type", property="type", text="Interpolation Mode")
|
||||||
layout.operator_menu_enum("graph.extrapolation_type", property="type", text="Extrapolation Mode")
|
layout.operator_menu_enum("graph.extrapolation_type", property="type", text="Extrapolation Mode")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("graph.clean")
|
layout.operator("graph.clean")
|
||||||
layout.operator("graph.sample")
|
layout.operator("graph.sample")
|
||||||
layout.operator("graph.bake")
|
layout.operator("graph.bake")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("graph.copy")
|
layout.operator("graph.copy")
|
||||||
layout.operator("graph.paste")
|
layout.operator("graph.paste")
|
||||||
|
|
||||||
|
|
||||||
class GRAPH_MT_key_transform(bpy.types.Menu):
|
class GRAPH_MT_key_transform(bpy.types.Menu):
|
||||||
bl_label = "Transform"
|
bl_label = "Transform"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
layout.operator("tfm.translate", text="Grab/Move")
|
layout.operator("tfm.translate", text="Grab/Move")
|
||||||
layout.operator("tfm.transform", text="Extend").mode = 'TIME_EXTEND'
|
layout.operator("tfm.transform", text="Extend").mode = 'TIME_EXTEND'
|
||||||
layout.operator("tfm.rotate", text="Rotate")
|
layout.operator("tfm.rotate", text="Rotate")
|
||||||
layout.operator("tfm.resize", text="Scale")
|
layout.operator("tfm.resize", text="Scale")
|
||||||
|
|
||||||
|
|
||||||
bpy.types.register(GRAPH_HT_header) # header/menu classes
|
bpy.types.register(GRAPH_HT_header) # header/menu classes
|
||||||
|
@ -20,142 +20,142 @@ import bpy
|
|||||||
|
|
||||||
|
|
||||||
class NLA_HT_header(bpy.types.Header):
|
class NLA_HT_header(bpy.types.Header):
|
||||||
bl_space_type = 'NLA_EDITOR'
|
bl_space_type = 'NLA_EDITOR'
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
st = context.space_data
|
st = context.space_data
|
||||||
|
|
||||||
row = layout.row(align=True)
|
row = layout.row(align=True)
|
||||||
row.template_header()
|
row.template_header()
|
||||||
|
|
||||||
if context.area.show_menus:
|
if context.area.show_menus:
|
||||||
sub = row.row(align=True)
|
sub = row.row(align=True)
|
||||||
|
|
||||||
sub.menu("NLA_MT_view")
|
sub.menu("NLA_MT_view")
|
||||||
sub.menu("NLA_MT_select")
|
sub.menu("NLA_MT_select")
|
||||||
sub.menu("NLA_MT_edit")
|
sub.menu("NLA_MT_edit")
|
||||||
sub.menu("NLA_MT_add")
|
sub.menu("NLA_MT_add")
|
||||||
|
|
||||||
layout.template_dopesheet_filter(st.dopesheet)
|
layout.template_dopesheet_filter(st.dopesheet)
|
||||||
|
|
||||||
layout.prop(st, "autosnap", text="")
|
layout.prop(st, "autosnap", text="")
|
||||||
|
|
||||||
|
|
||||||
class NLA_MT_view(bpy.types.Menu):
|
class NLA_MT_view(bpy.types.Menu):
|
||||||
bl_label = "View"
|
bl_label = "View"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
st = context.space_data
|
st = context.space_data
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
|
|
||||||
layout.operator("nla.properties", icon="ICON_MENU_PANEL")
|
layout.operator("nla.properties", icon="ICON_MENU_PANEL")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.prop(st, "show_cframe_indicator")
|
layout.prop(st, "show_cframe_indicator")
|
||||||
|
|
||||||
if st.show_seconds:
|
if st.show_seconds:
|
||||||
layout.operator("anim.time_toggle", text="Show Frames")
|
layout.operator("anim.time_toggle", text="Show Frames")
|
||||||
else:
|
else:
|
||||||
layout.operator("anim.time_toggle", text="Show Seconds")
|
layout.operator("anim.time_toggle", text="Show Seconds")
|
||||||
|
|
||||||
layout.prop(st, "show_strip_curves")
|
layout.prop(st, "show_strip_curves")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("anim.previewrange_set")
|
layout.operator("anim.previewrange_set")
|
||||||
layout.operator("anim.previewrange_clear")
|
layout.operator("anim.previewrange_clear")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("screen.area_dupli")
|
layout.operator("screen.area_dupli")
|
||||||
layout.operator("screen.screen_full_area")
|
layout.operator("screen.screen_full_area")
|
||||||
|
|
||||||
|
|
||||||
class NLA_MT_select(bpy.types.Menu):
|
class NLA_MT_select(bpy.types.Menu):
|
||||||
bl_label = "Select"
|
bl_label = "Select"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
# This is a bit misleading as the operator's default text is "Select All" while it actually *toggles* All/None
|
# This is a bit misleading as the operator's default text is "Select All" while it actually *toggles* All/None
|
||||||
layout.operator("nla.select_all_toggle")
|
layout.operator("nla.select_all_toggle")
|
||||||
layout.operator("nla.select_all_toggle", text="Invert Selection").invert = True
|
layout.operator("nla.select_all_toggle", text="Invert Selection").invert = True
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("nla.select_border")
|
layout.operator("nla.select_border")
|
||||||
layout.operator("nla.select_border", text="Border Axis Range").axis_range = True
|
layout.operator("nla.select_border", text="Border Axis Range").axis_range = True
|
||||||
|
|
||||||
|
|
||||||
class NLA_MT_edit(bpy.types.Menu):
|
class NLA_MT_edit(bpy.types.Menu):
|
||||||
bl_label = "Edit"
|
bl_label = "Edit"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
scene = context.scene
|
|
||||||
|
|
||||||
layout.column()
|
scene = context.scene
|
||||||
layout.menu("NLA_MT_edit_transform", text="Transform")
|
|
||||||
|
|
||||||
layout.operator_menu_enum("nla.snap", property="type", text="Snap")
|
layout.column()
|
||||||
|
layout.menu("NLA_MT_edit_transform", text="Transform")
|
||||||
|
|
||||||
layout.separator()
|
layout.operator_menu_enum("nla.snap", property="type", text="Snap")
|
||||||
layout.operator("nla.duplicate")
|
|
||||||
layout.operator("nla.split")
|
|
||||||
layout.operator("nla.delete")
|
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("nla.mute_toggle")
|
layout.operator("nla.duplicate")
|
||||||
|
layout.operator("nla.split")
|
||||||
|
layout.operator("nla.delete")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("nla.apply_scale")
|
layout.operator("nla.mute_toggle")
|
||||||
layout.operator("nla.clear_scale")
|
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("nla.move_up")
|
layout.operator("nla.apply_scale")
|
||||||
layout.operator("nla.move_down")
|
layout.operator("nla.clear_scale")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
# TODO: names of these tools for 'tweakmode' need changing?
|
layout.operator("nla.move_up")
|
||||||
if scene.nla_tweakmode_on:
|
layout.operator("nla.move_down")
|
||||||
layout.operator("nla.tweakmode_exit", text="Stop Tweaking Strip Actions")
|
|
||||||
else:
|
layout.separator()
|
||||||
layout.operator("nla.tweakmode_enter", text="Start Tweaking Strip Actions")
|
# TODO: names of these tools for 'tweakmode' need changing?
|
||||||
|
if scene.nla_tweakmode_on:
|
||||||
|
layout.operator("nla.tweakmode_exit", text="Stop Tweaking Strip Actions")
|
||||||
|
else:
|
||||||
|
layout.operator("nla.tweakmode_enter", text="Start Tweaking Strip Actions")
|
||||||
|
|
||||||
|
|
||||||
class NLA_MT_add(bpy.types.Menu):
|
class NLA_MT_add(bpy.types.Menu):
|
||||||
bl_label = "Add"
|
bl_label = "Add"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
layout.operator("nla.actionclip_add")
|
layout.operator("nla.actionclip_add")
|
||||||
layout.operator("nla.transition_add")
|
layout.operator("nla.transition_add")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("nla.meta_add")
|
layout.operator("nla.meta_add")
|
||||||
layout.operator("nla.meta_remove")
|
layout.operator("nla.meta_remove")
|
||||||
|
|
||||||
layout.separator()
|
layout.separator()
|
||||||
layout.operator("nla.tracks_add")
|
layout.operator("nla.tracks_add")
|
||||||
layout.operator("nla.tracks_add", text="Add Tracks Above Selected").above_selected = True
|
layout.operator("nla.tracks_add", text="Add Tracks Above Selected").above_selected = True
|
||||||
|
|
||||||
|
|
||||||
class NLA_MT_edit_transform(bpy.types.Menu):
|
class NLA_MT_edit_transform(bpy.types.Menu):
|
||||||
bl_label = "Transform"
|
bl_label = "Transform"
|
||||||
|
|
||||||
def draw(self, context):
|
def draw(self, context):
|
||||||
layout = self.layout
|
layout = self.layout
|
||||||
|
|
||||||
layout.column()
|
layout.column()
|
||||||
layout.operator("tfm.translate", text="Grab/Move")
|
layout.operator("tfm.translate", text="Grab/Move")
|
||||||
layout.operator("tfm.transform", text="Extend").mode = 'TIME_EXTEND'
|
layout.operator("tfm.transform", text="Extend").mode = 'TIME_EXTEND'
|
||||||
layout.operator("tfm.resize", text="Scale")
|
layout.operator("tfm.resize", text="Scale")
|
||||||
|
|
||||||
|
|
||||||
bpy.types.register(NLA_HT_header) # header/menu classes
|
bpy.types.register(NLA_HT_header) # header/menu classes
|
||||||
|
Loading…
Reference in New Issue
Block a user