Blender Media Viewer: Fix legacy overrides #69

Merged
Nick Alberelli merged 1 commits from fix/media-viewer-legacy-overrides into main 2023-06-05 16:25:51 +02:00
2 changed files with 44 additions and 31 deletions
Showing only changes of commit 0a81a178d3 - Show all commits

View File

@ -391,7 +391,7 @@ class MV_OT_toggle_timeline(bpy.types.Operator):
if area_timeline: if area_timeline:
# Timeline needs to be closed. # Timeline needs to be closed.
timeline_state = TimelineState(area=area_timeline) timeline_state = TimelineState(area=area_timeline)
opsdata.close_area(area_timeline) opsdata.close_area(context, area_timeline)
logger.info("Hide timeline") logger.info("Hide timeline")
elif area_media: elif area_media:
@ -453,7 +453,7 @@ class MV_OT_toggle_filebrowser(bpy.types.Operator):
# If sqe and timeline visible but not filebrowser # If sqe and timeline visible but not filebrowser
# we need to first close timeline and then open it after to # we need to first close timeline and then open it after to
# get correct layout. # get correct layout.
opsdata.close_area(area_time) opsdata.close_area(context, area_time)
# We need to do some custom context assembly here # We need to do some custom context assembly here
# because the bpy.ops.screen.area_close() sets context.screen to NULL. # because the bpy.ops.screen.area_close() sets context.screen to NULL.
@ -468,7 +468,8 @@ class MV_OT_toggle_filebrowser(bpy.types.Operator):
) )
# Screen must be re-drawn, otherwise space.params is None. # Screen must be re-drawn, otherwise space.params is None.
bpy.ops.wm.redraw_timer(ctx, type="DRAW_WIN_SWAP", iterations=1) with context.temp_override(**ctx):
bpy.ops.wm.redraw_timer(type="DRAW_WIN_SWAP", iterations=1)
# Restore previous filebrowser state. # Restore previous filebrowser state.
filebrowser_state.apply_to_area(area_fb) filebrowser_state.apply_to_area(area_fb)
@ -513,7 +514,7 @@ class MV_OT_toggle_filebrowser(bpy.types.Operator):
# Save filebrowser state. # Save filebrowser state.
filebrowser_state = FileBrowserState(area=area_fb) filebrowser_state = FileBrowserState(area=area_fb)
opsdata.close_area(area_fb) opsdata.close_area(context, area_fb)
logger.info("Hide filebrowser") logger.info("Hide filebrowser")
return {"FINISHED"} return {"FINISHED"}
@ -649,7 +650,8 @@ class MV_OT_screen_full_area(bpy.types.Operator):
# active_media_area_obj = area_media # active_media_area_obj = area_media
ctx = opsdata.get_context_for_area(area_media) ctx = opsdata.get_context_for_area(area_media)
bpy.ops.screen.screen_full_area(ctx, use_hide_panels=True) with context.temp_override(**ctx):
bpy.ops.screen.screen_full_area(use_hide_panels=True)
is_fullscreen = not is_fullscreen is_fullscreen = not is_fullscreen
# Select previous filepath if in FILE_BROWSER area. # Select previous filepath if in FILE_BROWSER area.
@ -699,7 +701,8 @@ class MV_OT_jump_folder_up(bpy.types.Operator):
return {"CANCELLED"} return {"CANCELLED"}
ctx = opsdata.get_context_for_area(area_fb) ctx = opsdata.get_context_for_area(area_fb)
bpy.ops.file.parent(ctx) with context.temp_override(**ctx):
bpy.ops.file.parent()
return {"FINISHED"} return {"FINISHED"}
@ -761,7 +764,8 @@ class MV_OT_walk_bookmarks(bpy.types.Operator):
# Run Cleanup. # Run Cleanup.
ctx = opsdata.get_context_for_area(area_fb) ctx = opsdata.get_context_for_area(area_fb)
bpy.ops.file.bookmark_cleanup(ctx) with context.temp_override(**ctx):
bpy.ops.file.bookmark_cleanup()
# !!!!! # !!!!!
# The following section is the most stupid code in the universe. # The following section is the most stupid code in the universe.
@ -913,7 +917,8 @@ class MV_OT_animation_play(bpy.types.Operator):
ctx = opsdata.get_context_for_area(area_media) ctx = opsdata.get_context_for_area(area_media)
bpy.ops.screen.animation_play(ctx) with context.temp_override(**ctx):
bpy.ops.screen.animation_play()
return {"FINISHED"} return {"FINISHED"}
@ -943,7 +948,8 @@ class MV_OT_next_media_file(bpy.types.Operator):
# If not fullscreen, just call select_wall op # If not fullscreen, just call select_wall op
area_fb = opsdata.find_area(context, "FILE_BROWSER") area_fb = opsdata.find_area(context, "FILE_BROWSER")
ctx = opsdata.get_context_for_area(area_fb) ctx = opsdata.get_context_for_area(area_fb)
bpy.ops.file.select_walk(ctx, "INVOKE_DEFAULT", direction=self.direction) with context.temp_override(**ctx):
bpy.ops.file.select_walk(ctx, "INVOKE_DEFAULT", direction=self.direction)
return {"FINISHED"} return {"FINISHED"}
# Get all files and folders and sort them alphabetically. # Get all files and folders and sort them alphabetically.
@ -1040,7 +1046,8 @@ class MV_OT_set_fb_display_type(bpy.types.Operator):
# Redraw if needed to update params. # Redraw if needed to update params.
if not area_fb.spaces.active.params: if not area_fb.spaces.active.params:
bpy.ops.wm.redraw_timer(ctx, type="DRAW_WIN_SWAP", iterations=1) with context.temp_override(**ctx):
bpy.ops.wm.redraw_timer(type="DRAW_WIN_SWAP", iterations=1)
# Set display type. # Set display type.
area_fb.spaces.active.params.display_type = self.display_type area_fb.spaces.active.params.display_type = self.display_type
@ -1123,15 +1130,13 @@ class MV_OT_pan_media_view(bpy.types.Operator):
if area_media.type == "IMAGE_EDITOR": if area_media.type == "IMAGE_EDITOR":
ctx = opsdata.get_context_for_area(area_media) ctx = opsdata.get_context_for_area(area_media)
bpy.ops.image.view_pan( with context.temp_override(**ctx):
ctx, "EXEC_DEFAULT", offset=(self.deltax, self.deltay) bpy.ops.image.view_pan("EXEC_DEFAULT", offset=(self.deltax, self.deltay))
)
elif area_media.type == "SEQUENCE_EDITOR": elif area_media.type == "SEQUENCE_EDITOR":
ctx = opsdata.get_context_for_area(area_media, region_type="PREVIEW") ctx = opsdata.get_context_for_area(area_media, region_type="PREVIEW")
bpy.ops.view2d.pan( with context.temp_override(**ctx):
ctx, "EXEC_DEFAULT", deltax=self.deltax, deltay=self.deltay bpy.ops.view2d.pan("EXEC_DEFAULT", deltax=self.deltax, deltay=self.deltay)
)
# Redraw Area. # Redraw Area.
area_media.tag_redraw() area_media.tag_redraw()
@ -1162,19 +1167,21 @@ class MV_OT_zoom_media_view(bpy.types.Operator):
if area_media.type == "IMAGE_EDITOR": if area_media.type == "IMAGE_EDITOR":
ctx = opsdata.get_context_for_area(area_media) ctx = opsdata.get_context_for_area(area_media)
if self.direction == "IN": with context.temp_override(**ctx):
bpy.ops.image.view_zoom_in(ctx, "EXEC_DEFAULT", location=(0.5, 0.5)) if self.direction == "IN":
bpy.ops.image.view_zoom_in("EXEC_DEFAULT", location=(0.5, 0.5))
elif self.direction == "OUT": elif self.direction == "OUT":
bpy.ops.image.view_zoom_out(ctx, "EXEC_DEFAULT", location=(0.5, 0.5)) bpy.ops.image.view_zoom_out("EXEC_DEFAULT", location=(0.5, 0.5))
elif area_media.type == "SEQUENCE_EDITOR": elif area_media.type == "SEQUENCE_EDITOR":
ctx = opsdata.get_context_for_area(area_media, region_type="PREVIEW") ctx = opsdata.get_context_for_area(area_media, region_type="PREVIEW")
if self.direction == "IN": with context.temp_override(**ctx):
bpy.ops.view2d.zoom_in(ctx, "EXEC_DEFAULT") if self.direction == "IN":
elif self.direction == "OUT": bpy.ops.view2d.zoom_in("EXEC_DEFAULT")
bpy.ops.view2d.zoom_out(ctx, "EXEC_DEFAULT") elif self.direction == "OUT":
bpy.ops.view2d.zoom_out("EXEC_DEFAULT")
# Redraw Area. # Redraw Area.
area_media.tag_redraw() area_media.tag_redraw()
@ -1607,7 +1614,8 @@ class MV_OT_flip_media_view(bpy.types.Operator):
elif active_media_area == "IMAGE_EDITOR": elif active_media_area == "IMAGE_EDITOR":
ctx = opsdata.get_context_for_area(area) ctx = opsdata.get_context_for_area(area)
bpy.ops.image.flip(ctx, use_flip_x=True) with context.temp_override(**ctx):
bpy.ops.image.flip(use_flip_x=True)
else: else:
return {"CANCELLED"} return {"CANCELLED"}

View File

@ -127,7 +127,8 @@ def fit_timeline_view(context: bpy.types.Context, area: bpy.types.Area = None) -
return return
ctx = get_context_for_area(area) ctx = get_context_for_area(area)
bpy.ops.action.view_all(ctx) with context.temp_override(**ctx):
bpy.ops.action.view_all()
def fit_image_editor_view( def fit_image_editor_view(
@ -139,7 +140,8 @@ def fit_image_editor_view(
return return
ctx = get_context_for_area(area) ctx = get_context_for_area(area)
bpy.ops.image.view_all(ctx, fit_view=True) with context.temp_override(**ctx):
bpy.ops.image.view_all(fit_view=True)
def fit_sqe_preview(context: bpy.types.Context, area: bpy.types.Area = None) -> None: def fit_sqe_preview(context: bpy.types.Context, area: bpy.types.Area = None) -> None:
@ -149,7 +151,8 @@ def fit_sqe_preview(context: bpy.types.Context, area: bpy.types.Area = None) ->
return return
ctx = get_context_for_area(area) ctx = get_context_for_area(area)
bpy.ops.sequencer.view_all_preview(ctx) with context.temp_override(**ctx):
bpy.ops.sequencer.view_all_preview()
def fit_view(context: bpy.types.Context, area: bpy.types.Area) -> None: def fit_view(context: bpy.types.Context, area: bpy.types.Area) -> None:
@ -195,7 +198,8 @@ def split_area(
ctx = get_context_for_area(area_split) ctx = get_context_for_area(area_split)
start_areas = screen.areas[:] start_areas = screen.areas[:]
bpy.ops.screen.area_split(ctx, direction=direction, factor=factor) with context.temp_override(**ctx):
bpy.ops.screen.area_split(direction=direction, factor=factor)
for area in screen.areas: for area in screen.areas:
if area not in start_areas: if area not in start_areas:
@ -203,9 +207,10 @@ def split_area(
return area return area
def close_area(area: bpy.types.Area) -> None: def close_area(context: bpy.types.Context, area: bpy.types.Area) -> None:
ctx = get_context_for_area(area) ctx = get_context_for_area(area)
bpy.ops.screen.area_close(ctx) with context.temp_override(**ctx):
bpy.ops.screen.area_close()
def setup_filebrowser_area(filebrowser_area: bpy.types.Area) -> None: def setup_filebrowser_area(filebrowser_area: bpy.types.Area) -> None: