o
    hq                    @   s  d dl Z 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l
mZ d dlmZ d dlmZmZ d dlmZmZmZmZmZ d dlZd dlmZ d dlZejdd Zd	d
 Zej !de" e"ddde"dddde"e"dddgdd Z#ej !dddgej !dd dgddgddggej !dd dgddgddggdd Z$ej !dddgd d!ggd"d# Z%d$d% Z&d&d' Z'd(d) Z(ej !d*dd gd+d, Z)ej !d*dd gd-d. Z*d/d0 Z+ej !d1ej,ej-gd2d3 Z.d4d5 Z/ej !d6d dgd7d8 Z0d9d: Z1d;d< Z2ej !d=dd gd>d? Z3ej !d@dd gdAdB Z4ej !dCdDd e"dddEfdFde"ddGfdDd e"e"dddfdDd e"ddHfgdIdJ Z5ej !d=dd gdKdL Z6ej !d@dd gdMdN Z7ej !dOdd gdPdQ Z8dRdS Z9dTdU Z:ej !dVdWdXgdYdZ Z;ej !dVdWdXgd[d\ Z<d]d^ Z=d_d` Z>ej !dadbdcdd Z?ej j@deddfdgdh ZAdidj ZBdkdl ZCdmdn ZDej !de" e"d e"dodpdqe"dddgdrds ZEdtdu ZFdvdw ZGdxdy ZHej !dzg d{d|d} ZId~d ZJedgddddd ZKedgddd ZLedgddd ZMdd ZNedgddd ZOedgddd ZPedgddd ZQdd ZRdd ZSdd ZTdd ZUdd ZVdd ZWej !ddDdFgdd ZXej !ddDdFgdd ZYdd ZZdd Z[dd Z\ej !dd dgdd Z]ej !dd dgdd Z^e dd Z_ej !dg dej !dd dgdd Z`ej !dd dgdd Zaej !dd dgdd Zbej !dd dgedgddd Zcdd Zddd Zeej !dd dgej !dd dgdd ZfdS )    N)mock)
MouseEvent)check_figures_equalimage_comparison)click_and_dragdo_eventget_ax
mock_eventnoop)assert_allclosec                   C   s   t  S N)r    r   r   q/var/www/html/construction_image-detection-poc/venv/lib/python3.10/site-packages/matplotlib/tests/test_widgets.pyax   s   r   c            
   	   C   sP  ddl m} m} ddlm} | dvrtd tjdddddgd	\}}||d
 ddg}||d ddgddgddgdddgddgdd}| |d ddgddgd}| |d ddgddgddgddgdddgddgddddgid}|d
 	d |d 	d  |j
  t }	|j|	d!d" W d    d S 1 sw   Y  d S )#Nr   )CheckButtonsRadioButtons)"_get_running_interactive_framework)headlessNz-Callback exceptions are not raised otherwise.   )   r      )nrowsncolsfigsizewidth_ratiosr   r   ApplesOrangesr   r   redorange      colorfontsize	mistyrose	peachpuff	edgecolor	facecolorlabel_propsradio_props)r   r   T)actives)r   r   r$   darkred
darkorange)r.   r,   frame_propscheck_propsDefaultStylizedpdf)format)matplotlib.widgetsr   r   matplotlib.cbookr   pytestxfailpltsubplots	set_titlecanvasdrawioBytesIOsavefig)
r   r   r   figr   
default_rb	styled_rb
default_cb	styled_cbresult_afterr   r   r   test_save_blitted_widget_as_pdf   sJ   






"rI   kwargsTr   )useblitbutton
   pixels)minspanxminspany
spancoords)fillpropsc                 C   s   t jtd d}tj| fd|i|}t|ddddd t|ddddd t|d	d
d
dd |dd dvrDt|jg dg dg|jd |	  |j
\\}}}|jdksVJ |jdks]J |jdksdJ |jdkskJ |i ksqJ d S )Nspecreturn_valueonselectpressd   r   xdataydatarL   onmove   release   drawtype)linenone)      Y@rZ   r_   r_   rZ   )rZ   r_   r_   rZ   rZ   )err_msg)r   Mockr
   widgetsRectangleSelectorr   getr   geometryassert_called_once	call_argsr\   r]   )r   rJ   rX   toolepressereleaser   r   r   test_rectangle_selector@   s&   rq   rQ   datazminspanx, x1      %@   zminspany, y1c                 C   s&  t jtd d}d\}}|dkr!| j||f| j||f \}}tj| |d|||d}	t|	||f||fd |	jr<J |	  t|	ddd |	jsLJ |
  |  t|	||f||fd |	jrdJ |
  |j\\}
}}|
j|ksvJ |
j|ks}J |j|ksJ |j|ksJ |i ksJ d S )	NrU   rM   rM   rN   T)rX   interactiverQ   rO   rP   startendr"   r"      r|   )r   rg   r
   	transData	transformrh   ri   r   _selection_completedassert_not_calledrl   
reset_mockrm   r\   r]   )r   rQ   rO   x1rP   y1rX   x0y0rn   ro   rp   rJ   r   r   r   test_rectangle_minspan_   s4   



