Fix broken cursor_follow feature

master
pullusb 2024-12-03 16:10:30 +01:00
parent 3695470354
commit 2013c55ba8
2 changed files with 6 additions and 11 deletions

View File

@ -119,7 +119,7 @@ def cursor_follow_update(self, context):
if self.cursor_follow:#True if self.cursor_follow:#True
if not cursor_follow.__name__ in [hand.__name__ for hand in bpy.app.handlers.frame_change_post]: if not cursor_follow.__name__ in [hand.__name__ for hand in bpy.app.handlers.frame_change_post]:
if context.object: if context.object:
prev_matrix = context.object.matrix_world prev_matrix = context.object.matrix_world.copy()
bpy.app.handlers.frame_change_post.append(cursor_follow) bpy.app.handlers.frame_change_post.append(cursor_follow)
@ -131,7 +131,6 @@ def cursor_follow_update(self, context):
def cursor_follow(scene): def cursor_follow(scene):
'''Handler to make the cursor follow active object matrix changes on frame change''' '''Handler to make the cursor follow active object matrix changes on frame change'''
## TODO update global prev_matrix to equal current_matrix on selection change (need another handler)...
if not bpy.context.object: if not bpy.context.object:
return return
global prev_matrix global prev_matrix
@ -149,8 +148,6 @@ def cursor_follow(scene):
## translation only ## translation only
# scene.cursor.location += (current_matrix - prev_matrix).to_translation() # scene.cursor.location += (current_matrix - prev_matrix).to_translation()
# print('offset:', (current_matrix - prev_matrix).to_translation())
## full ## full
scene.cursor.location = current_matrix @ (prev_matrix.inverted() @ scene.cursor.location) scene.cursor.location = current_matrix @ (prev_matrix.inverted() @ scene.cursor.location)
@ -164,11 +161,10 @@ def selection_changed():
"""Callback function for selection changes""" """Callback function for selection changes"""
if not bpy.context.scene.gptoolprops.cursor_follow: if not bpy.context.scene.gptoolprops.cursor_follow:
return return
print('select_changed')
global prev_matrix, prev_active_obj global prev_matrix, prev_active_obj
if prev_active_obj != bpy.context.object: if prev_active_obj != bpy.context.object:
## Set stored matrix to active object ## Set stored matrix to active object
prev_matrix = bpy.context.object.matrix_world prev_matrix = bpy.context.object.matrix_world.copy()
prev_active_obj = bpy.context.object prev_active_obj = bpy.context.object
## Note: Same owner as layer manager (will be removed as well) ## Note: Same owner as layer manager (will be removed as well)
@ -197,15 +193,15 @@ def register():
# swap_keymap_by_id('view3d.cursor3d','view3d.cursor_snap')#auto swap to custom GP snap wrap # swap_keymap_by_id('view3d.cursor3d','view3d.cursor_snap')#auto swap to custom GP snap wrap
## Follow cursor matrix update on object change ## Follow cursor matrix update on object change
# bpy.app.handlers.load_post.append(subscribe_object_change_handler) # select_change bpy.app.handlers.load_post.append(subscribe_object_change_handler) # select_change
# ## Directly set msgbus to work at first addon activation # select_change # ## Directly set msgbus to work at first addon activation # select_change
# bpy.app.timers.register(subscribe_object_change, first_interval=1) # select_change bpy.app.timers.register(subscribe_object_change, first_interval=1) # select_change
## No need to frame_change_post.append(cursor_follow). Added by property update, when activating 'cursor follow' ## No need to frame_change_post.append(cursor_follow). Added by property update, when activating 'cursor follow'
def unregister(): def unregister():
# bpy.app.handlers.load_post.remove(subscribe_object_change_handler) # select_change bpy.app.handlers.load_post.remove(subscribe_object_change_handler) # select_change
# swap_keymap_by_id('view3d.cursor_snap','view3d.cursor3d')#Restore normal snap # swap_keymap_by_id('view3d.cursor_snap','view3d.cursor3d')#Restore normal snap

View File

@ -73,7 +73,6 @@ class GPTB_OT_file_checker(bpy.types.Operator):
problems = [] problems = []
## Old method : Apply fixes based on pref (inverted by ctrl key) ## Old method : Apply fixes based on pref (inverted by ctrl key)
# apply = not fix.check_only
# # If Ctrl is pressed, invert behavior (invert boolean) # # If Ctrl is pressed, invert behavior (invert boolean)
# apply ^= self.ctrl # apply ^= self.ctrl