Source code for ooodev.draw.shapes.partial.export_jpg_partial

from __future__ import annotations
from typing import Any, Callable, TYPE_CHECKING

from ooodev.mock import mock_g
from ooodev.events.draw_named_event import DrawNamedEvent
from ooodev.events.args.cancel_event_args_export import CancelEventArgsExport
from ooodev.events.args.event_args_export import EventArgsExport
from ooodev.utils.type_var import PathOrStr
from ooodev.loader import lo as mLo
from ooodev.events.lo_events import Events
from ooodev.loader.inst.lo_inst import LoInst

if TYPE_CHECKING:
    from ooodev.draw.filter.export_jpg import ExportJpgT
    from com.sun.star.drawing import XShape
else:
    ExportJpgT = Any


[docs]class ExportJpgPartial: """Partial Class for Shapes that implements jpg export."""
[docs] def __init__(self, component: XShape, events: Events | None = None, lo_inst: LoInst | None = None): """ Constructor. Args: component (XShape): Shape component. events (Events, optional): Events instance. lo_inst (LoInst, optional): Lo Instance. Use when creating multiple documents. Defaults to None. """ self.__component = component if events is None: self.__events = Events(source=self) else: self.__events = events if lo_inst is None: self.__lo_inst = mLo.Lo.current_lo else: self.__lo_inst = lo_inst
[docs] def export_shape_jpg(self, fnm: PathOrStr, resolution: int = 96) -> None: """ Exports shape as jpg image. Args: fnm (PathOrStr, optional): Image file name. resolution (int, optional): Resolution in dpi. Defaults to 96. :events: .. cssclass:: lo_event - :py:attr:`~ooodev.events.draw_named_event.DrawNamedEvent.EXPORTING_SHAPE_JPG` :eventref:`src-docs-event-cancel-export` - :py:attr:`~ooodev.events.draw_named_event.DrawNamedEvent.EXPORTED_SHAPE_JPG` :eventref:`src-docs-event-export` Returns: None: Note: On exporting event is :ref:`cancel_event_args_export`. On exported event is :ref:`event_args_export`. Args ``event_data`` is a :py:class:`~ooodev.draw.filter.export_jpg.ExportJpgT` dictionary. If ``fnm`` is not specified, the image file name is created based on the document name and page number and written to the same folder as the document. """ # pylint: disable=import-outside-toplevel from ooodev.draw.export.shape_jpg import ShapeJpg def on_exporting(source: Any, args: CancelEventArgsExport[ExportJpgT]) -> None: self.__events.trigger(DrawNamedEvent.EXPORTING_SHAPE_JPG, args) def on_exported(source: Any, args: EventArgsExport[ExportJpgT]) -> None: self.__events.trigger(DrawNamedEvent.EXPORTED_SHAPE_JPG, args) exporter = ShapeJpg(shape=self.__component, lo_inst=self.__lo_inst) exporter.subscribe_event_exporting(on_exporting) exporter.subscribe_event_exported(on_exported) exporter.export(fnm, resolution)
# region Events
[docs] def subscribe_event_shape_jpg_exporting( self, callback: Callable[[Any, CancelEventArgsExport[ExportJpgT]], None] ) -> None: """ Add an event listener to current instance that is triggered on exporting. Args: callback (Callable[[Any, CancelEventArgsExport[ExportJpgT]], None]): Callback of the event listener. Returns: None: """ self.__events.on(DrawNamedEvent.EXPORTING_SHAPE_JPG, callback)
[docs] def subscribe_event_shape_jpg_exported(self, callback: Callable[[Any, EventArgsExport[ExportJpgT]], None]) -> None: """ Add an event listener to current instance that is triggered on export complete. Args: callback (Callable[[Any, EventArgsExport[ExportJpgT]], None]): Callback of the event listener. Returns: None: """ self.__events.on(DrawNamedEvent.EXPORTED_SHAPE_JPG, callback)
[docs] def unsubscribe_event_shape_jpg_exporting( self, callback: Callable[[Any, CancelEventArgsExport[ExportJpgT]], None] ) -> None: """ Remove an event listener from current instance. Args: callback (Callable[[Any, CancelEventArgsExport[ExportJpgT]], None]): Callback of the event listener. Returns: None: """ self.__events.remove(DrawNamedEvent.EXPORTING_SHAPE_JPG, callback)
[docs] def unsubscribe_event_shape_jpg_exported( self, callback: Callable[[Any, EventArgsExport[ExportJpgT]], None] ) -> None: """ Remove an event listener from current instance. Args: callback (Callable[[Any, EventArgsExport[ExportJpgT]], None]): Callback of the event listener. Returns: None: """ self.__events.remove(DrawNamedEvent.EXPORTED_SHAPE_JPG, callback)
# endregion Events if mock_g.FULL_IMPORT: pass