r   zdrag_from_anywhere, new_center)<   K   Fr|   r"   c                 C   sh   t j| d|d}t|ddd |jdksJ t|ddd |j|ks$J t|d	d
d |jdks2J d S )NT)rv   drag_from_anywherer   rM   rZ   x   rw   )2   A         #   r         r      )      )rh   ri   r   center)r   r   
new_centerrn   r   r   r   test_rectangle_drag   s   r   c                 C   s   t j| dtdddtddd}t|dd	d
 |j}| tjdddks'J |jddd | tjdddks;J |j	D ]}|
 dksHJ | dksPJ q>|jddd |j	D ]}|
 dkseJ | dksmJ q[d S )NTb皙?r*   alpha      ?r   )rv   rT   handle_propsr   r   rw   r333333?black)markeredgecolorr   )rh   ri   dictr   _selection_artistget_facecolormcolorsto_rgba	set_props_handles_artistsget_markeredgecolor	get_alphaset_handle_propsr   rn   artistr   r   r   .test_rectangle_selector_set_props_handle_props   s"   


r   c                 C   s  t j| dd}t|ddd |jdksJ |j}|d |d }}|d	 |d
 }}t|||f||fd |j|d ||d |fksDJ |j}|d |d |d |d  d  }}|d	 |}}t|||f||fd |j|d ||d |d fks}J |j}|d |d |d |d  d  }}|d |}}t|||f||fd |j||d |d |d fksJ |j}|d |d }}|d |d }}t|||f||fd |j||d ||d fksJ d S )NTrv   r   r   rw   )        re         $@      ^@r      rM   r   r   r   r   r"   r   )rh   ri   r   extents)r   rn   r   r\   r]   	xdata_new	ydata_newr   r   r   test_rectangle_resize   s.   &"&""r   c                 C   s   t j| dd}t|ddd tt |d W d    n1 s#w   Y  tt |d W d    n1 s=w   Y  |d |d	 |d
 d S )NTr   F   r   }      rw   unsupported_stateclearmovesquarer   )rh   ri   r   r9   raises
ValueError	add_stater   rn   r   r   r   test_rectangle_add_state   s   

r   r   c                 C   s  t j| dd}t|ddd |jdksJ |r|d d }nd}|j}|d	 |d
 }}d\}}|| || }	}
t|||f|	|
f|d |j|d | |	|d | |
fksYJ |j}|d	 |d |d
 |d  d  }}d}|| |}	}
t|||f|	|
f|d |j|d | |	|d |d
 fksJ |j}|d	 |d |d
 |d  d  }}d}|| |}	}
t|||f|	|
f|d |j|d | |	|d |d
 fksJ |j}|d |d |d
 |d  d  }}d}|| |}	}
t|||f|	|
f|d |j|	|d	 | |d |d
 fksJ |j}|d |d |d
 |d  d  }}d}|| |}	}
t|||f|	|
f|d |j|	|d	 | |d |d
 fksSJ |j}|d |d }}d\}}|| || }	}
t|||f|	|
f|d |j|	|d	 | |
|d
 | fksJ d S )NTr   r   r   rw   )     Q@     @_@     @P@g     @`@r   controlr   r   rM   r   rx   ry   keyr   r   rM   r   r"   r   rh   ri   r   r   r   r   r   rn   use_keyr   r\   r]   xdiffydiffr   r   r   r   r   test_rectangle_resize_center   s   

&
&
&&r   c                 C   s  t j| dd}t|ddd |jdksJ |r|d d }nd}|j}|d	 |d
 }}d\}}|| || }	}
t|||f|	|
f|d |j|d |	|d |d
 | fksYJ |j}|d	 |d |d
 |d  d  }}d}|| |}	}
t|||f|	|
f|d |j|d |	|d |d
 | fksJ |j}|d	 |d |d
 |d  d  }}d}|| |}	}
t|||f|	|
f|d |j|d |	|d |d
 | fksJ |j}|d |d |d
 |d  d  }}d}|| |}	}
t|||f|	|
f|d |j|	|d	 |d |d
 | fksJ |j}|d |d |d
 |d  d  }}d}|| |}	}
t|||f|	|
f|d |j|	|d	 |d |d
 | fksSJ |j}|d |d }}d\}}|| || }	}
t|||f|	|
f|d |j|d | |d	 |
|d
 fksJ d S )NTr   r   r   s   rw   r   r   r   g     \@r   shiftr   r   r   r   r   r   rM   r   r   r   r   r   r   r   r   r   test_rectangle_resize_square.  s   

&
&
&&r   c           	      C   s(  t j| dd}t|ddd |d |d t|jd |j}|d	 |d
 }}d\}}|| || }}t|||f||fd t|j|d | ||d | |d
 | f |j}|d	 |d |d
 |d  d  }}d}|| |}}t|||f||fd t|j|d | ||d | |d
 | f |j}|d	 |d |d
 |d  d  }}d}|| |}}t|||f||fd t|j|d | ||d | |d
 | f |j}|d |d |d
 |d  d  }}d}|| |}}t|||f||fd t|j||d	 | |d | |d
 | f |j}|d |d |d
 |d  d  }}d}|| |}}t|||f||fd t|j||d	 | |d | |d
 | f |j}|d |d }}d\}}|| || }}t|||f||fd t|j|d | |d	 | ||d
 | f d S )NTr   r   r   rw   r   r   r   r   r   r   r   r   rM   r   r   r   r   )rh   ri   r   r   r   r   )	r   rn   r   r\   r]   r   r   r   r   r   r   r   #test_rectangle_resize_square_centerx  sj   

&&&&
r   selector_classc                 C   sP  || dd}t |ddd |jdksJ t|jdksJ t|dd	d
 |jdhks,J t|jdks5J t |ddd t|dd	d
 t|jdksLJ |jdksSJ t|jddd d|_|jdkseJ t|jt	g dg dgdd t |ddd t|jddd |t
jkrtt d|j_W d    d S 1 sw   Y  d S d S )NTr   rZ   rZ   r      rw   rZ   r   rZ   r   r   on_key_pressr   r   rotater   )r      g(\9@g{Gz?)atol-   )gR]@     xa@g=
ףp[@g     V@)g     W@g=
ףp]@g     b@g(\^@)n   r   )r      )rZ   r   rZ   g
ףp=b@unvalid_value)r   r   len_stater   r   rotationcornersnparrayrh   ri   r9   r   r   r   rotation_point)r   r   rn   r   r   r   test_rectangle_rotate  s6   


"r   c                 C   s   t j| dd}t|ddd |jdksJ t|jdksJ dD ]}|| t|jd	ks0J || t|jdks>J q d S )
NTr   r   r   rw   r   r   )r   r   r   r   )rh   ri   r   r   r   r   r   remove_state)r   rn   stater   r   r   test_rectangle_add_remove_set  s   

r   use_data_coordinatesc                 C   s`  |  d tj| d|d}t|ddd |jdksJ |d |d	 |ry|j}|d
 |d |d
 |d  }}}d|d |d |d  d  }}|| |}	}
|d | }t|||f|	|
fd t|j|d | |	|| || g d S |j}|d
 |d }}d}|| |}	}
|d
 |j }t|||f|	|
fd t|j|d | |	ddg d S )N皙?T)rv   r   r   r   rw   r   r   r   r   r   r   rM   r   g      G@g     `@)
set_aspectrh   ri   r   r   r   r   _aspect_ratio_correction)r   r   rn   r   r\   r]   widthr   ycenterr   r   ychanger   r   r   *test_rectangle_resize_square_center_aspect  s6   


$"

r  c                 C   s   t j| ddd}d|_t|ddd |jdksJ t|d	dd
d |jdks(J t|dddd dd |jD }|g dks@J t|d	ddd dd |jD }|g dksXJ |jjdks`J t|jdddf ddg dS )z'For ellipse, test out the key modifiersrM   T)
grab_rangerv   rZ      rZ   r  r   r   )r   r   rw   )r      r   r
  r   r   r   )r   r   r   r   ru   )r   r|   r   c                 S      g | ]}t |qS r   int.0er   r   r   
<listcomp>      z test_ellipse.<locals>.<listcomp>)rM   r   rM   r   r   z
ctrl+shiftc                 S   r  r   r  r  r   r   r   r    r  )r   r   r   r   )r   I   Nr   r   rZ   )rh   EllipseSelectorr   r   rk   shaper   )r   rn   r   r   r   r   test_ellipse	  s    r  c                 C   s   t j| dddddd}d|_t|jd |jdksJ t|jd	 |jdks)J t|d
dd |jdks7J t|ddd |jdksEJ t|dd
d |jdksSJ t|j	j
d  dsaJ t|j	j
d  dsoJ d S )NrM   Tr   r   )markerfacecolorr   )r  rv   r   r  ))rZ   r  r  rZ   )rZ   rZ   r  r  ))rZ   r   r  r   )r   rZ   r   r  r   )r   r   rw   )r   r  r   r  )   r  )l      r  r  ru   )rM   rZ   rM   rZ   r   )rh   ri   r   r   r   edge_centersr   r   
same_color_corner_handlesartistsget_markerfacecolorr   r   r   r   r   test_rectangle_handles$  s0   
r   rv   c                 C   sd   t jtd d}tj| ||d}t|ddd |  |jdks!J |  t|ddd |  d S )NrU   )rX   rv   rZ   r   r  r   rw   re        b@g     [@r   rM   rZ   )	r   rg   r
   rh   ri   r   rl   r   r   r   rv   rX   rn   r   r   r    test_rectangle_selector_onselectC  s   r'  ignore_event_outsidec                 C   s   t jtd d}tj| ||d}t|ddd |  |jdks!J |  t|ddd |r;|	  |jdks9J d S |  |jd	ksFJ d S )
