Added nightlight thickness parm to Checkbox so focus ring thickness can be controlled when creating element
This commit is contained in:
		
							parent
							
								
									4d02f3a515
								
							
						
					
					
						commit
						3507b2708b
					
				
					 1 changed files with 54 additions and 48 deletions
				
			
		
							
								
								
									
										102
									
								
								PySimpleGUI.py
									
										
									
									
									
								
							
							
						
						
									
										102
									
								
								PySimpleGUI.py
									
										
									
									
									
								
							|  | @ -1,6 +1,6 @@ | ||||||
| #!/usr/bin/python3 | #!/usr/bin/python3 | ||||||
| 
 | 
 | ||||||
| version = __version__ = "4.61.0.162 Unreleased" | version = __version__ = "4.61.0.163 Unreleased" | ||||||
| 
 | 
 | ||||||
| _change_log = """ | _change_log = """ | ||||||
|     Changelog since 4.60.0 released to PyPI on 8-May-2022 |     Changelog since 4.60.0 released to PyPI on 8-May-2022 | ||||||
|  | @ -391,6 +391,8 @@ _change_log = """ | ||||||
|         New set_options to control user-defined watermarks |         New set_options to control user-defined watermarks | ||||||
|     4.61.0.162 |     4.61.0.162 | ||||||
|         Addition of new parms to Combo.update - text color, background color.  Also font now applied correctly to dropdown list |         Addition of new parms to Combo.update - text color, background color.  Also font now applied correctly to dropdown list | ||||||
|  |     4.61.0.163 | ||||||
|  |         Checkbox - added highlight thickness parm to control how thick the focus ring is. Defaults to 1 still but now changable | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
| __version__ = version.split()[0]  # For PEP 396 and PEP 345 | __version__ = version.split()[0]  # For PEP 396 and PEP 345 | ||||||
|  | @ -3423,56 +3425,59 @@ class Checkbox(Element): | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     def __init__(self, text, default=False, size=(None, None), s=(None, None), auto_size_text=None, font=None, background_color=None, |     def __init__(self, text, default=False, size=(None, None), s=(None, None), auto_size_text=None, font=None, background_color=None, | ||||||
|                  text_color=None, checkbox_color=None, change_submits=False, enable_events=False, disabled=False, key=None, k=None, pad=None, p=None, tooltip=None, |                  text_color=None, checkbox_color=None, highlight_thickness=1, change_submits=False, enable_events=False, disabled=False, key=None, k=None, pad=None, p=None, tooltip=None, | ||||||
|                  right_click_menu=None, expand_x=False, expand_y=False, visible=True, metadata=None): |                  right_click_menu=None, expand_x=False, expand_y=False, visible=True, metadata=None): | ||||||
|         """ |         """ | ||||||
|         :param text:             Text to display next to checkbox |         :param text:                Text to display next to checkbox | ||||||
|         :type text:              (str) |         :type text:                 (str) | ||||||
|         :param default:          Set to True if you want this checkbox initially checked |         :param default:             Set to True if you want this checkbox initially checked | ||||||
|         :type default:           (bool) |         :type default:              (bool) | ||||||
|         :param size:             (w, h) w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 |         :param size:                (w, h) w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 | ||||||
|         :type size:              (int, int)  | (None, None) | int |         :type size:                 (int, int)  | (None, None) | int | ||||||
|         :param s:                Same as size parameter.  It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |         :param s:                   Same as size parameter.  It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used | ||||||
|         :type s:                 (int, int)  | (None, None) | int |         :type s:                    (int, int)  | (None, None) | int | ||||||
|         :param auto_size_text:   if True will size the element to match the length of the text |         :param auto_size_text:      if True will size the element to match the length of the text | ||||||
|         :type auto_size_text:    (bool) |         :type auto_size_text:       (bool) | ||||||
|         :param font:             specifies the  font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |         :param font:                specifies the  font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike | ||||||
|         :type font:              (str or (str, int[, str]) or None) |         :type font:                 (str or (str, int[, str]) or None) | ||||||
|         :param background_color: color of background |         :param background_color:    color of background | ||||||
|         :type background_color:  (str) |         :type background_color:     (str) | ||||||
|         :param text_color:       color of the text |         :param text_color:          color of the text | ||||||
|         :type text_color:        (str) |         :type text_color:           (str) | ||||||
|         :param checkbox_color:   color of background of the box that has the check mark in it. The checkmark is the same color as the text |         :param checkbox_color:      color of background of the box that has the check mark in it. The checkmark is the same color as the text | ||||||
|         :type checkbox_color:    (str) |         :type checkbox_color:       (str) | ||||||
|         :param change_submits:   DO NOT USE. Only listed for backwards compat - Use enable_events instead |         :param highlight_thickness: thickness of border around checkbox when gets focus | ||||||
|         :type change_submits:    (bool) |         :type highlight_thickness:  (int) | ||||||
|         :param enable_events:    Turns on the element specific events. Checkbox events happen when an item changes |         :param change_submits:      DO NOT USE. Only listed for backwards compat - Use enable_events instead | ||||||
|         :type enable_events:     (bool) |         :type change_submits:       (bool) | ||||||
|         :param disabled:         set disable state |         :param enable_events:       Turns on the element specific events. Checkbox events happen when an item changes | ||||||
|         :type disabled:          (bool) |         :type enable_events:        (bool) | ||||||
|         :param key:              Used with window.find_element and with return values to uniquely identify this element |         :param disabled:            set disable state | ||||||
|         :type key:               str | int | tuple | object |         :type disabled:             (bool) | ||||||
|         :param k:                Same as the Key. You can use either k or key. Which ever is set will be used. |         :param key:                 Used with window.find_element and with return values to uniquely identify this element | ||||||
|         :type k:                 str | int | tuple | object |         :type key:                  str | int | tuple | object | ||||||
|         :param pad:              Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |         :param k:                   Same as the Key. You can use either k or key. Which ever is set will be used. | ||||||
|         :type pad:               (int, int) or ((int, int),(int,int)) or (int,(int,int)) or  ((int, int),int) | int |         :type k:                    str | int | tuple | object | ||||||
|         :param p:                Same as pad parameter.  It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, pad will be used |         :param pad:                 Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) | ||||||
|         :type p:                 (int, int) or ((int, int),(int,int)) or (int,(int,int)) or  ((int, int),int) | int |         :type pad:                  (int, int) or ((int, int),(int,int)) or (int,(int,int)) or  ((int, int),int) | int | ||||||
|         :param tooltip:          text, that will appear when mouse hovers over the element |         :param p:                   Same as pad parameter.  It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, pad will be used | ||||||
|         :type tooltip:           (str) |         :type p:                    (int, int) or ((int, int),(int,int)) or (int,(int,int)) or  ((int, int),int) | int | ||||||
|         :param right_click_menu: A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |         :param tooltip:             text, that will appear when mouse hovers over the element | ||||||
|         :type right_click_menu:  List[List[ List[str] | str ]] |         :type tooltip:              (str) | ||||||
|         :param expand_x:         If True the element will automatically expand in the X direction to fill available space |         :param right_click_menu:    A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. | ||||||
|         :type expand_x:          (bool) |         :type right_click_menu:     List[List[ List[str] | str ]] | ||||||
|         :param expand_y:         If True the element will automatically expand in the Y direction to fill available space |         :param expand_x:            If True the element will automatically expand in the X direction to fill available space | ||||||
|         :type expand_y:          (bool) |         :type expand_x:             (bool) | ||||||
|         :param visible:          set visibility state of the element |         :param expand_y:            If True the element will automatically expand in the Y direction to fill available space | ||||||
|         :type visible:           (bool) |         :type expand_y:             (bool) | ||||||
|         :param metadata:         User metadata that can be set to ANYTHING |         :param visible:             set visibility state of the element | ||||||
|         :type metadata:          (Any) |         :type visible:              (bool) | ||||||
|  |         :param metadata:            User metadata that can be set to ANYTHING | ||||||
|  |         :type metadata:             (Any) | ||||||
|         """ |         """ | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|         self.Text = text |         self.Text = text | ||||||
|         self.InitialState = bool(default) |         self.InitialState = bool(default) | ||||||
|         self.Value = None |         self.Value = None | ||||||
|  | @ -3480,6 +3485,7 @@ class Checkbox(Element): | ||||||
|         self.Disabled = disabled |         self.Disabled = disabled | ||||||
|         self.TextColor = text_color if text_color else theme_text_color() |         self.TextColor = text_color if text_color else theme_text_color() | ||||||
|         self.RightClickMenu = right_click_menu |         self.RightClickMenu = right_click_menu | ||||||
|  |         self.highlight_thickness = highlight_thickness | ||||||
| 
 | 
 | ||||||
|         # ---- compute color of circle background --- |         # ---- compute color of circle background --- | ||||||
|         if checkbox_color is None: |         if checkbox_color is None: | ||||||
|  | @ -16975,7 +16981,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form): | ||||||
|                     element.TKCheckbutton.configure(fg=text_color) |                     element.TKCheckbutton.configure(fg=text_color) | ||||||
|                     element.TKCheckbutton.configure(activeforeground=element.TextColor) |                     element.TKCheckbutton.configure(activeforeground=element.TextColor) | ||||||
| 
 | 
 | ||||||
|                 element.Widget.configure(highlightthickness=1) |                 element.Widget.configure(highlightthickness=element.highlight_thickness) | ||||||
|                 if element.BackgroundColor != COLOR_SYSTEM_DEFAULT: |                 if element.BackgroundColor != COLOR_SYSTEM_DEFAULT: | ||||||
|                     element.TKCheckbutton.config(highlightbackground=element.BackgroundColor) |                     element.TKCheckbutton.config(highlightbackground=element.BackgroundColor) | ||||||
|                 if element.TextColor != COLOR_SYSTEM_DEFAULT: |                 if element.TextColor != COLOR_SYSTEM_DEFAULT: | ||||||
|  | @ -26475,4 +26481,4 @@ if __name__ == '__main__': | ||||||
|         exit(0) |         exit(0) | ||||||
|     main() |     main() | ||||||
|     exit(0) |     exit(0) | ||||||
| #0f39d7ccc690f323707b2c591286af1aa7833c959432b3478340c6818dff6f76095f647e438ccdd3bccf0b24b1ea4f2e65b3dd131346e60e564361f2638b765cc96144915a9e22af993eec69165cee78a4234a49360501170277d846db7b9d1503e1c73f55252cb82865bd79554d67a769ddb860d568c93e202e0944b5676ed64dabc0373a6ed98c283c8e91980b43e7b2ce817dae72ab7fc4199949f34e8953f7b8f17a3fefda65baeb53f49c8d55896f2402675298a42f3a0ffb8046b58c26e52fb40ec9118b8c7d369f75e77e6c91d95f9db37462e0f62b9a10cf98ac7cfe769235ce6310136ec9c88c22332ca877bfb8508c26b39a94b6b0c90160692d4756569aba1ff4ce0115840d145bf6b509b8de50fba63f56509ebb72401337697e6b9bb2d669e4e28210f5e753db71bd97432dc55759d0251346b5239d6c4f120d56141c1e7f8269c0dc4bcfac73ee79dd2b8d70f4049a5f93554bd87b246708c808ae1dc3f2bfb224ee6479824b3c1b653ed1c5918198670840d02e3eb2162319049dd1bf486492fb202fc87810127bc3f00770ba7b7251b7f33880b02284bf9e103428186576d28f89e6749e4f4dea026ef740528d21ab022858ab0f78b08186d9c919e5ea02b819c9934670f8437f869ba5026de5e0321030b9d863cb0b1b5e33c3e91f6e14034d89ecb13210ffaa6d23cb910bd8cbd33457a588a4c3c52439 | #775d50bc7a349101f5f8cf0fa731a832480c6dbdfe73bdd2dcd1d96a86c9c4b7fddaf350d28ed990dded140d52689328f7f68ade01cb281e58332887235cc76411a24c9bc3cfb32fd32eb17a5d94660ec9117979f92137899377742bc6c1c45a7def3d6886e4d650ef8fd19b53dd8319dd1615df41aa4e6a967a8a7b01830e074b90d1dcfabd8ae7a5848cac7f3fc82cb1ec51e0fa4c3b2fd6b82a8ede0f6c257973ff4f8263bb41abe488a4bec28a15d9e9981aecfa59f5f46fcea8b9134acd3d43b2b0ceb15837aa1753f13ef12c4c9d4c2559302a02600f9cc32fb7dacc50f2c144dd996e4c5c1abb5ada3dc50b045e23e730c24dce5684132fc8d98c0725b2e61745b33ce258b6d695b2ddc13656ee8e4d867646807bc5e578eb5bbd51fa069bdd24f3ad4ade1971833a7a41e1d35d23ee41a54f276946e3b109e08ff72ce1994462021bcbdb337693caa803134196212f802e914026dfa8e055b8258fce2888c5affaac665c644f56af42a62935bec8b58dcf5d98f6d556337b26b6fa00a6aa33b76c73768713a666f58623304e59739e91587aa664055091465903ecfbde1d9aecd6696af5ff9b92096a2f007a1821cf74c107f58bc1d390c9d233af00e341a8ead04dfb29d748749a4d2ce1c59afb7efa501dd046cce5a3ef9d5fc05ad2aed21b32c4cd80364f40044396308bfbe3ae6dd1afb594b1380e42854d7ece | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue