a
    s=ic"                     @   s.  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dd Zedgd	d
 Zdd Zedgde dkrd ndeddddd Zedgde dkrd 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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)ZxyZxytextsizeZ
arrowprops)Zannotatedict)axtr r   t/home/droni/.local/share/virtualenvs/DPS-5Je3_V2c/lib/python3.9/site-packages/matplotlib/tests/test_arrow_patches.py
draw_arrow   s
    r   Zfancyarrow_test_imagec            	      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	 qVqFd S )
N)皙?333333?皙?皙?r   fancysimpleF)   g      @   )Zaspect)ZsqueezefigsizeZ
subplot_kw)Z	labelleftZlabelbottom)
mpatches
ArrowStyleFancypltsubplotslenr   	enumerater   Ztick_params)	r   r   figZaxsZi_rr1Zi_tt1r   r   r   r   test_fancyarrow   s    

r'   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 qFd S )Ng333333?r   gUUUUUU@g      ?r   g5@centerwr   )Zboxstyler
   r   )Zhar   Z	transformZbbox)r   ZBoxStyle
get_stylesr"   r    figurer#   sortedtextZtransFigurer   )stylesnspacingZ	figheightr$   Zfontsizei	stylenamer   r   r   test_boxarrow   s    
r4   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!
    Zfancyarrow_dpi_cor_test)      2   )r   dpir   r   )r   r   )皙?g333333?r6   ->d   )ZposAZposBZlwr	   mutation_scale)r    r,   Zadd_subplotset_xlimset_ylim	add_patchr   FancyArrowPatch)Zfig2r   r   r   r   !__prepare_fancyarrow_dpi_cor_test3   s    rA   zfancyarrow_dpi_cor_100dpi.pngTx86_64g{Gz?r;   )r8   )remove_texttolZsavefig_kwargc                   C   s
   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rA   r   r   r   r   test_fancyarrow_dpi_cor_100dpiE   s    rF   zfancyarrow_dpi_cor_200dpi.png   c                   C   s
   t   dS )z
    As test_fancyarrow_dpi_cor_100dpi, but exports @ 200 DPI. The relative size
    of the arrow head should be the same.
    NrE   r   r   r   r   test_fancyarrow_dpi_cor_200dpiT   s    	rH   zfancyarrow_dash.pngdefault)rC   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      $@   Zdashedr   )r	   connectionstyler<   Z	linewidthZ	linestylecolorZangle3Zdotted)r    r!   r   r@   r?   )r$   r   ee2r   r   r   test_fancyarrow_dash`   s&    
rP   zarrow_styles.pngZmpl20g{Gzt?)rJ   rC   rD   c                  C   s>  t j } t| }tjdd\}}|dd |d| |jddddd t	t
| D ]D\}}t jd|d d	  |fd
|d d	  |f|dd}|| qXt	g dD ]\}}|}|d dkr|d7 }|d dkr|d7 }t	ddgD ]L\}}	|dt|	}
t jdd| | fdd| | f|
dd}|| qqd S )N)r   r   r(   r   r   )leftrightbottomtopr   rK   g?g?   )r	   r<   )z]-[z]-z-[z|-|-z,angleA=ANGLEz,angleB=ANGLEi<   ZANGLEg?g?)r   r   r+   r"   r    r!   r=   r>   Zsubplots_adjustr#   r-   r@   r?   replacestr)r/   r0   r$   r   r2   r3   patchrJ   jZangler	   r   r   r   test_arrow_stylesu   s4    
 r]   zconnection_styles.png)rJ   rC   c                  C   s~   t j } t| }tjdd\}}|dd |d| tt	| D ]2\}}t j
d|fd|d fd	|d
d}|| qFd S )N)   
   r(   r   r   rQ   r   r9   r   r:   rV   )r	   rL   r<   )r   ConnectionStyler+   r"   r    r!   r=   r>   r#   r-   r@   r?   )r/   r0   r$   r   r2   r3   r[   r   r   r   test_connection_styles   s    
ra   c                  C   s   t jjddd} t jdd| d}tt t 	| W d    n1 sN0    Y  t jjddd}t jdd|d}t 	| d S )N   rG   )ZangleAZangleB)r   r   r   )rL   gh@)
r   r`   ZAngle3r@   pytestZraises
ValueErrorr    Zgcar?   )Zconn_style_1p1Zconn_style_2p2r   r   r   test_invalid_intersection   s    ,rg   )rc   platformZmatplotlib.pyplotZpyplotr    Zmatplotlib.testing.decoratorsr   Zmatplotlib.patchesZpatchesr   r   r'   r4   rA   machiner   rF   rH   rP   r]   ra   rg   r   r   r   r   <module>   s:   



	



