
    hL                        d dl mZ d dlmZ d dlmZ ddlmZ  G d dej                        Z	 G d d	e	      Z
 G d
 de	      Z G d de	      Z G d de	      Z G d de	      Zy)    )annotations)Sequence)Any   )Imagec                  D    e Zd ZU dZded<   ddZd	dZ	 	 	 	 	 	 	 	 d
dZy)	TransformzIBase class for other transforms defined in :py:mod:`~PIL.ImageTransform`.zImage.Transformmethodc                    || _         y N)data)selfr   s     P/var/www/html/eduruby.in/venv/lib/python3.12/site-packages/PIL/ImageTransform.py__init__zTransform.__init__   s	    	    c                2    | j                   | j                  fS r   )r
   r   )r   s    r   getdatazTransform.getdata   s    {{DII%%r   c                R    | j                         \  }} |j                  |||fi |S )z?Perform the transform. Called from :py:meth:`.Image.transform`.)r   	transform)r   sizeimageoptionsr
   r   s         r   r   zTransform.transform"   s-     ||~utVT=W==r   N)r   zSequence[Any]returnNone)r   z%tuple[Image.Transform, Sequence[int]])r   ztuple[int, int]r   Image.Imager   r   r   r   )__name__
__module____qualname____doc____annotations__r   r   r    r   r   r	   r	      s@    S&	>	> 	> 		>
 
	>r   r	   c                  <    e Zd ZdZej
                  j                  Zy)AffineTransformag  
    Define an affine image transform.

    This function takes a 6-tuple (a, b, c, d, e, f) which contain the first
    two rows from the inverse of an affine transform matrix. For each pixel
    (x, y) in the output image, the new value is taken from a position (a x +
    b y + c, d x + e y + f) in the input image, rounded to nearest pixel.

    This function can be used to scale, translate, rotate, and shear the
    original image.

    See :py:meth:`.Image.transform`

    :param matrix: A 6-tuple (a, b, c, d, e, f) containing the first two rows
        from the inverse of an affine transform matrix.
    N)r   r   r   r   r   r	   AFFINEr
   r!   r   r   r#   r#   .   s    " __##Fr   r#   c                  <    e Zd ZdZej
                  j                  Zy)PerspectiveTransforma  
    Define a perspective image transform.

    This function takes an 8-tuple (a, b, c, d, e, f, g, h). For each pixel
    (x, y) in the output image, the new value is taken from a position
    ((a x + b y + c) / (g x + h y + 1), (d x + e y + f) / (g x + h y + 1)) in
    the input image, rounded to nearest pixel.

    This function can be used to scale, translate, rotate, and shear the
    original image.

    See :py:meth:`.Image.transform`

    :param matrix: An 8-tuple (a, b, c, d, e, f, g, h).
    N)r   r   r   r   r   r	   PERSPECTIVEr
   r!   r   r   r&   r&   C   s      __((Fr   r&   c                  <    e Zd ZdZej
                  j                  Zy)ExtentTransforma  
    Define a transform to extract a subregion from an image.

    Maps a rectangle (defined by two corners) from the image to a rectangle of
    the given size. The resulting image will contain data sampled from between
    the corners, such that (x0, y0) in the input image will end up at (0,0) in
    the output image, and (x1, y1) at size.

    This method can be used to crop, stretch, shrink, or mirror an arbitrary
    rectangle in the current image. It is slightly slower than crop, but about
    as fast as a corresponding resize operation.

    See :py:meth:`.Image.transform`

    :param bbox: A 4-tuple (x0, y0, x1, y1) which specifies two points in the
        input image's coordinate system. See :ref:`coordinate-system`.
    N)r   r   r   r   r   r	   EXTENTr
   r!   r   r   r)   r)   W   s    $ __##Fr   r)   c                  <    e Zd ZdZej
                  j                  Zy)QuadTransformav  
    Define a quad image transform.

    Maps a quadrilateral (a region defined by four corners) from the image to a
    rectangle of the given size.

    See :py:meth:`.Image.transform`

    :param xy: An 8-tuple (x0, y0, x1, y1, x2, y2, x3, y3) which contain the
        upper left, lower left, lower right, and upper right corner of the
        source quadrilateral.
    N)r   r   r   r   r   r	   QUADr
   r!   r   r   r,   r,   m   s     __!!Fr   r,   c                  <    e Zd ZdZej
                  j                  Zy)MeshTransformz
    Define a mesh image transform.  A mesh transform consists of one or more
    individual quad transforms.

    See :py:meth:`.Image.transform`

    :param data: A list of (bbox, quad) tuples.
    N)r   r   r   r   r   r	   MESHr
   r!   r   r   r/   r/   ~   s     __!!Fr   r/   N)
__future__r   collections.abcr   typingr    r   ImageTransformHandlerr	   r#   r&   r)   r,   r/   r!   r   r   <module>r6      sa    # $  >++ >.$i $*)9 )($i $,"I ""
"I 
"r   