Source code for pdftools_sdk.image2_pdf.shrink_to_fit

from __future__ import annotations
import io
from typing import List, Iterator, Tuple, Optional, Any, TYPE_CHECKING, Callable
from ctypes import *
from datetime import datetime
from numbers import Number
from pdftools_sdk.internal import _lib
from pdftools_sdk.internal.utils import _string_to_utf16, _utf16_to_string
from pdftools_sdk.internal.streams import _StreamDescriptor, _NativeStream
from pdftools_sdk.internal.native_base import _NativeBase
from pdftools_sdk.internal.native_object import _NativeObject

import pdftools_sdk.internal
import pdftools_sdk.image2_pdf.image_mapping

if TYPE_CHECKING:
    from pdftools_sdk.geometry.units.size import Size
    from pdftools_sdk.geometry.units.margin import Margin

else:
    Size = "pdftools_sdk.geometry.units.size.Size"
    Margin = "pdftools_sdk.geometry.units.margin.Margin"


[docs] class ShrinkToFit(pdftools_sdk.image2_pdf.image_mapping.ImageMapping): """ The image mapping that places the image onto pages of the specified size Place images onto portrait or landscape pages. Large images are scaled down to fit onto :attr:`pdftools_sdk.image2_pdf.shrink_to_fit.ShrinkToFit.page_size` . """
[docs] def __init__(self): """ """ _lib.PdfToolsImage2Pdf_ShrinkToFit_New.argtypes = [] _lib.PdfToolsImage2Pdf_ShrinkToFit_New.restype = c_void_p ret_val = _lib.PdfToolsImage2Pdf_ShrinkToFit_New() if ret_val is None: _NativeBase._throw_last_error(False) super()._initialize(ret_val)
@property def page_size(self) -> Size: """ The page size All output pages are created as that size. Default value: "A4" (210mm 297mm) Returns: pdftools_sdk.geometry.units.size.Size """ from pdftools_sdk.geometry.units.size import Size _lib.PdfToolsImage2Pdf_ShrinkToFit_GetPageSize.argtypes = [c_void_p, POINTER(Size)] _lib.PdfToolsImage2Pdf_ShrinkToFit_GetPageSize.restype = c_bool ret_val = Size() if not _lib.PdfToolsImage2Pdf_ShrinkToFit_GetPageSize(self._handle, byref(ret_val)): _NativeBase._throw_last_error(False) return ret_val @page_size.setter def page_size(self, val: Size) -> None: """ The page size All output pages are created as that size. Default value: "A4" (210mm 297mm) Args: val (pdftools_sdk.geometry.units.size.Size): property value Raises: ValueError: The argument is smaller than "3pt 3pt" or larger than "14400pt 14400pt". """ from pdftools_sdk.geometry.units.size import Size if not isinstance(val, Size): raise TypeError(f"Expected type {Size.__name__}, but got {type(val).__name__}.") _lib.PdfToolsImage2Pdf_ShrinkToFit_SetPageSize.argtypes = [c_void_p, POINTER(Size)] _lib.PdfToolsImage2Pdf_ShrinkToFit_SetPageSize.restype = c_bool if not _lib.PdfToolsImage2Pdf_ShrinkToFit_SetPageSize(self._handle, val): _NativeBase._throw_last_error(False) @property def page_margin(self) -> Margin: """ The page margin Default value: 20mm (0.79in) Returns: pdftools_sdk.geometry.units.margin.Margin """ from pdftools_sdk.geometry.units.margin import Margin _lib.PdfToolsImage2Pdf_ShrinkToFit_GetPageMargin.argtypes = [c_void_p, POINTER(Margin)] _lib.PdfToolsImage2Pdf_ShrinkToFit_GetPageMargin.restype = c_bool ret_val = Margin() if not _lib.PdfToolsImage2Pdf_ShrinkToFit_GetPageMargin(self._handle, byref(ret_val)): _NativeBase._throw_last_error(False) return ret_val @page_margin.setter def page_margin(self, val: Margin) -> None: """ The page margin Default value: 20mm (0.79in) Args: val (pdftools_sdk.geometry.units.margin.Margin): property value Raises: ValueError: The argument has negative margin values. """ from pdftools_sdk.geometry.units.margin import Margin if not isinstance(val, Margin): raise TypeError(f"Expected type {Margin.__name__}, but got {type(val).__name__}.") _lib.PdfToolsImage2Pdf_ShrinkToFit_SetPageMargin.argtypes = [c_void_p, POINTER(Margin)] _lib.PdfToolsImage2Pdf_ShrinkToFit_SetPageMargin.restype = c_bool if not _lib.PdfToolsImage2Pdf_ShrinkToFit_SetPageMargin(self._handle, val): _NativeBase._throw_last_error(False) @property def force_fit(self) -> bool: """ Whether to force images to fit into the page If an image is smaller than the specified :attr:`pdftools_sdk.image2_pdf.shrink_to_fit.ShrinkToFit.page_size` , it will be scaled up respecting the aspect ratio to fit within the page dimensions. Default is `False` Returns: bool """ _lib.PdfToolsImage2Pdf_ShrinkToFit_GetForceFit.argtypes = [c_void_p] _lib.PdfToolsImage2Pdf_ShrinkToFit_GetForceFit.restype = c_bool ret_val = _lib.PdfToolsImage2Pdf_ShrinkToFit_GetForceFit(self._handle) if not ret_val: _NativeBase._throw_last_error() return ret_val @force_fit.setter def force_fit(self, val: bool) -> None: """ Whether to force images to fit into the page If an image is smaller than the specified :attr:`pdftools_sdk.image2_pdf.shrink_to_fit.ShrinkToFit.page_size` , it will be scaled up respecting the aspect ratio to fit within the page dimensions. Default is `False` Args: val (bool): property value """ if not isinstance(val, bool): raise TypeError(f"Expected type {bool.__name__}, but got {type(val).__name__}.") _lib.PdfToolsImage2Pdf_ShrinkToFit_SetForceFit.argtypes = [c_void_p, c_bool] _lib.PdfToolsImage2Pdf_ShrinkToFit_SetForceFit.restype = c_bool if not _lib.PdfToolsImage2Pdf_ShrinkToFit_SetForceFit(self._handle, val): _NativeBase._throw_last_error(False) @staticmethod def _create_dynamic_type(handle): return ShrinkToFit._from_handle(handle) @classmethod def _from_handle(cls, handle): """ Internal factory method for constructing an instance using an internal handle. This method creates an instance of the class by bypassing the public constructor. """ instance = ShrinkToFit.__new__(cls) # Bypass __init__ instance._initialize(handle) return instance def _initialize(self, handle): super()._initialize(handle)