1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
# ##### BEGIN GPL LICENSE BLOCK #####
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software Foundation,
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
# ##### END GPL LICENSE BLOCK #####
# <pep8 compliant>
bl_info = {
"name": "Hotkey: 'Ctrl Shift Spacebar'",
"description": "Pie menu for Timeline controls",
"author": "pitiwazou, meta-androcto",
"version": (0, 1, 1),
"blender": (2, 80, 0),
"location": "3D View",
"warning": "",
"wiki_url": "",
"category": "Animation Pie"
}
import bpy
from bpy.types import (
Menu,
Operator,
)
# Pie Animation
class PIE_MT_PieAnimation(Menu):
bl_idname = "PIE_MT_animation"
bl_label = "Pie Animation"
def draw(self, context):
layout = self.layout
pie = layout.menu_pie()
# 4 - LEFT
pie.operator("screen.frame_jump", text="Jump REW", icon='REW').end = False
# 6 - RIGHT
pie.operator("screen.frame_jump", text="Jump FF", icon='FF').end = True
# 2 - BOTTOM
pie.operator("screen.animation_play", text="Reverse", icon='PLAY_REVERSE').reverse = True
# 8 - TOP
if not context.screen.is_animation_playing: # Play / Pause
pie.operator("screen.animation_play", text="Play", icon='PLAY')
else:
pie.operator("screen.animation_play", text="Stop", icon='PAUSE')
# 7 - TOP - LEFT
pie.operator("screen.keyframe_jump", text="Previous FR", icon='PREV_KEYFRAME').next = False
# 9 - TOP - RIGHT
pie.operator("screen.keyframe_jump", text="Next FR", icon='NEXT_KEYFRAME').next = True
# 1 - BOTTOM - LEFT
pie.operator("insert.autokeyframe", text="Auto Keyframe", icon='REC')
# 3 - BOTTOM - RIGHT
pie.menu("VIEW3D_MT_object_animation", text="Keyframe Menu", icon="KEYINGSET")
# Insert Auto Keyframe
class PIE_OT_InsertAutoKeyframe(Operator):
bl_idname = "insert.autokeyframe"
bl_label = "Insert Auto Keyframe"
bl_description = "Toggle Insert Auto Keyframe"
bl_options = {'REGISTER', 'UNDO'}
def execute(self, context):
ts = context.tool_settings
ts.use_keyframe_insert_auto ^= 1
for area in context.screen.areas:
if area.type == 'TIMELINE':
area.tag_redraw()
return {'FINISHED'}
classes = (
PIE_MT_PieAnimation,
PIE_OT_InsertAutoKeyframe
)
addon_keymaps = []
def register():
for cls in classes:
bpy.utils.register_class(cls)
wm = bpy.context.window_manager
if wm.keyconfigs.addon:
# Animation
km = wm.keyconfigs.addon.keymaps.new(name='Object Non-modal')
kmi = km.keymap_items.new('wm.call_menu_pie', 'SPACE', 'PRESS', ctrl=True, shift=True)
kmi.properties.name = "PIE_MT_animation"
addon_keymaps.append((km, kmi))
def unregister():
for cls in classes:
bpy.utils.unregister_class(cls)
wm = bpy.context.window_manager
kc = wm.keyconfigs.addon
if kc:
for km, kmi in addon_keymaps:
km.keymap_items.remove(kmi)
addon_keymaps.clear()
if __name__ == "__main__":
register()
|