NrU   )rX   r(  r!  r"  rw   r#  r  r  r   r   )r$        d@r$  r+  )
r   rg   r
   rh   ri   r   rl   r   r   r   )r   r(  rX   rn   r   r   r   &test_rectangle_selector_ignore_outsideT  s   r,  z$orientation, onmove_callback, kwargs
horizontal)minspanrK   vertical)rL   r   c                 C   s   t jtd d}t jtd d}|r||d< | d |  }tj| ||fi |}t|ddddd t|dd	d	dd t|d
dddd |dd	 |rS|dd	 d S d S )NrU   onmove_callbackautorY   rZ   r   r[   r^   r_   r`   ra   )	r   rg   r
   r   twinxrh   SpanSelectorr   assert_called_once_with)r   orientationr0  rJ   rX   r^   taxrn   r   r   r   test_span_selectork  s   
r7  c                 C   sf   t jtd d}tj| |d|d}t|ddd |  |jdks"J |  t|ddd |  d S )	NrU   r-  r   r   )r  rZ   rw   )rZ   r  r%  )	r   rg   r
   rh   r3  r   rl   r   r   r&  r   r   r   test_span_selector_onselect  s   
r8  c                 C   s   t jtd d}t jtd d}tj| |d||d}t|ddd |  |  |jdks.J |  |  t|dd	d |rP|	  |	  |jdksNJ d S |  |  |jd
ks_J d S )NrU   r-  )r0  r(  r   r	  rw   )rZ   r   r)  r*  )r  r   )
r   rg   r
   rh   r3  r   rl   r   r   r   )r   r(  rX   r^   rn   r   r   r   !test_span_selector_ignore_outside  s(   
r9  r   c                 C   s   t j| tdd|d}t|ddd |jdksJ t|dd	d |r)|jd
ks(J n|jdks0J t|ddd |jdks>J d S )Nr-  T)rX   	directionrv   r   ru   r   rw   r%  r   r   )r"   r   )r   r   r   r   )rh   r3  r
   r   r   )r   r   rn   r   r   r   test_span_selector_drag  s   
r;  c                 C   s   t j| tddd}|jdksJ |jjdksJ tt t j| tdd}W d    n1 s0w   Y  d|_|jdks?J |jjdksGJ tt d|_W d    d S 1 s[w   Y  d S )Nr-  T)rX   r:  rv   invalid_direction)rX   r:  r/  invalid_string)rh   r3  r
   r:  _edge_handlesr9   r   r   r   r   r   r   test_span_selector_direction  s    
"r?  c              	   C   s   t j| tddtdddtddd}t|d	d
d |j}| tjdddks)J |j	ddd | tjdddks=J |j
D ]}| dksJJ | dksRJ q@|jddd |j
D ]}| dksgJ | dksoJ q]d S )Nr-  Tr   r   r   r   r   )rX   r:  rv   rT   r   r   r   rw   r   r   r$   r   )rh   r3  r
   r   r   r   r   r   r   r   r   	get_colorr   r   r   r   r   r   )test_span_selector_set_props_handle_props  s$   



rB  selectorspan	rectanglec                 C   s   t | dd}|dkrtj}d|d< t|d< ntj}|di |}t|ddd	 t|d
d
d	 |jr3J d|d< |di |}|jsCJ t|ddd	 t|d
d
d	 |jsVJ t|ddd |jrbJ d S )NT)r   rv   rD  r-  r:  rX   ru   r   rw   )r   r   r(  r   escaper   r   )	r   rh   r3  r
   ri   r   r   r(  r   )r   rC  rJ   Selectorrn   r   r   r   test_selector_clear  s$   



rH  c                 C   s   |dkrt j| tdddd}nt j| dd}t|ddd |js"J | s(J |dkr3|jd	ks3J |  |jr<J | rBJ t|dd
d |jsNJ | sTJ |dkr_|jdksaJ d S d S )NrD  r-  T)rX   r:  rv   r(  r   ru   r   rw   r%  )r   r   )rM   r   )	rh   r3  r
   ri   r   r   get_visibler   r   )r   rC  rn   r   r   r   test_selector_clear_method  s*   



rJ  c                 C   s   t j| tddd}tt |d W d    n1 sw   Y  tt |d W d    n1 s8w   Y  tt |d W d    n1 sRw   Y  |d d S )Nr-  Tr   r   r   r   r   )rh   r3  r
   r9   r   r   r   r   r   r   r   test_span_selector_add_state0  s   
rK  c                 C   s   g d}t j| |ddd}|jD ]}| rJ | rJ q|d |d |jD ]}| s4J | s:J q,|j|ksBJ d S )N)r"   r|   r   r-  F)rK   T)rh   ToolLineHandlesr  get_animatedrI  set_visibleset_animated	positions)r   rP  tool_line_handler   r   r   r   test_tool_line_handle>  s   




rR  r:  )r-  r/  c                 C   s  t dd\}}|ddgddg |j  | }| }tj|t	| dd}| |ks0J | |ks8J | dkr>|n|}|j
jt|ksJJ d}d	}|}	t|||d
 | |ks_J | |ksgJ | dkrmdnd}
||
 |	|
 g}|j
j|ksJ d S )Nr   rM   r"   r|   Tr   r-  )rs   g      '@)rt      rw   r   )r;   r<   plotr>   r?   
get_xbound
get_yboundrh   r3  printr>  rP  listr   )r:  rC   r   x_boundy_boundrn   bound
press_data	move_datarelease_dataindexhandle_positionsr   r   r   test_span_selector_boundQ  s&   
ra  QtAgg)skip_on_importerrorc               	      s  t ddt j dt t \} }|jdd\}|jg dd\ td || | j	
| j  fdd}tj||d	|dddd
}ddg}ddg}t|d|d |d dd t|d|d |d dd | | fkswJ |jdu s~J  jsJ t  d |   jdu sJ ddg}ddg}ddg}t|d|d |d dd t|d|d |d dd |jdu sJ  jsJ t  d t|d|d |d dd  jdu sJ dS )zACheck that the animated artists changed in callbacks are updated.r   r   rZ   T)animated皙?c                    s<   t | |f\}}||  } t | d S r   )r   searchsortedmeanset_data	full_like)vminvmaxindminindmaxvln2valuesxr   r   rg  ~  s   z:test_span_selector_animated_artists_callback.<locals>.meanr-  )r:  r0  rv   r   rK   r   rY   r[   r^   FgSG-?   r   gȄC(r`   N)r   linspacepisinr;   r<   rT  pausedraw_artistr>   blitbboxrh   r3  r   _get_animated_artistsstaler   	get_ydataupdate)rC   r   lnrg  rD  r\  r]  r^  r   ro  r   ,test_span_selector_animated_artists_callbackm  sJ   





