o
    h                     @   sT  d dl Z d dlZd dlmZ d dlmZ d dlmZ	 dd Z
edge dkr)d nddd	d
 Zedgdd Zdd Zedgde dkrJd ndeddddd Zedgde dkrbd ndeddddd Zedgddddd  Zed!gd"de dkrd ndd#d$d% Zed&gd"de dkrd nd'd#d(d) Zd*d+ ZdS ),    N)image_comparisonc              
   C   s*   | j ddd| fddt|dddd d S )	N       ?r   r      bk)
arrowstylefcec)xyxytextsize
arrowprops)annotatedict)axtr r   w/var/www/html/construction_image-detection-poc/venv/lib/python3.10/site-packages/matplotlib/tests/test_arrow_patches.py
draw_arrow   s
   
r   fancyarrow_test_imagex86_64g~jt?)tolc            	      C   s   g d} ddt j g}tjt|t| ddtddd\}}t| D ] \}}t|D ]\}}|||f }t||| |j	ddd	 q+q#d S )
N)皙?333333?皙?皙?r   fancysimpleF)   g      @   )aspect)squeezefigsize
subplot_kw)	labelleftlabelbottom)
mpatches
ArrowStyleFancypltsubplotslenr   	enumerater   tick_params)	r   r   figaxsi_rr1i_tt1r   r   r   r   test_fancyarrow   s   

r7   zboxarrow_test_image.pngc                  C   s   t j } t| }d}|| d }tjd|d fd}d}tt| D ]\}}|jd|| | d | |d||j	t
|dd	d
d q#d S )Ng333333?r   gUUUUUU@g      ?r%   g5@centerwr   )boxstyler
   r   )har   	transformbbox)r)   BoxStyle
get_stylesr.   r,   figurer/   sortedtexttransFigurer   )stylesnspacing	figheightr1   fontsizei	stylenamer   r   r   test_boxarrow   s   
rL   c               	   C   sR   t jdddd} |  }|ddg |ddg |tjddd	d
dd | S )z
    Convenience function that prepares and returns a FancyArrowPatch. It aims
    at being used to test that the size of the arrow head does not depend on
    the DPI value of the exported picture.

    NB: this function *is not* a test in itself!
    fancyarrow_dpi_cor_test)      2   )r%   dpir   r"   )r   r   )皙?g333333?rO   ->d   )posAposBlwr	   mutation_scale)r,   rA   add_subplotset_xlimset_ylim	add_patchr)   FancyArrowPatch)fig2r   r   r   r   !__prepare_fancyarrow_dpi_cor_test4   s   r_   zfancyarrow_dpi_cor_100dpi.pngTg{Gz?rT   )rQ   )remove_textr   savefig_kwargc                   C   
   t   dS )a   
    Check the export of a FancyArrowPatch @ 100 DPI. FancyArrowPatch is
    instantiated through a dedicated function because another similar test
    checks a similar export but with a different DPI value.

    Remark: test only a rasterized format.
    Nr_   r   r   r   r   test_fancyarrow_dpi_cor_100dpiF   s   
rd   zfancyarrow_dpi_cor_200dpi.png   c                   C   rb   )z
    As test_fancyarrow_dpi_cor_100dpi, but exports @ 200 DPI. The relative size
    of the arrow head should be the same.
    Nrc   r   r   r   r   test_fancyarrow_dpi_cor_200dpiU   s   
	rf   zfancyarrow_dash.pngdefault)r`   stylec               
   C   sX   t  \} }tjddddddddd	}tjdddd
ddddd	}|| || d S )N)r   r   r   z-|>zangle3,angleA=0,angleB=90g      $@   dashedr   )r	   connectionstylerX   	linewidth	linestylecolorangle3dotted)r,   r-   r)   r]   r\   )r1   r   ee2r   r   r   test_fancyarrow_dasha   s&   
rs   zarrow_styles.pngmpl20)rh   r`   r   c                  C   s>  t j } t| }tjdd\}}|dd |d| |jddddd t	t
| D ]"\}}t jd|d d	  |fd
|d d	  |f|dd}|| q,t	g dD ]G\}}|}|d dkre|d7 }|d dkro|d7 }t	ddgD ]&\}}	|dt|	}
t jdd| | fdd| | f|
dd}|| quqUd S )N)r!   r!   r8   r   r"   )leftrightbottomtopr   ri   g?g?   )r	   rX   )z]-[z]-z-[z|-|-z,angleA=ANGLEz,angleB=ANGLEi<   ANGLEg?g?)r)   r*   r@   r.   r,   r-   rZ   r[   subplots_adjustr/   rB   r]   r\   replacestr)rE   rF   r1   r   rJ   rK   patchrh   jangler	   r   r   r   test_arrow_stylesv   s8   
 r   zconnection_styles.pngg9v?c                  C   s~   t j } t| }tjdd\}}|dd |d| tt	| D ]\}}t j
d|fd|d fd	|d
d}|| q#d S )N)   
   r8   r   r"   ru   r   rR   r   rS   rz   )r	   rk   rX   )r)   ConnectionStyler@   r.   r,   r-   rZ   r[   r/   rB   r]   r\   )rE   rF   r1   r   rJ   rK   r   r   r   r   test_connection_styles   s   
r   c                  C   s   t jjddd} t jdd| d}tt t 	| W d    n1 s'w   Y  t jjddd}t jdd|d}t 	| d S )N   re   )angleAangleB)r   r   r   )rk   gh@)
r)   r   Angle3r]   pytestraises
ValueErrorr,   gcar\   )conn_style_1p1conn_style_2p2r   r   r   test_invalid_intersection   s   r   )r   platformmatplotlib.pyplotpyplotr,   matplotlib.testing.decoratorsr   matplotlib.patchespatchesr)   r   machiner7   rL   r_   r   rd   rf   rs   r   r   r   r   r   r   r   <module>   sD    



	




