o
    :a                     @   sr  d dl Z d dlmZ d dlZd dlZd dlZd dlZd dlZ	d dl
Zd dlZd dlZd dlmZ d dlZd dlmZmZ d dlZd dlmZmZmZmZ d dlmZmZmZmZmZm Z m!Z!m"Z" d dl#m$Z$ d dl%m&Z& d d	l'm(Z( d
dl)m*Z* e+e,Z-e	j.Z/e!j0de!j1de!j2de!j3de!j4de!j5de!j6diZ7edd Z8i Z9de : j; Z<d Z=d
Z>dd Z?d5ddZ@G dd deZAG dd deZBG dd deZCG d d! d!ee	jDZEG d"d# d#ZFG d$d% d%ejGZHejId&d'd(G d)d* d*ejJZKG d+d, d,e e	jDZLG d-d. d.ejMZNG d/d0 d0ejOZPG d1d2 d2ejQZReNe_SePe_TeHe_UeRe_VejWe_XeLZYejZG d3d4 d4eZ[dS )6    N)contextmanager)SimpleDialog)ImageImageTk)_apibackend_toolscbook_c_internal_utils)_BackendFigureCanvasBaseFigureManagerBaseNavigationToolbar2	TimerBaseToolContainerBasecursors_Mode)Gcf)Figure)SubplotTool   )_tkaggZfleurZhand2ZarrowZtcrossZwatchZsb_h_double_arrowZsb_v_double_arrowc               	   c   sH    t  } zd V  W tjd rt |  d S d S tjd r#t |  w w )Nztk.window_focus)r	   ZWin32_GetForegroundWindowmplrcParamsZWin32_SetForegroundWindow)Z
foreground r   A/usr/lib/python3/dist-packages/matplotlib/backends/_backend_tk.py!_restore_foreground_window_at_end*   s   
r   Z	mpl_blit_c                 C   s6   t | \}}}}}t|j t||||| dS )z
    Thin wrapper to blit called via tkapp.call.

    *argsid* is a unique string identifier to fetch the correct arguments from
    the ``_blit_args`` dict, since arguments cannot be passed directly.
    N)
_blit_argspopr   blittk
interpaddrstr)argsid
photoimagedataptroffsetsbboxptr	comp_ruler   r   r   _blit<   s   r(   c              
   C   s2  t |}|jdd \}}|||jjf}|durL| \\}}	\}
}tt|d}t	t
|
|}
tt|	d}	t	t
||}||
|	|f}t}nd|d|f}t}| ||||f}tt|}|t|< z
| jt| W dS  tjy } zdt|vr | jtt | jt| W Y d}~dS d}~ww )a.  
    Blit *aggimage* to *photoimage*.

    *offsets* is a tuple describing how to fill the ``offset`` field of the
    ``Tk_PhotoImageBlock`` struct: it should be (0, 1, 2, 3) for RGBA8888 data,
    (2, 1, 0, 3) for little-endian ARBG32 (i.e. GBRA8888) data and (1, 2, 3, 0)
    for big-endian ARGB32 (i.e. ARGB8888) data.

    If *bbox* is passed, it defines the region that gets blitted. That region
    will be composed with the previous data according to the alpha channel.

    Tcl events must be dispatched to trigger a blit from a non-Tcl thread.
    N   r   zinvalid command name)npZasarrayshapeZctypesdataZ	__array__maxmathZfloorminZceilTK_PHOTO_COMPOSITE_OVERLAYTK_PHOTO_COMPOSITE_SETr!   idr   r   call_blit_tcl_nameTclErrorZcreatecommandr(   )r#   Zaggimager%   bboxr,   heightwidthr$   x1y1Zx2Zy2r&   r'   argsr"   er   r   r   r   H   s2   
	r   c                       s<   e Zd ZdZ fddZdd Zdd Z fdd	Z  ZS )
TimerTkz<Subclass of `backend_bases.TimerBase` using Tk timer events.c                    s"   d | _ t j|i | || _d S N)_timersuper__init__parent)selfrB   r;   kwargs	__class__r   r   rA   ~   s   
zTimerTk.__init__c                 C   s    |    | j| j| j| _d S r>   )_timer_stoprB   after	_interval	_on_timerr?   rC   r   r   r   _timer_start   s   zTimerTk._timer_startc                 C   s"   | j d ur| j| j  d | _ d S r>   )r?   rB   after_cancelrK   r   r   r   rG      s   