r  c                 C   s`   dd }t j| |dd}|j}tddd}tg d}tg d	}|||}t|| d S )
Nc                  W      d S r   r   )argsr   r   r   rX     s   z4test_snapping_values_span_selector.<locals>.onselectr-  )r:  r   r   rt   )
gre  r   r   333333?ffffff??g
ףp=
@      @      @)
r   r   r   r   r   r         ?r  r  r  )rh   r3  _snapr   rt  r   r   )r   rX   rn   snap_functionsnap_valuesrq  expectr   r   r   "test_snapping_values_span_selector  s   
r  c                    sl    fdd}t dd }tj |d|d}d|_|jdks J d |_|jd u s*J d|_|jdks4J d S )	Nc                    s
   d _ d S )NT)_got_onselect)rj  rk  r   r   r   rX     s   
z)test_span_selector_snap.<locals>.onselectr   rs  r-  )r:  r  )   r   )r!   $   )r   arangerh   r3  r   r  )r   rX   r  rn   r   r  r   test_span_selector_snap  s   
r  c                 C   s\   t j| dd ddd}d|_|jdksJ |jsJ d}d}t|||d	 |jdks,J d S )
Nc                 S   r  r   r   )ar   r   r   r   <lambda>      z,test_span_selector_extents.<locals>.<lambda>r-  T)r(  )r   rM   )      )r"   r  rw   )rh   r3  r   r   r   )r   rn   r\  r^  r   r   r   test_span_selector_extents  s   
r  r   )r$   )rK   rT   c                 C   sl   t jtd d}tj| fd|i|}t|ddddd t|ddddd t|d	d
d
dd |g d d S )NrU   rX   rY   rZ   r   r[   r^   r   r`   r  )r   r	  r)  )r   rg   r
   rh   LassoSelectorr   r4  )r   rJ   rX   rn   r   r   r   test_lasso_selector  s   r  c                 C   s   t jtd d}tj| |tdddd}|j}t|	 ds J |
 dks(J |jddd t|	 ds9J |
 dksAJ d S )NrU   r   r   r@  )rX   rT   r   r   )r   rg   r
   rh   r  r   r   r   r  rA  r   r   )r   rX   rn   r   r   r   r   test_lasso_selector_set_props  s   
r  c              
   C   s   t jtd d}t| d|}|j}t| dsJ |	 dks#J |
 dks+J tj| d|tddddd	d
}|j}t| dsGJ | dksOJ |
 dksWJ |	 dks_J |d |d t| dssJ | dks{J d S )NrU   r   r   -r   darkbluer   r   )	linestyler$   r   lwrS   r   r   )r   rg   r
   rh   Lassorc   r   r  rA  get_linestyleget_lwr   r   	set_color	set_alpha)r   rX   rn   rc   r   r   r   test_lasso_set_props  s$   


r  c              	   C   s2  d}t | |d}| g dksJ |d | g dks"J | dgks+J |  | g dks9J | g ksAJ dt|t|d fD ]}tt	 |j|d	 W d    n1 sdw   Y  qLd
D ]}tt
 |jd|d W d    n1 sw   Y  ql|dd }|| d S )N)r  r   c)TFTr   )FFTr  )FFFr   )r_  )invalidr  r   )r   c                   S   r  r   r   r   r   r   r   r    r  z#test_CheckButtons.<locals>.<lambda>)rh   r   
get_status
set_activeget_checked_labelsr   r   r9   r   r   	TypeError
on_clicked
disconnect)r   labelscheckinvalid_indexinvalid_valuecidr   r   r   test_CheckButtons	  s*   
r  toolbar)rd   toolbar2toolmanagerc                 C   s   t jd| tjtd d}tjtd d}t| d}|| |	| |j
dks,J t|d |d |j
dks=J |jdksDJ |  |  |jdksSJ t|dddd	 t|d
dd t|d
dd |jdkspJ d S )Nr  rU    _clickzx**2r   r   r   r\   r]   	_keypress+r   5r   )r;   rcParams_setr   rg   r
   rh   TextBox	on_submiton_text_changetextr   set_val
call_countbegin_typingstop_typing)r   r  submit_eventtext_change_eventrn   r   r   r   test_TextBox   s$   



