o
    sh                     @  sd   d dl mZ ddlmZ G dd dZG dd dZG dd	 d	ZG d
d dZG dd deZdS )    )annotations   )Imagec                   @  $   e Zd ZdZdddZddd	Zd
S )HDCz
    Wraps an HDC integer. The resulting object can be passed to the
    :py:meth:`~PIL.ImageWin.Dib.draw` and :py:meth:`~PIL.ImageWin.Dib.expose`
    methods.
    dcintreturnNonec                 C  
   || _ d S Nr   )selfr    r   `/var/www/html/construction_image-detection-poc/venv/lib/python3.10/site-packages/PIL/ImageWin.py__init__      
zHDC.__init__c                 C     | j S r   r   r   r   r   r   __int__"      zHDC.__int__N)r   r   r	   r
   r	   r   __name__
__module____qualname____doc__r   r   r   r   r   r   r          
r   c                   @  r   )HWNDz
    Wraps an HWND integer. The resulting object can be passed to the
    :py:meth:`~PIL.ImageWin.Dib.draw` and :py:meth:`~PIL.ImageWin.Dib.expose`
    methods, instead of a DC.
    wndr   r	   r
   c                 C  r   r   r   )r   r   r   r   r   r   -   r   zHWND.__init__c                 C  r   r   r    r   r   r   r   r   0   r   zHWND.__int__N)r   r   r	   r
   r   r   r   r   r   r   r   &   r   r   c                   @  sb   e Zd ZdZ	d#d$d	d
Zd%ddZ	d#d&ddZd'ddZ	d#d(ddZd)dd Z	d*d!d"Z
dS )+Diba&  
    A Windows bitmap with the given mode and size.  The mode can be one of "1",
    "L", "P", or "RGB".

    If the display requires a palette, this constructor creates a suitable
    palette and associates it with the image. For an "L" image, 128 graylevels
    are allocated. For an "RGB" image, a 6x6x6 colour cube is used, together
    with 20 graylevels.

    To make sure that palettes work properly under Windows, you must call the
    ``palette`` method upon certain events from Windows.

    :param image: Either a PIL image, or a mode string. If a mode string is
                  used, a size must also be given.  The mode can be one of "1",
                  "L", "P", or "RGB".
    :param size: If the first argument is a mode string, this
                 defines the size of the image.
    NimageImage.Image | strsizetuple[int, int] | Noner	   r
   c                 C  s   t |tr|}d}|d u rd}t|n|j}|j}|dvr#t|}tj||| _	|| _|| _|rAt |tr:J | 
| d S d S )N z+If first argument is mode, size is required)1LPRGB)
isinstancestr
ValueErrormoder$   r   getmodebasecoredisplayr"   paste)r   r"   r$   r.   msgr   r   r   r   H   s$   

zDib.__init__handleint | HDC | HWNDc              
   C  s`   t |}t|tr(| j|}z| j| W | j|| dS | j|| w | j| dS )a   
        Copy the bitmap contents to a device context.

        :param handle: Device context (HDC), cast to a Python integer, or an
                       HDC or HWND instance.  In PythonWin, you can use
                       ``CDC.GetHandleAttrib()`` to get a suitable handle.
        N)r   r+   r   r"   getdcexpose	releasedc)r   r4   
handle_intr   r   r   r   r7   ]   s   
"z
Dib.exposedsttuple[int, int, int, int]src tuple[int, int, int, int] | Nonec              
   C  sz   |du r	d| j  }t|}t|tr3| j|}z| j||| W | j|| dS | j|| w | j||| dS )am  
        Same as expose, but allows you to specify where to draw the image, and
        what part of it to draw.

        The destination and source areas are given as 4-tuple rectangles. If
        the source is omitted, the entire image is copied. If the source and
        the destination have different sizes, the image is resized as
        necessary.
        N)r   r   )r$   r   r+   r   r"   r6   drawr8   )r   r4   r:   r<   r9   r   r   r   r   r>   o   s   