zTimerTk._timer_stopc                    s\   t     js) jr) jdkr j j j _d S  j fdd _d S d  _d S )Nr   c                      s    j  j jS r>   )rB   rH   rI   rJ   r   rK   r   r   <lambda>   s    z#TimerTk._on_timer.<locals>.<lambda>)r@   rJ   Z_singler?   rI   rB   rH   
after_idlerK   rE   rK   r   rJ      s   




zTimerTk._on_timer)	__name__
__module____qualname____doc__rA   rL   rG   rJ   __classcell__r   r   rE   r   r=   {   s    r=   c                       s   e Zd ZdZejddddd1 fdd	Zd2d	d
Zdd Zdd Z	dd Z
dd Z fddZ fddZd3 fdd	Zdd Z fddZ fddZd d! Zd"d# Zd$d% Zd&d' Zd(d) Zd*d+ Zd4d-d.Zd/d0 Z  ZS )5FigureCanvasTkr   z3.4resize_callbackz.get_tk_widget().bind('<Configure>', ..., True)ZalternativeNc           	         s  t  | d  _d  _ jdd\}}tj|d||ddd _tj j||d _	 jj
|d |d  j	d | _ jd	 j  jd
 j  jd j  jd j  jd j  jd j  jd j dD ]
} j| j qudD ]
} j| j qdD ]
} j| j qdD ]
} j| j q j }|d jd  fdd}|d|d  j  d S )NTZphysicalZwhiter   )masterZ
backgroundr8   r7   borderwidthZhighlightthicknessrY   r8   r7   r)   imagez<Configure>z<Map>z<Key>z<Motion><Enter><Leave>z<KeyRelease>)z
<Button-1>z
<Button-2>z
<Button-3>)z<Double-Button-1>z<Double-Button-2>z<Double-Button-3>)z<ButtonRelease-1>z<ButtonRelease-2>z<ButtonRelease-3>)z
<Button-4>z
<Button-5>z<MouseWheel>+c                    s   | j  ju r   d S d S r>   )widget	_tkcanvasZclose_eventeventrK   r   r   filter_destroy   s   z/FigureCanvasTk.__init__.<locals>.filter_destroyz	<Destroy>)r@   rA   _idle_draw_id_event_loop_idget_width_heightr   ZCanvasrb   
PhotoImage_tkphotocreate_image_resize_callbackbindresize_update_device_pixel_ratio	key_pressmotion_notify_evententer_notify_eventZleave_notify_eventkey_releasebutton_press_eventbutton_dblclick_eventbutton_release_eventscroll_eventZwinfo_toplevelscroll_event_windowsZ	focus_set)	rC   figurerY   rV   whnamerootre   rE   rK   r   rA      sB   
zFigureCanvasTk.__init__c                 C   sL   t | jjddd d}| |r$| jdd\}}| jj||d d S d S )Nr   scalinggUUUUUU?r)   TrX   r8   r7   )roundrb   r   r3   Z_set_device_pixel_ratiorh   	configure)rC   rd   Zratiorz   r{   r   r   r   ro      s
   
z)FigureCanvasTk._update_device_pixel_ratioc                 C   s   |j |j}}| jd ur| | | jj}|| }|| }| jj||dd | j| j t	j
| jt|t|d| _| jjt|d t|d | jd |   d S )NF)Zforwardr[   r)   r\   )r8   r7   rl   ry   ZdpiZset_size_inchesrb   deleterj   r   ri   intrk   Zresize_event)rC   rd   r8   r7   ZdpivalZwinchZhinchr   r   r   rn      s   

zFigureCanvasTk.resizec                    s(    j rd S  fdd} j| _ d S )Nc                     s   z
    W d  _d S d  _w r>   )drawrf   r;   rK   r   r   	idle_draw   s   
z+FigureCanvasTk.draw_idle.<locals>.idle_draw)rf   rb   rO   )rC   r   r   rK   r   	draw_idle   s   zFigureCanvasTk.draw_idlec                 C   s   | j S )z
        Return the Tk widget used to implement FigureCanvasTkAgg.

        Although the initial implementation uses a Tk canvas,  this routine
        is intended to hide that fact.
        )rb   rK   r   r   r   get_tk_widget  s   zFigureCanvasTk.get_tk_widgetc                 C   s&   | j |j| jjj| j |j fS r>   )rb   canvasxxry   r6   r7   canvasyyrC   rd   r   r   r   _event_mpl_coords
  s   z FigureCanvasTk._event_mpl_coordsc                    s   t  j| |d|i d S )NguiEvent)r@   rq   r   r   rE   r   r   rq     s
   
z"FigureCanvasTk.motion_notify_eventc                    s   t  j|| |d d S )N)r   Zxy)r@   rr   r   r   rE   r   r   rr     s   

z!FigureCanvasTk.enter_notify_eventFc                    sP   t |dd }tjdkrddd||}t jg | ||R ||d d S )Nnumdarwin   r)   r)   r   )dblclickr   )getattrsysplatformgetr@   rt   r   )rC   rd   r   r   rE   r   r   rt     s   
z!FigureCanvasTk.button_press_eventc                 C   s   | j |dd d S )NT)r   )rt   r   r   r   r   ru   !  s   z$FigureCanvasTk.button_dblclick_eventc                    sN   t |dd }tjdkrddd||}t jg | ||R d|i d S )Nr   r   r   r)   r   r   )r   r   r   r   r@   rv   r   )rC   rd   r   rE   r   r   rv   $  s   

z#FigureCanvasTk.button_release_eventc                    sN   t |dd }|dkrdn|dkrdnd}t jg | ||R d|i d S )Nr      r      r   r   )r   r@   rw   r   )rC   rd   r   steprE   r   r   rw   +  s   
zFigureCanvasTk.scroll_eventc                 C   sx   |j |j|j}|| jkr:| j|j|  }| jjj	| j
|j|   }|jd }tj| ||||d dS dS )zMouseWheel event processorg      ^@r   N)ra   Zwinfo_containingZx_rootZy_rootrb   r   winfo_rootxry   r6   r7   r   winfo_rootyZdeltar   rw   )rC   rd   rz   r   r   r   r   r   r   rx   1  s   

z#FigureCanvasTk.scroll_event_windowsc                 C   s   |j }t||j}tjdkrg d}ntjdkrg d}ng d}|d urE|D ]\}}}|jd|> @ rD||vrD|dkr>|sDd||}q(|S )	Nwin32)r)   ZctrlZcontrol)   altr   r   shiftr   r   )r   )r   r   r   r   )r   r@   r@   )r   )r   r   r   r   )   r@   r@   r   r   z{0}+{1})charr   Z_unikey_or_keysym_to_mplkeyZkeysymr   r   stateformat)rC   rd   Zunikeykey	modifiersZbitmaskprefixZkey_namer   r   r   _get_key<  s   




zFigureCanvasTk._get_keyc                 C      |  |}tj| ||d d S Nr   )r   r   Zkey_press_eventrC   rd   r   r   r   r   rp   c     
zFigureCanvasTk.key_pressc                 C   r   r   )r   r   Zkey_release_eventr   r   r   r   rs   g  r   zFigureCanvasTk.key_releasec                 O   s   t | jg|R i |S r>   )r=   rb   rC   r;   rD   r   r   r   	new_timerk  s   zFigureCanvasTk.new_timerc                 C   s   | j   d S r>   )rb   updaterK   r   r   r   flush_eventso  s   zFigureCanvasTk.flush_eventsr   c                 C   sN   |dkr t d| }|dkr| j|| j| _n| j| j| _| j  d S )Nr   i  )r   rb   rH   stop_event_looprg   rO   mainloop)rC   ZtimeoutZmillisecondsr   r   r   start_event_loops  s   zFigureCanvasTk.start_event_loopc                 C   s(   | j r| j| j  d | _ | j  d S r>   )rg   rb   rM   quitrK   r   r   r   r     s   zFigureCanvasTk.stop_event_loop)NNNr>   )F)r   )rP   rQ   rR   Zrequired_interactive_frameworkr   Zdelete_parameterrA   ro   rn   r   r   r   rq   rr   rt   ru   rv   rw   rx   r   rp   rs   r   r   r   r   rT   r   r   rE   r   rU      s4    
/	'
rU   c                       sd   e Zd ZdZdZ fddZdd Zdd Zd	d
 Zdd Z	dd Z
dd Zdd Zdd Z  ZS )FigureManagerTkz
    Attributes
    ----------
    canvas : `FigureCanvas`
        The FigureCanvas instance
    num : int or str
        The Figure number
    toolbar : tk.Toolbar
        The tk.Toolbar
    window : tk.Window
        The tk.Window
    Fc                    s   || _ t || | j   |  | _| jjjt	j
t	jdd | jr2t| j | jr2t| j t| d}t	j|dd| d}t||j	 rW|| _|d| j d| _d S )	Nr   sidefillexpand   `   
window_dpi)rY   valuer|   writeF)windowr@   rA   withdraw_get_toolbartoolbarcanvasrb   packr   TOPBOTHtoolmanagerr   Zadd_tools_to_managerZadd_tools_to_containerr   Zwm_frameIntVarr   Zenable_dpi_awarenessr    _window_dpiZ	trace_add_update_window_dpi_shown)rC   r   r   r   Zwindow_framer   rE   r   r   rA     s"   


zFigureManagerTk.__init__c                 C   sH   t jd dkrt| j| j}|S t jd dkr t| j| j}|S d }|S )Nr   Ztoolbar2r   )r   r   NavigationToolbar2Tkr   r   	ToolbarTkr   )rC   r   r   r   r   r     s   zFigureManagerTk._get_toolbarc                 G   sH   | j  }| jdd|d  | jrt| jdr| j  | j  d S )Nr   r~   H   _rescale)	r   r   r   r3   r   hasattrr   r   ro   )rC   r;   Znewdpir   r   r   r     s
   

z"FigureManagerTk._update_window_dpic                 C   sP   d}||ks
||krt jdkrtd| d| d| d| jjj||d d S )Ni\ Zlinuxz/You have requested to resize the Tk window to (z, z), one of which is bigger than z.  At larger sizes xorg will either exit with an error on newer versions (~1.20) or cause corruption on older version (~1.19).  We do not expect a window over a million pixel wide or tall to be intended behavior.r   )r   r   
ValueErrorr   rb   r   )rC   r8   r7   Zmax_sizer   r   r   rn     s   zFigureManagerTk.resizec                    s   t  >  js fdd} jd|  j  n j  tjd r6 jj	j
dd  jj	j
dd d _W d    d S 1 sDw   Y  d S )	Nc                     s   t   d S r>   )r   destroyr   rK   r   r   r        z%FigureManagerTk.show.<locals>.destroyWM_DELETE_WINDOWzfigure.raise_windowz-topmostr   r   T)r   r   r   protocolZ	deiconifyr   r   r   r   manager
attributes)rC   r   r   rK   r   show  s   

"zFigureManagerTk.showc                    sX    j jr j j j j  j jr j j j j  fdd} j jjd| d S )Nc                      s.    j    jrt s j   d S d S d S r>   )r   r   _owns_mainloopr   Zget_num_fig_managersr   r   rK   r   r   delayed_destroy  s   
z0FigureManagerTk.destroy.<locals>.delayed_destroyr   )r   rf   rb   rM   rg   r   rO   rH   )rC   r;   r   r   rK   r   r     s   zFigureManagerTk.destroyc                 C   s
   | j  S r>   r   Zwm_titlerK   r   r   r   get_window_title     
z FigureManagerTk.get_window_titlec                 C      | j | d S r>   r   )rC   titler   r   r   set_window_title     z FigureManagerTk.set_window_titlec                 C   s$   t | jd}| jd|  d S )Nz-fullscreen)boolr   r   )rC   Zis_fullscreenr   r   r   full_screen_toggle  s   z"FigureManagerTk.full_screen_toggle)rP   rQ   rR   rS   r   rA   r   r   rn   r   r   r   r   r   rT   r   r   rE   r   r     s    	r   c                       s   e Zd ZdZddddZdd Zdd	 Z fd
dZ fddZdd Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Z  ZS ) r   a  
    Attributes
    ----------
    canvas : `FigureCanvas`
        The figure canvas on which to operate.
    win : tk.Window
        The tk.Window which owns this toolbar.
    pack_toolbar : bool, default: True
        If True, add the toolbar to the parent's pack manager's packing list
        during initialization with ``side='bottom'`` and ``fill='x'``.
        If you want to use the toolbar with a different layout manager, use
        ``pack_toolbar=False``.
    T)pack_toolbarc          
   	   C   s.  || _ tjj| |dt|jjjdd i | _| j	D ]5\}}}}|d u r(| 
  q| j|ttd| d|dv t| |d | j|< }|d urNt|| qtjj|dd	| _tj| | jd
d}	|	jtjd tj| d| _tj| | j| jd| _| jjtjd t| | |r| jtjtjd d S d S )Nr)   2   )rY   rZ   r8   r7   zimages/.png)zoompan)togglecommand
   )r}   sizeu    
 )rY   fonttextr   rY   rY   r   Ztextvariabler   r   )r   r   FramerA   r   ry   r6   r8   _buttonsZ	toolitems_Spacer_Buttonr!   r   _get_data_pathr   ToolTipcreateToolTiptkinterr   Font_label_fontLabelr   RIGHT	StringVarmessage_message_labelr   ZBOTTOMX)
rC   r   r   r   r   Ztooltip_text
image_filecallbackbuttonlabelr   r   r   rA   
  s>   


zNavigationToolbar2Tk.__init__c                 C   s   |   D ];}t|tjtjfrt|drt| | q	 qt|tjr1|j	ddd |j
dd qt|tjr8qtd|j q| jj	dd	 d
S )a  
        Scale all children of the toolbar to current DPI setting.

        Before this is called, the Tk scaling setting will have been updated to
        match the new DPI. Tk widgets do not update for changes to scaling, but
        all measurements made after the change will match the new scaling. Thus
        this function re-applies all the same sizes in points, which Tk will
        scale correctly to pixels.
        _image_fileZ22pZ1p)r7   ZpadyZ4p)padxzUnknown child class %sr   r   N)Zwinfo_children
isinstancer   ButtonCheckbuttonr   r   _set_image_for_buttonr   r   Zpack_configurer  _logZwarningZwinfo_classr  rC   ra   r   r   r   r   4  s   

zNavigationToolbar2Tk._rescalec                 C   sT   dt jfdt jffD ]\}}|| jv r'| j|kr | j|   q
| j|   q
d S )NZZoomZPan)r   ZZOOMZPANr   modeselectdeselect)rC   r   r  r   r   r   _update_buttons_checkedO  s   

z,NavigationToolbar2Tk._update_buttons_checkedc                       t  j|  |   d S r>   )r@   r   r  rC   r;   rE   r   r   r   X     zNavigationToolbar2Tk.panc                    r  r>   )r@   r   r  r  rE   r   r   r   \  r  zNavigationToolbar2Tk.zoomc                 C   r   r>   )r  setrC   sr   r   r   set_message`  r   z NavigationToolbar2Tk.set_messagec                 C   s>   |    | jjjj}|| }|| }| jj||||| _d S r>   )remove_rubberbandr   ry   r6   r7   rb   create_rectanglelastrect)rC   rd   x0y0r9   r:   r7   r   r   r   draw_rubberbandc  s
   z$NavigationToolbar2Tk.draw_rubberbandc                 C   s&   t | dr| jj| j | `d S d S Nr"  )r   r   rb   r   r"  rK   r   r   r   r   j  s   
z&NavigationToolbar2Tk.remove_rubberbandc                 C   s:   | j  j}z|jt| d W d S  tjy   Y d S w )N)cursor)r   r   rY   r   cursordr   r5   )rC   r'  r   r   r   r   
set_cursoro  s   zNavigationToolbar2Tk.set_cursorc                 C   s   |j du rdS |d}t|dkr|j ddn|j }tj|||f| d}W d   n1 s4w   Y  |j|ddd ||_	dS )z
        Set the image for a button based on its pixel size.

        The pixel size is determined by the DPI scaling of the window.
        N18p   r   z
_large.pngr   )r]   r7   r8   )
r  Zwinfo_pixelsr   openreplacer   ri   rn   r   Z_ntimage)rC   r
  r   Zimr]   r   r   r   r  v  s   


z*NavigationToolbar2Tk._set_image_for_buttonc                 C   sx   |st j| ||d}nt j| d}t j| ||d|d}||_||_|d ur,t| | n|j| j	d |j
t jd |S )N)rY   r   r   r   F)rY   r   r   Zindicatoronvariable)r   r   )r   r  r   r  varr  r   r  r   r  r   LEFT)rC   r   r  r   r   br/  r   r   r   r     s   zNavigationToolbar2Tk._Buttonc                 C   s(   t j| dt jdd}|jt jdd |S )Nr*  ZDarkGray)rY   r7   reliefbgZ3p)r   r  )r   r   ZRIDGEr   r0  r  r   r   r   r     s   zNavigationToolbar2Tk._Spacerc              
   G   s   | j   }| j  }||}||fgt|  }dd |D }d}tj	t
jd }| j  }	tjj| j  jd||||	d}
|
dv rId S |dkrXtjt|
t
jd< z
| j j|
 W d S  ty~ } ztjdt| W Y d }~d S d }~ww )	Nc                 S   s   g | ]
\}}|d | fqS )z*.%sr   ).0extr|   r   r   r   
<listcomp>  s    z4NavigationToolbar2Tk.save_figure.<locals>.<listcomp> zsavefig.directoryzSave the figure)rY   r   	filetypesdefaultextension
initialdirinitialfile)r7  r   zError saving file)r   Zget_supported_filetypescopyZget_default_filetyper   sorteditemsospath
expanduserr   r   Zget_default_filenamer   Z
filedialogZasksaveasfilenamer   rY   dirnamer!   ry   Zsavefig	ExceptionZ
messageboxZ	showerror)rC   r;   r8  Zdefault_filetypeZdefault_filetype_nameZsorted_filetypesZtk_filetypesr9  r:  r;  fnamer<   r   r   r   save_figure  s:   




	 z NavigationToolbar2Tk.save_figurec                 C   sr   t jt jd}| jjdk}| jjt| jjd k }d| jv r'|| | jd d< d| jv r7|| | jd d< d S d S )N)TFr   r   ZBackr   ZForward)r   ZNORMALZDISABLEDZ
_nav_stack_poslenZ	_elementsr   )rC   Z	state_mapZcan_backZcan_forwardr   r   r   set_history_buttons  s   

z(NavigationToolbar2Tk.set_history_buttons)rP   rQ   rR   rS   rA   r   r  r   r   r  r%  r   r)  r  r   r   rE  rH  rT   r   r   rE   r   r     s     *	(r   c                   @   s4   e Zd ZdZedd Zdd Zdd Zdd	 Zd
S )r   zi
    Tooltip recipe from
    http://www.voidspace.org.uk/python/weblog/arch_d7_2006_07_01.shtml#e387
    c                    s>   t |  fdd}fdd}| d| | d| d S )Nc                    s      d S r>   )showtiprc   r   toolTipr   r   enter  r   z$ToolTip.createToolTip.<locals>.enterc                    s       d S r>   )hidetiprc   )rK  r   r   leave  s   z$ToolTip.createToolTip.<locals>.leaver^   r_   )r   rm   )ra   r   rL  rN  r   rJ  r   r     s
   zToolTip.createToolTipc                 C   s"   || _ d | _d | _d | _| _d S )Nr   )ra   	tipwindowr2   r   r   r  r   r   r   rA     s   zToolTip.__init__c                 C   s   || _ | js	| j sdS | jd\}}}}|| j  d }|| j  }t| j | _}|d |	d||f  z|j
dd|jdd	 W n
 tjyS   Y nw tj|| j tjtjdd
}|jdd dS )zDisplay text in tooltip window.Ninsert   r   z+%d+%dz!::tk::unsupported::MacWindowStyleZstylehelpZnoActivates)r   Zjustifyr2  rZ   )Zipadx)r   rO  ra   r6   r   r   r   ZToplevelZwm_overrideredirectZwm_geometryr3   Z_wr5   r  r0  ZSOLIDr   )rC   r   r   r   _twr  r   r   r   rI    s*   
zToolTip.showtipc                 C   s    | j }d | _ |r|  d S d S r>   )rO  r   )rC   rT  r   r   r   rM    s
   zToolTip.hidetipN)	rP   rQ   rR   rS   staticmethodr   rA   rI  rM  r   r   r   r   r     s    
	r   c                   @   s   e Zd Zdd Zdd ZdS )RubberbandTkc                 C   sB   |    | jjjjj}|| }|| }| jjj||||| _d S r>   )r   ry   r   r6   r7   rb   r!  r"  )rC   r#  r$  r9   r:   r7   r   r   r   r%  
  s   

zRubberbandTk.draw_rubberbandc                 C   s(   t | dr| jjj| j | `d S d S r&  )r   ry   r   rb   r   r"  rK   r   r   r   r     s   
zRubberbandTk.remove_rubberbandN)rP   rQ   rR   r%  r   r   r   r   r   rV  	  s    rV  z3.5ZToolSetCursorrW   c                   @      e Zd Zdd ZdS )SetCursorTkc                 C   s   t |  | d S r>   )r   r)  "_make_classic_style_pseudo_toolbar)rC   r'  r   r   r   r)    s   zSetCursorTk.set_cursorN)rP   rQ   rR   r)  r   r   r   r   rX    s    rX  c                   @   sT   e Zd Zdd Zdd Zdd Zdd Zd	d
 Zdd Zdd Z	dd Z
