a
    ضa                     @   s   d dl Zd dlmZ d dlmZ d dlmZ	 d dl
mZ d dlmZ edgdddd Zed	gdd
ddd Zedgdd Zedgdd Zdd Zdd Zedgdd
ddd Zedgddgdd d!d" ZdS )#    N)image_comparison)PathZpatheffect1T)remove_textc                  C   s   t  } | ddgddgg | jdddtdddd	d
dtjdddgd}|jtj	dddt
 g tjdddg}| jdd|d d S )N         test)      ?r	   )        r   z->Zangle3)Z
arrowstyleZconnectionstylelw   centerw	linewidth
foreground)Z
arrowpropssizehapath_effects   T-)Z	linestyler   )pltsubplotimshowZannotatedictr   
withStrokeZarrow_patchset_path_effectsStrokeNormalZgrid)ax1txtpe r"   q/Users/vegardjervell/Documents/master/model/venv/lib/python3.9/site-packages/matplotlib/tests/test_patheffects.pytest_patheffect1
   s$    
r$   Zpatheffect2Zmpl20)r   stylec                  C   s~   t  } tdd}| j|dd | j|dd}t j|jt	j
ddd	gd
 | j|ddd}t j|t	j
ddd	gd
 d S )N   )r   r   Znearest)interpolationkcolorsr   r   r   r   z%2.0fT)fmtZuse_clabeltext)r   r   npZarangeZreshaper   contoursetpcollectionsr   r   clabel)ax2ZarrZcntrZclblsr"   r"   r#   test_patheffect2   s    r3   Zpatheffect3c                  C   s  t jg dddd\} | t t g t jdtjdddgd	 t j| gd
gddd}|j	t
 g t jdddddddd}tjdddtj
dddg}|| | | tjddddtjddd d!g}t  jd"d#d$d%d&d'd(}|| d S ))N)r   r   r      r   zo-br4   )r   ztesting$^{123}$r   rr   r+   z
Line 1$^2$Tz
upper left)Zfancyboxlocr   r   z	Drop testwhitezcircle,pad=0.1red)boxstylecolor)r:   Zbboxg      @r(   )   blue)Zshadow_rgbFace)r4   ZxxxxZgray)offsetZhatch	facecolorblackg?)	edgecolorr@   r   g{Gz?g?zHatch shadowK   i  r   )ZfontsizeZweightva)r   plotr   r   SimpleLineShadowr   titler   legendZlegendPatchZwithSimplePatchShadowtextr   Zget_bbox_patchPathPatchEffectZgcf)p1ZlegrI   r!   tr"   r"   r#   test_patheffect3.   s:    

rM   zstroked_text.pngc               
   C   s   g d} d}t g d}t| D ]L\}}|jdd|d  |dd|d	d
d}|tj|d ddt g q"|dd |	dd |
d d S )N)zA B C D E F G H I J K LzM N O P Q R S T U V WzX Y Z a b c d e f g h i jzk l m n o p q r s t u vzw x y z 0123456789z!@#$%^&*()-=_+[]\;'z,./{}|:"<>?2   )r   r   r   r   g{Gz?g?gp=
ף?leftr   r7   )r   rD   r   r:   )xysZfontdict
   rA   r   r   r   off)r   Zaxes	enumeraterI   r   r   r   r   set_xlimset_ylimaxis)Ztext_chunksZ	font_sizeaxichunkrI   r"   r"   r#   test_patheffects_stroked_textJ   s"    	r\   c                  C   sh   t jdd} t td\}|t t g | j	 }t
| |}|d|dksdJ d S )N   )ZdpirS      )r   figurerE   ranger   r   rF   r   ZcanvasZget_rendererZPathEffectRendererZget_path_effectsZpoints_to_pixels)figrK   ZrendererZpe_rendererr"   r"   r#    test_PathEffect_points_to_pixelsf   s    

rb   c                  C   s   t jdd} | jdksJ d S )N)r4   r   )r?   )r   ZSimplePatchShadow_offset)r!   r"   r"   r#   test_SimplePatchShadow_offsets   s    rd   
collectiongQ?)tolr%   c                  C   s   t t dddt ddd\} }t | t | }t|}tjddd	d
tj	ddg}|j
D ]}|| qdtj|ddD ],}|tjdddg |dddd qd S )Nr   rS   r]   r   d   rA   none   )rB   r@   r   )r   r7   r)   r(   r   )r   r   Zsawtoothr=   )r9   r@   rB   )r-   meshgridlinspacesincosr   r.   r   rJ   r   r0   r   r1   r   Zset_bbox)rP   rQ   datacsr!   re   rI   r"   r"   r#   test_collectionx   s"    $




rq   ZtickedstrokeZpngg)\(?)r   
extensionsrf   c               	   C   s  t jdddd\} \}}}t }tj|ddtjdddd	gd
}|| |	d |
dd |dd |jddgddgdtjdddgd d}tdd|}dt|d  d }|j||dt gd |  d}d}	tdd|}
tdd|	}t|
|\}}d| | d  }|d|  d  }d|d  | }|j|||dgd d!}t j|jtjdd"gd# |j|||dgd$d!}t j|jtjd%dd&gd# |j|||dgd'd!}t j|jtjdd(gd# |
dd |dd d S ))Nr   r   )rj   r4   )Zfigsizeri   r   irS   )anglespacinglength)r@   r   r   equalr          )rt   rs   )labelr   e   r
   r	   g333333?   g?i   gMbP?g      @g      @r4   g?r<   )r(   r)   )rs   r+   )r5   <   )rs   ru   )b)rt   )r   Zsubplotsr   Zunit_circlepatchesZ	PathPatchr   ZwithTickedStrokeZ	add_patchrX   rV   rW   rE   r-   rl   rm   rH   rk   r.   r/   r0   )ra   r   r2   Zax3pathpatchZnxrP   rQ   nyZxvecZyvecx1Zx2Zg1Zg2Zg3Zcg1Zcg2Zcg3r"   r"   r#   test_tickedstroke   sV    


r   )Znumpyr-   Zmatplotlib.testing.decoratorsr   Zmatplotlib.pyplotZpyplotr   Zmatplotlib.patheffectsZpatheffectsr   Zmatplotlib.pathr   Zmatplotlib.patchesr   r$   r3   rM   r\   rb   rd   rq   r   r"   r"   r"   r#   <module>   s*   




