Source code for pdftools_sdk.image2_pdf.shrink_to_page

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 ShrinkToPage(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. If an image is too large to fit on a page, the page may be rotated to better accommodate the image. Large images are scaled down to fit onto the PDF page size :attr:`pdftools_sdk.image2_pdf.shrink_to_page.ShrinkToPage.page_size` . """
[docs] def __init__(self): """ """ _lib.PdfToolsImage2Pdf_ShrinkToPage_New.argtypes = [] _lib.PdfToolsImage2Pdf_ShrinkToPage_New.restype = c_void_p ret_val = _lib.PdfToolsImage2Pdf_ShrinkToPage_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 with that size. The default page orientation is portrait, but if the image fits better, the page is rotated to landscape. Default value: "A4" (210mm 297mm) Returns: pdftools_sdk.geometry.units.size.Size """ from pdftools_sdk.geometry.units.size import Size _lib.PdfToolsImage2Pdf_ShrinkToPage_GetPageSize.argtypes = [c_void_p, POINTER(Size)] _lib.PdfToolsImage2Pdf_ShrinkToPage_GetPageSize.restype = c_bool ret_val = Size() if not _lib.PdfToolsImage2Pdf_ShrinkToPage_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 with that size. The default page orientation is portrait, but if the image fits better, the page is rotated to landscape. 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_ShrinkToPage_SetPageSize.argtypes = [c_void_p, POINTER(Size)] _lib.PdfToolsImage2Pdf_ShrinkToPage_SetPageSize.restype = c_bool if not _lib.PdfToolsImage2Pdf_ShrinkToPage_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_ShrinkToPage_GetPageMargin.argtypes = [c_void_p, POINTER(Margin)] _lib.PdfToolsImage2Pdf_ShrinkToPage_GetPageMargin.restype = c_bool ret_val = Margin() if not _lib.PdfToolsImage2Pdf_ShrinkToPage_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_ShrinkToPage_SetPageMargin.argtypes = [c_void_p, POINTER(Margin)] _lib.PdfToolsImage2Pdf_ShrinkToPage_SetPageMargin.restype = c_bool if not _lib.PdfToolsImage2Pdf_ShrinkToPage_SetPageMargin(self._handle, val): _NativeBase._throw_last_error(False) @staticmethod def _create_dynamic_type(handle): return ShrinkToPage._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 = ShrinkToPage.__new__(cls) # Bypass __init__ instance._initialize(handle) return instance def _initialize(self, handle): super()._initialize(handle)