dd ZdS )r   c                 C   s   t | | | jjjjj\}}d|| }}tjj| |t	|t	|dd t
jjdd| _tj| d| _tj| | j| jd| _| jjtjd i | _| jtjtjd	 i | _d S )
Nr   r)   )rY   r8   r7   rZ   r   r  r   r   r   r   )r   rA   r   r   ry   r6   Z	intervalxr   r   r   r   r   r   r  r  _messager  r  r   r  
_toolitemsr   r  _groups)rC   r   r   ZxminZxmaxr7   r8   r   r   r   rA      s    


zToolbarTk.__init__c                 C   
   t | S r>   )r   r   rK   r   r   r   r   0  r   zToolbarTk._rescalec           	   	      s\    |}t || fdd}|d urt|| j g  j  | d S )Nc                      s
     S r>   )_button_clickr   r|   rC   r   r   rN   7  s   
 z(ToolbarTk.add_toolitem.<locals>.<lambda>)_get_groupframer   r   r   r   r[  
setdefaultappend)	rC   r|   groupZpositionr  descriptionr   framer
  r   r_  r   add_toolitem3  s   
zToolbarTk.add_toolitemc                 C   sL   || j vr!| j r|   tj| dd}|jtjtjd || j |< | j | S )Nr   )rY   rZ   r   )r\  _add_separatorr   r   r   r0  Y)rC   rc  re  r   r   r   r`  =  s   


zToolbarTk._get_groupframec                 C   r]  r>   )r   r   rK   r   r   r   rg  F  r   zToolbarTk._add_separatorc                 C   s   |  | d S r>   )Ztrigger_tool)rC   r|   r   r   r   r^  I  r   zToolbarTk._button_clickc                 C   s8   || j vrd S | j | D ]}|r|  q|  qd S r>   )r[  r  r  )rC   r|   Ztoggledtoolitemr   r   r   toggle_toolitemL  s   


zToolbarTk.toggle_toolitemc                 C   s$   | j | D ]}|  q| j |= d S r>   )r[  Zpack_forget)rC   r|   ri  r   r   r   remove_toolitemU  s   
zToolbarTk.remove_toolitemc                 C   r   r>   )rZ  r  r  r   r   r   r  Z  r   zToolbarTk.set_messageN)rP   rQ   rR   rA   r   rf  r`  rg  r^  rj  rk  r  r   r   r   r   r     s    
		r   c                   @   rW  )SaveFigureTkc                 G   s   t |   d S r>   )r   rE  rY  r  r   r   r   trigger_  s   zSaveFigureTk.triggerNrP   rQ   rR   rm  r   r   r   r   rl  ^      rl  c                       s4   e Zd Z fddZdd Zdd Zdd Z  ZS )	ConfigureSubplotsTkc                    s   t  j|i | d | _d S r>   )r@   rA   r   r   rE   r   r   rA   e  s   