r  c                 C   sZ   t | d}|d |jdksJ |jdksJ |  |jdks$J |jdks+J d S )NRadio 1Radio 2zRadio 3r   r  r  r   )rh   r   r  value_selectedindex_selectedr   )r   radior   r   r   test_RadioButtons@  s   
r  zcheck_radio_buttons.pngmpl20)styleremove_textc            
   	   C   s   t  } | jdd}|jdd |d}t|d}|d}t|dd	}|d
}tj|dg dg ddg dg ddd}|d}tj|dd	g dg ddg dg dddg did}	d S )NFrootr   )left)皙?r  r   333333?r  )r  r   r   r  )zCheck 1zCheck 2zCheck 3)FTT)r  r   r   r  )   r  r!   )r   greenblue)r%   r$   )r&   	palegreen	lightbluer(   r+   )r  re  r   r  r$   r,   r1   r2   )r   
get_figuresubplots_adjustadd_axesrh   r   r   )
r   rC   rax1rb1rax2cb1rax3rb3rax4cb4r   r   r   test_check_radio_buttons_imageJ  s<   





r  png)
extensionsc                 C   s   t |  ddg |jg g d}|jddgddg|jtjd d d d	d
gd |jddd|jdd |jddd|jdd d S )Nteacoffeexticksyticksr  UUUUUU?UUUUUU?	font.sizer   C0rd   )r~   sr        ?r   r~   va)	rh   r   r<   add_subplotscatter	transAxesr;   r  r  fig_testfig_refr   r   r   r   test_radio_buttonsi  s   r  c                 C   sl   dgdgd}dddd}t j| dd	g||d
 t |  dd	g}|| |i |ddi d S )Nr      r#   r  r  r   r*   r)   	linewidthr  r  r+   r        b@)rh   r   r<   set_label_propsset_radio_props)r   r  r,   r-   cbr   r   r   test_radio_buttons_propss  s   
r
  c                 C   sf   t jtdd tj| ddgdddid}W d    n1 sw   Y  t|j dd	gs1J d S )
Nz"Both the \*activecolor\* parameter)matchr  r  r   r*   r  )activecolorr-   rd   )	r9   warnsUserWarningrh   r   r   r  _buttonsr   )r   rbr   r   r   !test_radio_button_active_conflict  s   r  c                 C   s:   t j| ddgdd t j|  ddgdd}d|_d S )Nr  r  r  )r  r   )rh   r   r<   r  )r   r  r	  r   r   r   %test_radio_buttons_activecolor_change  s   
r  c                 C   s   t |  ddgddg |jg g d}|jddgddgd|jtjd	 d
 d
 ddgd |jddgddgd|jtjd	 d
 d
 ddgd |jddd|jdd |jddd|jdd d S )Nr  r  Tr  r  r  r  r  r  r   rd   )markerr~   r  r  rr  kr  r   r  )	rh   r   r<   r  r  r  r;   r  r  r  r   r   r   test_check_buttons  s   r  c                 C   s   dgdgd}dddd}ddd}t j| d	d
gddg|||d t |  d	d
gddg}|| |i |ddi |d|d< |i |ddi d S )Nr   r  r#   r  r  r   r  )r*   r  r  r  Tr  r  r  r*   r)   )rh   r   r<   r  set_frame_propspopset_check_props)r   r  r,   r1   r2   r	  r   r   r   test_check_button_props  s   

r  c                  C   s   t  \} }tt tj|ddddd W d    n1 s w   Y  tt tj|ddddd W d    d S 1 s@w   Y  d S )Nr  r         8@r   )r   labelvalminvalmax	slidermin)r   r  r  r  	slidermax)r;   r<   r9   r   r   rh   Slider)rC   r   r   r   r   'test_slider_slidermin_slidermax_invalid  s   "r!  c                  C   sp   t  \} }tj|ddddd}tj|dddd|d}|j|jks#J tj|dddd|d	}|j|jks6J d S )
Nr  r   r  r  r   r  r  r  valinitr  )r   r  r  r  r#  r  r   )r   r  r  r  r#  r  r;   r<   rh   r   val)rC   r   slider_sliderr   r   r   test_slider_slidermin_slidermax  s   r(  c                  C   sX   t  \} }tj|ddddd}|j|jksJ tj|ddddd}|j|jks*J d S )Nr  r   r  g      $r"  g      9@)r;   r<   rh   r   r%  r  r  rC   r   r'  r   r   r   test_slider_valmin_valmax  s   r*  c                  C   s\   t  \} }tj|dddddd}|jdksJ tj|ddddg dd}|jd	ks,J d S )
Nr  r   r  g&@r   )r   r  r  r  r#  valsteprt   )r   r   r  g333333@r  r$  r)  r   r   r   test_slider_valstep_snapping  s   r,  c                  C   s   t  \} }tj|dddddd}|d |jdksJ |j |j	
 }t|jg d t  \} }tj|ddddd	d}|d |jdksMJ |j |j	
 }t|jg d
 d S )Nr  r   r  r  r-  )r   r  r  r  r#  r5  rM   )r   r  竪?r   r/  )r  r   r   r-  )r;   r<   rh   r   r  r%  polyget_extentstransformedr  invertedr   bounds)rC   r   r'  boxr   r   r   test_slider_horizontal_vertical  s    

r4  c                  C   sD   t  \} }tj|ddddd}|d |  |jdks J d S )Nr  r   r   r   r"        ?)r;   r<   rh   r   r  resetr%  r)  r   r   r   test_slider_reset  s
   
