o
    h                     @   sN   d Z ddlmZ ddlmZ dd Zdd Zdd	d
ZdddZ	dddZ
dS )z|
========================
Widget testing utilities
========================

See also :mod:`matplotlib.tests.test_widgets`.
    )mockNc                  C   s<   t dd\} }|ddgddg |d | j  |S )z"Create a plot and return its Axes.   r      g      ?)pltsubplotsplot
set_aspectcanvasdraw)figax r   n/var/www/html/construction_image-detection-poc/venv/lib/python3.10/site-packages/matplotlib/testing/widgets.pyget_ax   s
   

r   c                  O   s   d S Nr   )argskwargsr   r   r   noop   s   r   r   c                 C   sr   t  }||_| j||f||fgd \|_|_|||_|_| |_	| j
ddj|_||_||_d|_d|_|S )a  
    Create a mock event that can stand in for `.Event` and its subclasses.

    This event is intended to be used in tests where it can be passed into
    event handling functions.

    Parameters
    ----------
    ax : `~matplotlib.axes.Axes`
        The Axes the event will be in.
    xdata : float
        x coord of mouse in data coords.
    ydata : float
        y coord of mouse in data coords.
    button : None or `MouseButton` or {'up', 'down'}
        The mouse button pressed in this event (see also `.MouseEvent`).
    key : None or str
        The key pressed when the mouse event triggered (see also `.KeyEvent`).
    step : int
        Number of scroll steps (positive for 'up', negative for 'down').

    Returns
    -------
    event
        A `.Event`\-like Mock instance.
    r   T)rootNCustom)r   Mockbutton	transData	transformxyxdataydatainaxes
get_figurer	   keystepguiEventname)r   r   r   r   r    r!   eventr   r   r   
mock_event   s   r%   c           	      C   s*   t | j|||||}t| |}|| dS )aT  
    Trigger an event on the given tool.

    Parameters
    ----------
    tool : matplotlib.widgets.AxesWidget
    etype : str
        The event to trigger.
    xdata : float
        x coord of mouse in data coords.
    ydata : float
        y coord of mouse in data coords.
    button : None or `MouseButton` or {'up', 'down'}
        The mouse button pressed in this event (see also `.MouseEvent`).
    key : None or str
        The key pressed when the mouse event triggered (see also `.KeyEvent`).
    step : int
        Number of scroll steps (positive for 'up', negative for 'down').
    N)r%   r   getattr)	tooletyper   r   r   r    r!   r$   funcr   r   r   do_eventD   s   
r*   c                 C   s   |durt | d|d |d d|d t | d|d |d dd t | d|d |d dd t | d	|d |d dd |durMt | d
|d |d d|d dS dS )a}  
    Helper to simulate a mouse drag operation.

    Parameters
    ----------
    tool : `~matplotlib.widgets.Widget`
    start : [float, float]
        Starting point in data coordinates.
    end : [float, float]
        End point in data coordinates.
    key : None or str
         An optional key that is pressed during the whole operation
         (see also `.KeyEvent`).
    Non_key_pressr   r   )r   r   r   r    press)r   r   r   onmovereleaseon_key_release)r*   )r'   startendr    r   r   r   click_and_drag]   s   
r2   )r   r   r   Nr   r   )__doc__unittestr   matplotlib.pyplotpyplotr   r   r   r%   r*   r2   r   r   r   r   <module>   s    	

)