zConfigureSubplotsTk.__init__c                 G   s   |    | j  d S r>   )init_windowr   Zliftr  r   r   r   rm  i  s   zConfigureSubplotsTk.triggerc                 C   s~   | j rd S tdd}t | _ t| j|| j d}|jdd t| j| |	  |
 jtjtjdd | j d| j d S )	N)r   r   )Zfigsizer   g?)topr   r   r   )r   r   r   Tktyper   Zsubplots_adjustr   ry   r   r   r   r   r   r   r   )rC   Ztoolfigr   r   r   r   rq  m  s   

zConfigureSubplotsTk.init_windowc                 O   s"   | j d ur| j   d | _ d S d S r>   )r   r   r   r   r   r   r   {  s   


zConfigureSubplotsTk.destroy)rP   rQ   rR   rA   rm  rq  r   rT   r   r   rE   r   rp  d  s
    rp  c                   @   rW  )HelpTkc                    s*   t | jjj|  dg  fdd _d S )NZOKc                    s    j j S r>   )re  rY   r   )r   Zdialogr   r   rN     s    z HelpTk.trigger.<locals>.<lambda>)r   ry   r   rb   Z_get_help_textZdoner  r   rv  r   rm    s   zHelpTk.triggerNrn  r   r   r   r   ru    ro  ru  c                   @   s(   e Zd ZeZedd Zedd ZdS )