r7  r5  c                    sJ   dkr	g d}ng d}t  \}}tj|ddd ddgd	}|j |j }t	|
  | g d
 t	|jd  fdd}|d t	|jd t	||d |j |j }t	|
  | g d |d t	|jd t	||d |d t	|jd t	||d |  t	|jd t	||d d S )Nr/  r   r   r   r   r   r   r   r   r  r   r  re  (\?r   r  r  r  r5  r#  )re  r  r:  r5  )re  r:  c                    s(    dkrdd | j D S dd | j D S )Nr/  c                 S      g | ]}|  d  qS r   )r}  r  hr   r   r   r        z?test_range_slider.<locals>.handle_positions.<locals>.<listcomp>c                 S   r<  r=  )	get_xdatar>  r   r   r   r    r@  )_handles)r'  r5  r   r   r`    s   z+test_range_slider.<locals>.handle_positions)皙?r  )rD  r  r  r5  )r   re  )re  r   )r  rM   r   )r;   r<   rh   RangeSliderr.  r/  r0  r  r1  r   
get_pointsflattenr%  r  r6  )r5  idxrC   r   r'  r3  r`  r   rC  r   test_range_slider  s4   




rI  c                 C   st   | dkr	g d}ng d}t  \}}tj|ddd| ddgd}|j |j }t	|
  | g d	 d S )
Nr/  r8  r9  r  r   r  r   r;  )r   r  r   r5  )r;   r<   rh   rE  r.  r/  r0  r  r1  r   rF  rG  )r5  rH  rC   r   r'  r3  r   r   r   "test_range_slider_same_init_values1  s   

rJ  c           	      K   sp   t  }tjtdd}tj|fd|i|}| D ]\}}t||fi | q|j|ks,J |j|fi fks6J dS )a4  
    Helper function to test Polygon Selector.

    Parameters
    ----------
    event_sequence : list of tuples (etype, dict())
        A sequence of events to perform. The sequence is a list of tuples
        where the first element of the tuple is an etype (e.g., 'onmove',
        'press', etc.), and the second element of the tuple is a dictionary of
         the arguments for the event (e.g., xdata=5, key='shift', etc.).
    expected_result : list of vertices (xdata, ydata)
        The list of vertices that are expected to result from the event
        sequence.
    selections_count : int
        Wait for the tool to call its `onselect` function `selections_count`
        times, before comparing the result to the `expected_result`
    **kwargs
        Keyword arguments are passed to PolygonSelector.
    NrU   rX   )	r   r   rg   r
   rh   PolygonSelectorr   r  rm   )	event_sequenceexpected_resultselections_countrJ   r   rX   rn   etype
event_argsr   r   r   check_polygon_selectorB  s   rQ  c                 C   s.   dt | |dfdt | |dfdt | |dfgS )Nr^   r  rY   r`   r   r  r   r   r   polygon_place_vertexd  s   rS  c                 C   s2   dt | |dfdt | |ddfdt | |ddfgS )Nr^   r  rY   r   r[   r`   rR  r  r   r   r   polygon_remove_vertexj  s   rT  draw_bounding_boxc                 C   s  t jt| d}g d}g tddtddtddtdd}|||d g d}g tddtdddtdd	fd
tdddfdtdddfd
tdddfdtdddfdtdd	ftddtdd}|||d g d}g tddtdddtdd	fd
tdddfdtdddfd
tdddfdtdddfdtdd	ftddtdd}|||d g d}g tddtddtddtddd
tdddfdtdddfd
tdddfdtdddf}|||d g d}g tddtddtddtdddtdd	fd
tdddfdtdddfd
tdddfdtdddfdtdd	f}|||d g d}dtdd	fd
tdddfdtdddfd
tdddfdtdddfdtdd	fdtdd	fd
tdddfdtdddfd
tdddfdtdddfdtdd	fgtddtddtddtdd}|||d g d}g tddtdddtdd	fdtdd	ftddtddtddtdd}|||d d S )NrU  r   r   r  r   r   r  r   r  r   ))r   r   rY  rZ  r   r   r   r^   r  rY   r   r`   on_key_release))r   r   )r  r   rZ  r   rZ   r   r   ))r   r   )r   r   )r   r   ra   rF  )	functoolspartialrQ  rS  r   )rU  check_selectorrM  rL  r   r   r   test_polygon_selectorp  s   	
	

	

r_  c                 C   s*  t j| tdddtdd|d}g tddtddtddtdd}|D ]\}}t||fi | q(|j}| dksAJ | dksIJ |jd	d
d | d	ksXJ | d
ks`J |j	D ]}| dksmJ | dksuJ qc|j
d	d
d |j	D ]}| d	ksJ | d
ksJ qd S )Nr   r   r@  r   r   )rT   r   rU  r   r  r   r   )rh   rK  r   rS  r   r   rA  r   r   r   r   )r   rU  rn   rL  rO  rP  r   r   r   r   ,test_polygon_selector_set_props_handle_props  s<   