"zDib.drawr   c              
   C  s`   t |}t|tr(| j|}z| j|}W | j|| |S | j|| w | j|}|S )at  
        Installs the palette associated with the image in the given device
        context.

        This method should be called upon **QUERYNEWPALETTE** and
        **PALETTECHANGED** events from Windows. If this method returns a
        non-zero value, one or more display palette entries were changed, and
        the image should be redrawn.

        :param handle: Device context (HDC), cast to a Python integer, or an
                       HDC or HWND instance.
        :return: The number of entries that were changed (if one or more entries,
                 this indicates that the image should be redrawn).
        )r   r+   r   r"   r6   query_paletter8   )r   r4   r9   resultr   r   r   r?      s   
zDib.query_paletteimImage.Imageboxc                 C  sJ   |   | j|jkr|| j}|r| j|j| dS | j|j dS )a  
        Paste a PIL image into the bitmap image.

        :param im: A PIL image.  The size must match the target region.
                   If the mode does not match, the image is converted to the
                   mode of the bitmap image.
        :param box: A 4-tuple defining the left, upper, right, and
                    lower pixel coordinate.  See :ref:`coordinate-system`. If
                    None is given instead of a tuple, all of the image is
                    assumed.
        N)loadr.   convertr"   r2   rA   )r   rA   rC   r   r   r   r2      s   z	Dib.pastebufferbytesc                 C  s   | j | dS )z
        Load display memory contents from byte data.

        :param buffer: A buffer containing display data (usually
                       data returned from :py:func:`~PIL.ImageWin.Dib.tobytes`)
        N)r"   	frombytes)r   rF   r   r   r   rH      s   zDib.frombytesc                 C  s
   | j  S )zy
        Copy display memory contents to bytes object.

        :return: A bytes object containing display data.
        )r"   tobytesr   r   r   r   rI      s   
zDib.tobytesr   )r"   r#   r$   r%   r	   r
   )r4   r5   r	   r
   )r4   r5   r:   r;   r<   r=   r	   r
   )r4   r5   r	   r   )rA   rB   rC   r=   r	   r
   )rF   rG   r	   r
   )r	   rG   )r   r   r   r   r   r7   r>   r?   r2   rH   rI   r   r   r   r   r!   4   s    


	r!   c                   @  sd   e Zd ZdZ	d#d$ddZd%ddZd&ddZd'ddZd(ddZd&ddZ	d)dd Z
d(d!d"ZdS )*Windowz*Create a Window with the given title size.PILNtitler,   width
int | Noneheightr	   r
   c                 C  s"   t j|| j|p	d|pd| _d S )Nr   )r   r0   createwindow_Window__dispatcherhwnd)r   rL   rM   rO   r   r   r   r      s   
zWindow.__init__actionargsr   c                 G  s   t | d| |  d S )N
ui_handle_)getattr)r   rS   rT   r   r   r   __dispatcher   s   zWindow.__dispatcherr   x0y0x1y1c                 C     d S r   r   r   r   rX   rY   rZ   r[   r   r   r   ui_handle_clear      zWindow.ui_handle_clearc                 C  r\   r   r   )r   rX   rY   rZ   r[   r   r   r   ui_handle_damage   r_   zWindow.ui_handle_damagec                 C  r\   r   r   r   r   r   r   ui_handle_destroy   r_   zWindow.ui_handle_destroyc                 C  r\   r   r   r]   r   r   r   ui_handle_repair   r_   zWindow.ui_handle_repairc                 C  r\   r   r   )r   rM   rO   r   r   r   ui_handle_resize   r_   zWindow.ui_handle_resizec                 C  s   t j  d S r   )r   r0   	eventloopr   r   r   r   mainloop   s   zWindow.mainloop)rK   NN)rL   r,   rM   rN   rO   rN   r	   r
   )rS   r,   rT   r   r	   r
   r   r   rX   r   rY   r   rZ   r   r[   r   r	   r
   )
rX   r   rY   r   rZ   r   r[   r   r	   r
   )r	   r
   )rM   r   rO   r   r	   r
   )r   r   r   r   r   rQ   r^   r`   ra   rb   rc   re   r   r   r   r   rJ      s    





rJ   c                      s.   e Zd ZdZdd fd	d
ZdddZ  ZS )ImageWindowz6Create an image window which displays the given image.rK   r"   Image.Image | DibrL   r,   r	   r
   c                   s8   t |ts	t|}|| _|j\}}t j|||d d S )N)rM   rO   )r+   r!   r"   r$   superr   )r   r"   rL   rM   rO   	__class__r   r   r      s
   

zImageWindow.__init__r   r   rX   rY   rZ   r[   c                 C  s   | j |||||f d S r   )r"   r>   r]   r   r   r   rb      s   zImageWindow.ui_handle_repair)rK   )r"   rh   rL   r,   r	   r
   rf   )r   r   r   r   r   rb   __classcell__r   r   rj   r   rg      s    rg   N)	
__future__r   r&   r   r   r   r!   rJ   rg   r   r   r   r   <module>   s     