_BackendTkc           	      C   s   t  k t du rt  t  tjdd}|  t	t
d}tj||d}z|d| W n tyJ } ztd| W Y d}~nd}~ww | j||d}| |||}t re|  |  |W  d   S 1 sqw   Y  dS )	zL
        Create a new figure manager instance for the given figure.
        N
matplotlib)Z	classNamezimages/matplotlib_128.ppm)filerY   Fz"Could not load matplotlib icon: %sr   )r   r   Z"_get_running_interactive_frameworkZ_setup_new_guiappr	   Z Win32_SetProcessDpiAwareness_maxr   rs  r   r!   r   ri   Z	iconphotorC  r  infoZFigureCanvasFigureManagerr   Zis_interactiver   r   )	clsr   ry   r   Z
icon_fnameZicon_imgexcr   r   r   r   r   new_figure_manager_given_figure  s.   $z*_BackendTk.new_figure_manager_given_figurec                  C   sP   t  } | r&| d }t|}|jrd S d|_z|j  W d|_d S d|_w d S )Nr   TF)r   Zget_all_fig_managersrt  r   r   r   )ZmanagersZfirst_managerZmanager_classr   r   r   r     s   z_BackendTk.mainloopN)	rP   rQ   rR   r   r{  classmethodr~  rU  r   r   r   r   r   rw    s    
rw  r>   )\Zuuid
contextlibr   Zloggingr.   os.pathr?  r   r   r   Ztkinter.filedialogZtkinter.fontZtkinter.messageboxZtkinter.simpledialogr   Znumpyr*   ZPILr   r   rx  r   r   r   r   r	   Zmatplotlib.backend_basesr
   r   r   r   r   r   r   r   Zmatplotlib._pylab_helpersr   Zmatplotlib.figurer   Zmatplotlib.widgetsr   r7  r   Z	getLoggerrP   r  Z	TkVersionZbackend_versionZMOVEZHANDZPOINTERZSELECT_REGIONZWAITZRESIZE_HORIZONTALZRESIZE_VERTICALr(  r   r   Zuuid4hexr4   r0   r1   r(   r   r=   rU   r   r   r   r   ZRubberbandBaserV  Z
deprecatedZSetCursorBaserX  r   ZSaveFigureBaserl  ZConfigureSubplotsBaserp  ZToolHelpBaseru  ZToolSaveFigureZToolConfigureSubplotsZToolRubberbandZToolHelpZToolCopyToClipboardBaseZToolCopyToClipboardZToolbarZexportrw  r   r   r   r   <module>   sx    (

	
3& gu \2?