r`  c                 C   s,   |   }|  }tj|ddid}d|_d S )NvisibleFrS   )r   r   r   r  )r<   rh   ri   r   )r   r  ax_test_rn   r   r   r   test_rect_visibility  s   
rd  rH  )r   r   r   c                 C   sz   g d}t |d  t |d  t |d  t |d  g}|| t dd |tdd ttj|g }t||d|d d S )NrW  r   r   r      rV  )	rS  insertappendrT  r\  reduceoperatoriaddrQ  )rH  rU  vertsrL  r   r   r   test_polygon_selector_remove  s   




rl  c                 C   sd   g d}g t |d  t |d  t |d  t |d  t|d  }t||dd  d| d d S NrW  r   r   r   rV  )rS  rT  rQ  )rU  rk  rL  r   r   r   (test_polygon_selector_remove_first_point!  s   





rn  c                 C   s   g d}g t |d  t |d  t |d  t |d  t|d  t|d  t |d  }tj| |d}|D ]\}}t||fi | q9|j|dd ksRJ d S rm  )rS  rT  rh   rK  r   rk  )r   rU  rk  rL  rn   rO  rP  r   r   r   test_polygon_selector_redraw/  s(   






	ro  c                 C   s   g d}|   }tj||d}||_|j|ksJ |  }tj||d}g t|d  t|d  t|d  t|d  }|D ]\}	}
t||	fi |
 q@d S )N))re  rD  )r   r  )r   r   rV  r   r   r   )r  rh   rK  rk  rS  r   )r   r  rU  rk  rb  	tool_testax_reftool_refrL  rO  rP  r   r   r   "test_polygon_selector_verts_setterF  s&   



rs  c                 C   s  | j ddd g d}g t|d  t|d  t|d  t|d  t|d  }tj| dd	}|D ]\}}t||fi | q4| j}| jdd
j}td|g|	ddR  
  td|g|	dR  
  td|g|	ddR  
  tj|jg d td|g|	ddR  
  td|g|	dR  
  td|g|	ddR  
  tj|jg d tj|jjd td|g|	ddR  
  td|g|	ddR  
  tj|jg d tj|jjd d S )N)ir   )xlimylim))r"   r   )r   r"   )r"   (   )rv  r"   r   r   r   r   TrV  r  button_press_event)rv  rv  motion_notify_eventrz   button_release_event))rM   r   r   )rM   r"   )r"   rM   ru   r{   )r   r"   r|   r|   rv  rv  r|   )      4@      D@r}  r~  r   )rz  r{  r|  )r}  r~  g      >@r~  )setrS  rh   rK  r   r}   r  r>   r   r~   _processr   testingr   rk  _boxr   )r   rk  rL  rn   rO  rP  tr>   r   r   r   test_polygon_selector_box\  s   




	


r  c           	      C   s   t jtd d}t| |}g dg dfD ]Z}|D ]\}}t||D ]\}}t||fi | q"q|j}|js9J |	 s?J |	 sEJ t
j| | |j|d d fi fks\J |  |jreJ t
j| dg qd S )NrU   )rX  rY  rZ  rX  )rX  )rZ   r   rZ  rX  r  r   )r   rg   r
   rh   rK  rS  r   r   r   rI  r   r  assert_equal
get_xydatarm   r   )	r   rX   rn   resultrr  yrO  rP  r   r   r   r   "test_polygon_selector_clear_method  s&   

r  horizOnvertOnc           	      C   s  t  }|jddd\}}t   }tjd ||fd| |d}t|jdks(J t|jdks1J t|ddd}|	| |j
  |jD ]
}| d	ksOJ qE|jD ]
}| d
ks]J qStdd |jD |rkdndkspJ tdd |jD | r}dndksJ |j |_|j |_t|ddd}|	| tdd |jD |rdndksJ tdd |jD | rdndksJ t|ddd}|	| |jD ]
}| d	ksJ q|jD ]
}| d
ksJ qd S )Nr   T)sharexF)rK   r  r  r   r  r  )r   r   )r  r  c                 S      g | ]}|  r|qS r   rI  r  rc   r   r   r   r    r@  z$test_MultiCursor.<locals>.<listcomp>r   c                 S   r  r   r  r  r   r   r   r    r@  c                 S   r  r   r  r  r   r   r   r    r@  c                 S   r  r   r  r  r   r   r   r    r@  r5  )r;   figurer<   rh   MultiCursorr   vlineshlinesr	   r^   r>   r?   rA  r}  r  r  )	r  r  rC   ax1ax3ax2multieventlr   r   r   test_MultiCursor  sL   













r  )gr\  r@   ri  unittestr   matplotlib.backend_basesr   matplotlib.colorscolorsr   r7   rh   matplotlib.pyplotpyplotr;   matplotlib.testing.decoratorsr   r   matplotlib.testing.widgetsr   r   r   r	   r
   numpyr   numpy.testingr   r9   fixturer   rI   markparametrizer   rq   r   r   r   r   r   r   r   r   ri   r  r   r   r  r  r   r'  r,  r7  r8  r9  r;  r?  rB  rH  rJ  rK  rR  ra  backendr  r  r  r  r  r  r  r  r  r  r  r  r
  r  r  r  r  r!  r(  r*  r,  r4  r7  rI  rJ  rQ  rS  rT  r_  r`  rd  rl  rn  ro  rs  r  r  r  r   r   r   r   <module>   s   
'

#
#
I
I?

!
!









8







	

	






,
"
q
 




8