Exposed 'pad' for ALL ELEMENTS. Touched every Element. Changed how shortcut funcations are made. New demo program Keypad.
This commit is contained in:
		
							parent
							
								
									d4f09d367d
								
							
						
					
					
						commit
						07772cb2e7
					
				
					 2 changed files with 98 additions and 66 deletions
				
			
		
							
								
								
									
										36
									
								
								Demo_Keypad.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								Demo_Keypad.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,36 @@ | ||||||
|  | import PySimpleGUI as g | ||||||
|  | 
 | ||||||
|  | # g.SetOptions(button_color=g.COLOR_SYSTEM_DEFAULT)   # because some people like gray buttons | ||||||
|  | 
 | ||||||
|  | # create the 2 Elements we want to control outside the form | ||||||
|  | out_elem = g.Text('', size=(15, 1), font=('Helvetica', 18), text_color='red') | ||||||
|  | in_elem = g.Input(size=(10,1), do_not_clear=True, key='input') | ||||||
|  | 
 | ||||||
|  | layout = [[g.Text('Choose Test'), g.DropDown(values=['Input', 'Output', 'Some option']), g.ReadFormButton('Input Option', size=(10,1))], | ||||||
|  |           [in_elem], | ||||||
|  |           [g.ReadFormButton('1', size=(5,2)), g.ReadFormButton('2', size=(5,2)), g.ReadFormButton('3', size=(5,2))], | ||||||
|  |           [g.ReadFormButton('4', size=(5,2)), g.ReadFormButton('5', size=(5,2)), g.ReadFormButton('6', size=(5,2))], | ||||||
|  |           [g.ReadFormButton('7', size=(5,2)), g.ReadFormButton('8', size=(5,2)), g.ReadFormButton('9', size=(5,2))], | ||||||
|  |           [g.ReadFormButton('Submit', size=(5,2)),g.ReadFormButton('0', size=(5,2)), g.ReadFormButton('Clear', size=(5,2))], | ||||||
|  |           [out_elem], | ||||||
|  |           ] | ||||||
|  | 
 | ||||||
|  | form = g.FlexForm('Keypad', auto_size_buttons=False) | ||||||
|  | form.Layout(layout) | ||||||
|  | 
 | ||||||
|  | keys_entered = '' | ||||||
|  | while True: | ||||||
|  |     button, values = form.Read()                # read the form | ||||||
|  |     if button is None:                          # if the X button clicked, just exit | ||||||
|  |         break | ||||||
|  |     if button == 'Clear':                       # clear keys if clear button | ||||||
|  |         keys_entered = '' | ||||||
|  |     elif button in '1234567890': | ||||||
|  |         keys_entered = values['input']            # get what's been entered so far | ||||||
|  |         keys_entered += button                  # add the new digit | ||||||
|  |     elif button == 'Submit': | ||||||
|  |         keys_entered = in_elem.Get() | ||||||
|  |         out_elem.Update(keys_entered)           # output the final string | ||||||
|  | 
 | ||||||
|  |     in_elem.Update(keys_entered)                # change the form to reflect current key string | ||||||
|  | 
 | ||||||
							
								
								
									
										128
									
								
								PySimpleGUI.py
									
										
									
									
									
								
							
							
						
						
									
										128
									
								
								PySimpleGUI.py
									
										
									
									
									
								
							|  | @ -1,4 +1,3 @@ | ||||||
| 
 |  | ||||||
| #!/usr/bin/env Python3 | #!/usr/bin/env Python3 | ||||||
| import tkinter as tk | import tkinter as tk | ||||||
| from tkinter import filedialog | from tkinter import filedialog | ||||||
|  | @ -165,12 +164,12 @@ MSG_BOX_OK = 0 | ||||||
| #                       Element CLASS                                       # | #                       Element CLASS                                       # | ||||||
| # ------------------------------------------------------------------------- # | # ------------------------------------------------------------------------- # | ||||||
| class Element(): | class Element(): | ||||||
|     def __init__(self, type, scale=(None, None), size=(None, None), auto_size_text=None, font=None, background_color=None, text_color=None, key=None): |     def __init__(self, type, scale=(None, None), size=(None, None), auto_size_text=None, font=None, background_color=None, text_color=None, key=None, pad=None): | ||||||
|         self.Size = size |         self.Size = size | ||||||
|         self.Type = type |         self.Type = type | ||||||
|         self.AutoSizeText = auto_size_text |         self.AutoSizeText = auto_size_text | ||||||
|         self.Scale = scale |         self.Scale = scale | ||||||
|         self.Pad = DEFAULT_ELEMENT_PADDING |         self.Pad = DEFAULT_ELEMENT_PADDING if pad is None else pad | ||||||
|         self.Font = font |         self.Font = font | ||||||
| 
 | 
 | ||||||
|         self.TKStringVar = None |         self.TKStringVar = None | ||||||
|  | @ -217,7 +216,7 @@ class Element(): | ||||||
| #                           Input Class                                  # | #                           Input Class                                  # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class InputText(Element): | class InputText(Element): | ||||||
|     def __init__(self, default_text ='', scale=(None, None), size=(None, None), auto_size_text=None, password_char='', background_color=None, text_color=None, do_not_clear=False, key=None, focus=False): |     def __init__(self, default_text ='', scale=(None, None), size=(None, None), auto_size_text=None, password_char='', background_color=None, text_color=None, do_not_clear=False, key=None, focus=False, pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Input a line of text Element |         Input a line of text Element | ||||||
|         :param default_text: Default value to display |         :param default_text: Default value to display | ||||||
|  | @ -233,7 +232,7 @@ class InputText(Element): | ||||||
|         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR |         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR | ||||||
|         self.Focus = focus |         self.Focus = focus | ||||||
|         self.do_not_clear = do_not_clear |         self.do_not_clear = do_not_clear | ||||||
|         super().__init__(ELEM_TYPE_INPUT_TEXT, scale=scale, size=size, auto_size_text=auto_size_text, background_color=bg, text_color=fg, key=key) |         super().__init__(ELEM_TYPE_INPUT_TEXT, scale=scale, size=size, auto_size_text=auto_size_text, background_color=bg, text_color=fg, key=key, pad=pad) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     def Update(self, new_value): |     def Update(self, new_value): | ||||||
|  | @ -250,7 +249,7 @@ class InputText(Element): | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class InputCombo(Element): | class InputCombo(Element): | ||||||
| 
 | 
 | ||||||
|     def __init__(self, values, scale=(None, None), size=(None, None), auto_size_text=None, background_color=None, text_color=None, key=None): |     def __init__(self, values, scale=(None, None), size=(None, None), auto_size_text=None, background_color=None, text_color=None, key=None, pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Input Combo Box Element (also called Dropdown box) |         Input Combo Box Element (also called Dropdown box) | ||||||
|         :param values: |         :param values: | ||||||
|  | @ -264,7 +263,7 @@ class InputCombo(Element): | ||||||
|         bg = background_color if background_color else DEFAULT_INPUT_ELEMENTS_COLOR |         bg = background_color if background_color else DEFAULT_INPUT_ELEMENTS_COLOR | ||||||
|         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR |         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR | ||||||
| 
 | 
 | ||||||
|         super().__init__(ELEM_TYPE_INPUT_COMBO, scale=scale, size=size, auto_size_text=auto_size_text, background_color=bg, text_color=fg, key=key) |         super().__init__(ELEM_TYPE_INPUT_COMBO, scale=scale, size=size, auto_size_text=auto_size_text, background_color=bg, text_color=fg, key=key, pad=pad) | ||||||
| 
 | 
 | ||||||
|     def __del__(self): |     def __del__(self): | ||||||
|         try: |         try: | ||||||
|  | @ -278,8 +277,7 @@ class InputCombo(Element): | ||||||
| #                           Listbox                                      # | #                           Listbox                                      # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class Listbox(Element): | class Listbox(Element): | ||||||
| 
 |     def __init__(self, values, select_mode=None, scale=(None, None), size=(None, None), auto_size_text=None, font=None, background_color=None, text_color=None, key=None, pad=None): | ||||||
|     def __init__(self, values, select_mode=None, scale=(None, None), size=(None, None), auto_size_text=None, font=None, background_color=None, text_color=None, key=None): |  | ||||||
|         ''' |         ''' | ||||||
|         Listbox Element |         Listbox Element | ||||||
|         :param values: |         :param values: | ||||||
|  | @ -303,7 +301,7 @@ class Listbox(Element): | ||||||
|             self.SelectMode = DEFAULT_LISTBOX_SELECT_MODE |             self.SelectMode = DEFAULT_LISTBOX_SELECT_MODE | ||||||
|         bg = background_color if background_color else DEFAULT_INPUT_ELEMENTS_COLOR |         bg = background_color if background_color else DEFAULT_INPUT_ELEMENTS_COLOR | ||||||
|         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR |         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR | ||||||
|         super().__init__(ELEM_TYPE_INPUT_LISTBOX, scale=scale, size=size, auto_size_text=auto_size_text, font=font, background_color=bg, text_color=fg, key=key) |         super().__init__(ELEM_TYPE_INPUT_LISTBOX, scale=scale, size=size, auto_size_text=auto_size_text, font=font, background_color=bg, text_color=fg, key=key, pad=pad) | ||||||
| 
 | 
 | ||||||
|     def Update(self, values): |     def Update(self, values): | ||||||
|         self.TKListbox.delete(0, 'end') |         self.TKListbox.delete(0, 'end') | ||||||
|  | @ -324,7 +322,7 @@ class Listbox(Element): | ||||||
| #                           Radio                                        # | #                           Radio                                        # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class Radio(Element): | class Radio(Element): | ||||||
|     def __init__(self, text, group_id, default=False, scale=(None, None), size=(None, None), auto_size_text=None, background_color=None, text_color=None, font=None, key=None): |     def __init__(self, text, group_id, default=False, scale=(None, None), size=(None, None), auto_size_text=None, background_color=None, text_color=None, font=None, key=None, pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Radio Button Element |         Radio Button Element | ||||||
|         :param text: |         :param text: | ||||||
|  | @ -341,7 +339,7 @@ class Radio(Element): | ||||||
|         self.TKRadio = None |         self.TKRadio = None | ||||||
|         self.GroupID = group_id |         self.GroupID = group_id | ||||||
|         self.Value = None |         self.Value = None | ||||||
|         super().__init__(ELEM_TYPE_INPUT_RADIO, scale=scale , size=size, auto_size_text=auto_size_text, font=font, background_color=background_color, text_color=text_color, key=key) |         super().__init__(ELEM_TYPE_INPUT_RADIO, scale=scale , size=size, auto_size_text=auto_size_text, font=font, background_color=background_color, text_color=text_color, key=key, pad=pad) | ||||||
| 
 | 
 | ||||||
|     def __del__(self): |     def __del__(self): | ||||||
|         try: |         try: | ||||||
|  | @ -354,7 +352,7 @@ class Radio(Element): | ||||||
| #                           Checkbox                                     # | #                           Checkbox                                     # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class Checkbox(Element): | class Checkbox(Element): | ||||||
|     def __init__(self, text, default=False, scale=(None, None), size=(None, None), auto_size_text=None, font=None, background_color=None, text_color=None, key=None): |     def __init__(self, text, default=False, scale=(None, None), size=(None, None), auto_size_text=None, font=None, background_color=None, text_color=None, key=None, pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Check Box Element |         Check Box Element | ||||||
|         :param text: |         :param text: | ||||||
|  | @ -370,7 +368,7 @@ class Checkbox(Element): | ||||||
|         self.Value = None |         self.Value = None | ||||||
|         self.TKCheckbutton = None |         self.TKCheckbutton = None | ||||||
| 
 | 
 | ||||||
|         super().__init__(ELEM_TYPE_INPUT_CHECKBOX, scale=scale, size=size, auto_size_text=auto_size_text, font=font, background_color=background_color, text_color=text_color, key=key) |         super().__init__(ELEM_TYPE_INPUT_CHECKBOX, scale=scale, size=size, auto_size_text=auto_size_text, font=font, background_color=background_color, text_color=text_color, key=key, pad=pad) | ||||||
| 
 | 
 | ||||||
|     def Get(self): |     def Get(self): | ||||||
|         return self.TKIntVar.get() |         return self.TKIntVar.get() | ||||||
|  | @ -393,7 +391,7 @@ class Checkbox(Element): | ||||||
| class Spin(Element): | class Spin(Element): | ||||||
|     # Values = None |     # Values = None | ||||||
|     # TKSpinBox = None |     # TKSpinBox = None | ||||||
|     def __init__(self, values, initial_value=None, scale=(None, None), size=(None, None), auto_size_text=None, font=None, background_color=None, text_color=None, key=None): |     def __init__(self, values, initial_value=None, scale=(None, None), size=(None, None), auto_size_text=None, font=None, background_color=None, text_color=None, key=None, pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Spin Box Element |         Spin Box Element | ||||||
|         :param values: |         :param values: | ||||||
|  | @ -410,7 +408,7 @@ class Spin(Element): | ||||||
|         bg = background_color if background_color else DEFAULT_INPUT_ELEMENTS_COLOR |         bg = background_color if background_color else DEFAULT_INPUT_ELEMENTS_COLOR | ||||||
|         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR |         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR | ||||||
| 
 | 
 | ||||||
|         super().__init__(ELEM_TYPE_INPUT_SPIN, scale, size, auto_size_text, font=font,background_color=bg, text_color=fg, key=key) |         super().__init__(ELEM_TYPE_INPUT_SPIN, scale, size, auto_size_text, font=font,background_color=bg, text_color=fg, key=key, pad=pad) | ||||||
|         return |         return | ||||||
| 
 | 
 | ||||||
|     def __del__(self): |     def __del__(self): | ||||||
|  | @ -424,7 +422,7 @@ class Spin(Element): | ||||||
| #                           Multiline                                    # | #                           Multiline                                    # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class Multiline(Element): | class Multiline(Element): | ||||||
|     def __init__(self, default_text='', enter_submits = False, scale=(None, None), size=(None, None), auto_size_text=None, background_color=None, text_color=None, do_not_clear=False, key=None, focus=False): |     def __init__(self, default_text='', enter_submits = False, scale=(None, None), size=(None, None), auto_size_text=None, background_color=None, text_color=None, do_not_clear=False, key=None, focus=False, pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Input Multi-line Element |         Input Multi-line Element | ||||||
|         :param default_text: |         :param default_text: | ||||||
|  | @ -441,7 +439,7 @@ class Multiline(Element): | ||||||
|         self.do_not_clear = do_not_clear |         self.do_not_clear = do_not_clear | ||||||
|         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR |         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR | ||||||
| 
 | 
 | ||||||
|         super().__init__(ELEM_TYPE_INPUT_MULTILINE, scale=scale, size=size, auto_size_text=auto_size_text, background_color=bg, text_color=fg, key=key) |         super().__init__(ELEM_TYPE_INPUT_MULTILINE, scale=scale, size=size, auto_size_text=auto_size_text, background_color=bg, text_color=fg, key=key, pad=pad) | ||||||
|         return |         return | ||||||
| 
 | 
 | ||||||
|     def Update(self, NewValue): |     def Update(self, NewValue): | ||||||
|  | @ -458,7 +456,7 @@ class Multiline(Element): | ||||||
| #                                       Text                             # | #                                       Text                             # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class Text(Element): | class Text(Element): | ||||||
|     def __init__(self, text, scale=(None, None), size=(None, None), auto_size_text=None, font=None, text_color=None, background_color=None,justification=None): |     def __init__(self, text, scale=(None, None), size=(None, None), auto_size_text=None, font=None, text_color=None, background_color=None,justification=None, pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Text Element - Displays text in your form.  Can be updated in non-blocking forms |         Text Element - Displays text in your form.  Can be updated in non-blocking forms | ||||||
|         :param text: The text to display |         :param text: The text to display | ||||||
|  | @ -477,9 +475,7 @@ class Text(Element): | ||||||
|             bg = DEFAULT_TEXT_ELEMENT_BACKGROUND_COLOR |             bg = DEFAULT_TEXT_ELEMENT_BACKGROUND_COLOR | ||||||
|         else: |         else: | ||||||
|             bg = background_color |             bg = background_color | ||||||
|         # self.Font = Font if Font else DEFAULT_FONT |         super().__init__(ELEM_TYPE_TEXT, scale, size, auto_size_text, background_color=bg, font=font if font else DEFAULT_FONT, text_color=self.TextColor, pad=pad) | ||||||
|         # i=1/0 |  | ||||||
|         super().__init__(ELEM_TYPE_TEXT, scale, size, auto_size_text, background_color=bg, font=font if font else DEFAULT_FONT, text_color=self.TextColor) |  | ||||||
|         return |         return | ||||||
| 
 | 
 | ||||||
|     def Update(self, new_value = None, background_color=None, text_color=None): |     def Update(self, new_value = None, background_color=None, text_color=None): | ||||||
|  | @ -590,7 +586,7 @@ class TKOutput(tk.Frame): | ||||||
| #  Routes stdout, stderr to a scrolled window                            # | #  Routes stdout, stderr to a scrolled window                            # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class Output(Element): | class Output(Element): | ||||||
|     def __init__(self, scale=(None, None), size=(None, None), background_color=None, text_color=None): |     def __init__(self, scale=(None, None), size=(None, None), background_color=None, text_color=None, pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Output Element - reroutes stdout, stderr to this window |         Output Element - reroutes stdout, stderr to this window | ||||||
|         :param scale: Adds multiplier to size (w,h) |         :param scale: Adds multiplier to size (w,h) | ||||||
|  | @ -601,7 +597,7 @@ class Output(Element): | ||||||
|         bg = background_color if background_color else DEFAULT_INPUT_ELEMENTS_COLOR |         bg = background_color if background_color else DEFAULT_INPUT_ELEMENTS_COLOR | ||||||
|         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR |         fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR | ||||||
| 
 | 
 | ||||||
|         super().__init__(ELEM_TYPE_OUTPUT, scale=scale, size=size, background_color=bg, text_color=fg) |         super().__init__(ELEM_TYPE_OUTPUT, scale=scale, size=size, background_color=bg, text_color=fg, pad=pad) | ||||||
| 
 | 
 | ||||||
|     def __del__(self): |     def __del__(self): | ||||||
|         try: |         try: | ||||||
|  | @ -614,7 +610,7 @@ class Output(Element): | ||||||
| #                           Button Class                                 # | #                           Button Class                                 # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class Button(Element): | class Button(Element): | ||||||
|     def __init__(self, button_type=BUTTON_TYPE_CLOSES_WIN, target=(None, None), button_text='', file_types=(("ALL Files", "*.*"),), image_filename=None, image_size=(None, None), image_subsample=None, border_width=None, scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False): |     def __init__(self, button_type=BUTTON_TYPE_CLOSES_WIN, target=(None, None), button_text='', file_types=(("ALL Files", "*.*"),), image_filename=None, image_size=(None, None), image_subsample=None, border_width=None, scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False, pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Button Element - Specifies all types of buttons |         Button Element - Specifies all types of buttons | ||||||
|         :param button_type: |         :param button_type: | ||||||
|  | @ -645,7 +641,7 @@ class Button(Element): | ||||||
|         self.BorderWidth = border_width if border_width is not None else DEFAULT_BORDER_WIDTH |         self.BorderWidth = border_width if border_width is not None else DEFAULT_BORDER_WIDTH | ||||||
|         self.BindReturnKey = bind_return_key |         self.BindReturnKey = bind_return_key | ||||||
|         self.Focus = focus |         self.Focus = focus | ||||||
|         super().__init__(ELEM_TYPE_BUTTON, scale, size, font=font) |         super().__init__(ELEM_TYPE_BUTTON, scale=scale, size=size, font=font, pad=pad) | ||||||
|         return |         return | ||||||
| 
 | 
 | ||||||
|     def ButtonReleaseCallBack(self, parm): |     def ButtonReleaseCallBack(self, parm): | ||||||
|  | @ -731,7 +727,7 @@ class Button(Element): | ||||||
| #                           ProgreessBar                                 # | #                           ProgreessBar                                 # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class ProgressBar(Element): | class ProgressBar(Element): | ||||||
|     def __init__(self, max_value, orientation=None, scale=(None, None), size=(None, None), auto_size_text=None, bar_color=(None, None), style=None, border_width=None, relief=None): |     def __init__(self, max_value, orientation=None, scale=(None, None), size=(None, None), auto_size_text=None, bar_color=(None, None), style=None, border_width=None, relief=None, pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Progress Bar Element |         Progress Bar Element | ||||||
|         :param max_value: |         :param max_value: | ||||||
|  | @ -754,7 +750,7 @@ class ProgressBar(Element): | ||||||
|         self.BorderWidth = border_width if border_width else DEFAULT_PROGRESS_BAR_BORDER_WIDTH |         self.BorderWidth = border_width if border_width else DEFAULT_PROGRESS_BAR_BORDER_WIDTH | ||||||
|         self.Relief = relief if relief else DEFAULT_PROGRESS_BAR_RELIEF |         self.Relief = relief if relief else DEFAULT_PROGRESS_BAR_RELIEF | ||||||
|         self.BarExpired = False |         self.BarExpired = False | ||||||
|         super().__init__(ELEM_TYPE_PROGRESS_BAR, scale=scale, size=size, auto_size_text=auto_size_text) |         super().__init__(ELEM_TYPE_PROGRESS_BAR, scale=scale, size=size, auto_size_text=auto_size_text, pad=pad) | ||||||
|         return |         return | ||||||
| 
 | 
 | ||||||
|     def UpdateBar(self, current_count, max=None): |     def UpdateBar(self, current_count, max=None): | ||||||
|  | @ -779,7 +775,7 @@ class ProgressBar(Element): | ||||||
| #                           Image                                        # | #                           Image                                        # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class Image(Element): | class Image(Element): | ||||||
|     def __init__(self, filename=None, data=None,scale=(None, None), size=(None, None)): |     def __init__(self, filename=None, data=None,scale=(None, None), size=(None, None), pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Image Element |         Image Element | ||||||
|         :param filename: |         :param filename: | ||||||
|  | @ -792,7 +788,7 @@ class Image(Element): | ||||||
| 
 | 
 | ||||||
|         if data is None and filename is None: |         if data is None and filename is None: | ||||||
|             print('* Warning... no image specified in Image Element! *') |             print('* Warning... no image specified in Image Element! *') | ||||||
|         super().__init__(ELEM_TYPE_IMAGE, scale=scale, size=size) |         super().__init__(ELEM_TYPE_IMAGE, scale=scale, size=size, pad=pad) | ||||||
|         return |         return | ||||||
| 
 | 
 | ||||||
|     def Update(self, filename=None, data=None): |     def Update(self, filename=None, data=None): | ||||||
|  | @ -815,7 +811,7 @@ class Image(Element): | ||||||
| #                           Slider                                       # | #                           Slider                                       # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class Slider(Element): | class Slider(Element): | ||||||
|     def __init__(self, range=(None,None), default_value=None, orientation=None, border_width=None, relief=None, scale=(None, None), size=(None, None), font=None, background_color=None, text_color=None, key=None): |     def __init__(self, range=(None,None), default_value=None, orientation=None, border_width=None, relief=None, scale=(None, None), size=(None, None), font=None, background_color=None, text_color=None, key=None, pad=None): | ||||||
|         ''' |         ''' | ||||||
|         Slider Element |         Slider Element | ||||||
|         :param range: |         :param range: | ||||||
|  | @ -834,7 +830,7 @@ class Slider(Element): | ||||||
|         self.Orientation = orientation if orientation else DEFAULT_SLIDER_ORIENTATION |         self.Orientation = orientation if orientation else DEFAULT_SLIDER_ORIENTATION | ||||||
|         self.BorderWidth = border_width if border_width else DEFAULT_SLIDER_BORDER_WIDTH |         self.BorderWidth = border_width if border_width else DEFAULT_SLIDER_BORDER_WIDTH | ||||||
|         self.Relief = relief if relief else DEFAULT_SLIDER_RELIEF |         self.Relief = relief if relief else DEFAULT_SLIDER_RELIEF | ||||||
|         super().__init__(ELEM_TYPE_INPUT_SLIDER, scale=scale, size=size, font=font, background_color=background_color, text_color=text_color, key=key) |         super().__init__(ELEM_TYPE_INPUT_SLIDER, scale=scale, size=size, font=font, background_color=background_color, text_color=text_color, key=key, pad=pad) | ||||||
|         return |         return | ||||||
| 
 | 
 | ||||||
|     def Update(self, value, range=(None, None)): |     def Update(self, value, range=(None, None)): | ||||||
|  | @ -851,7 +847,7 @@ class Slider(Element): | ||||||
| #                           Column                                       # | #                           Column                                       # | ||||||
| # ---------------------------------------------------------------------- # | # ---------------------------------------------------------------------- # | ||||||
| class Column(Element): | class Column(Element): | ||||||
|     def __init__(self, layout, background_color = None): |     def __init__(self, layout, background_color = None, pad=None): | ||||||
|         self.UseDictionary = False |         self.UseDictionary = False | ||||||
|         self.ReturnValues = None |         self.ReturnValues = None | ||||||
|         self.ReturnValuesList = [] |         self.ReturnValuesList = [] | ||||||
|  | @ -865,7 +861,7 @@ class Column(Element): | ||||||
| 
 | 
 | ||||||
|         self.Layout(layout) |         self.Layout(layout) | ||||||
| 
 | 
 | ||||||
|         super().__init__(ELEM_TYPE_COLUMN, background_color=background_color) |         super().__init__(ELEM_TYPE_COLUMN, background_color=background_color, pad=pad) | ||||||
|         return |         return | ||||||
| 
 | 
 | ||||||
|     def AddRow(self, *args): |     def AddRow(self, *args): | ||||||
|  | @ -1200,68 +1196,68 @@ def T(display_text, scale=(None, None), size=(None, None), auto_size_text=None, | ||||||
|     return Text(display_text, scale=scale, size=size, auto_size_text=auto_size_text, font=font, text_color=text_color, justification=justification) |     return Text(display_text, scale=scale, size=size, auto_size_text=auto_size_text, font=font, text_color=text_color, justification=justification) | ||||||
| 
 | 
 | ||||||
| # -------------------------  FOLDER BROWSE Element lazy function  ------------------------- # | # -------------------------  FOLDER BROWSE Element lazy function  ------------------------- # | ||||||
| def FolderBrowse(target=(ThisRow, -1), button_text='Browse', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None): | def FolderBrowse(target=(ThisRow, -1), button_text='Browse', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, pad=None): | ||||||
|     return Button(BUTTON_TYPE_BROWSE_FOLDER, target=target, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color) |     return Button(BUTTON_TYPE_BROWSE_FOLDER, target=target, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  FILE BROWSE Element lazy function  ------------------------- # | # -------------------------  FILE BROWSE Element lazy function  ------------------------- # | ||||||
| def FileBrowse(target=(ThisRow, -1), file_types=(("ALL Files", "*.*"),), button_text='Browse', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None): | def FileBrowse(target=(ThisRow, -1), file_types=(("ALL Files", "*.*"),), button_text='Browse', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, pad=None): | ||||||
|     return Button(BUTTON_TYPE_BROWSE_FILE, target, button_text=button_text, file_types=file_types, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font) |     return Button(BUTTON_TYPE_BROWSE_FILE, target, button_text=button_text, file_types=file_types, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  FILE BROWSE Element lazy function  ------------------------- # | # -------------------------  FILE BROWSE Element lazy function  ------------------------- # | ||||||
| def FileSaveAs(target=(ThisRow, -1), file_types=(("ALL Files", "*.*"),), button_text='Save As...', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None): | def FileSaveAs(target=(ThisRow, -1), file_types=(("ALL Files", "*.*"),), button_text='Save As...', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, pad=None): | ||||||
|     return Button(BUTTON_TYPE_SAVEAS_FILE, target, button_text=button_text, file_types=file_types, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font) |     return Button(BUTTON_TYPE_SAVEAS_FILE, target, button_text=button_text, file_types=file_types, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  SAVE AS Element lazy function  ------------------------- # | # -------------------------  SAVE AS Element lazy function  ------------------------- # | ||||||
| def SaveAs(target=(ThisRow, -1), file_types=(("ALL Files", "*.*"),), button_text='Save As...', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None): | def SaveAs(target=(ThisRow, -1), file_types=(("ALL Files", "*.*"),), button_text='Save As...', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, pad=None): | ||||||
|     return Button(BUTTON_TYPE_SAVEAS_FILE, target, button_text=button_text, file_types=file_types, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font) |     return Button(BUTTON_TYPE_SAVEAS_FILE, target, button_text=button_text, file_types=file_types, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  SAVE BUTTON Element lazy function  ------------------------- # | # -------------------------  SAVE BUTTON Element lazy function  ------------------------- # | ||||||
| def Save(button_text='Save', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, bind_return_key=True,font=None, focus=False): | def Save(button_text='Save', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, bind_return_key=True,font=None, focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color,font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color,font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  SUBMIT BUTTON Element lazy function  ------------------------- # | # -------------------------  SUBMIT BUTTON Element lazy function  ------------------------- # | ||||||
| def Submit(button_text='Submit', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, bind_return_key=True,font=None, focus=False): | def Submit(button_text='Submit', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, bind_return_key=True,font=None, focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color,font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color,font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  OK BUTTON Element lazy function  ------------------------- # | # -------------------------  OK BUTTON Element lazy function  ------------------------- # | ||||||
| def OK(button_text='OK', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, bind_return_key=True, font=None,focus=False): | def OK(button_text='OK', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, bind_return_key=True, font=None,focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color,font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color,font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  YES BUTTON Element lazy function  ------------------------- # | # -------------------------  YES BUTTON Element lazy function  ------------------------- # | ||||||
| def Ok(button_text='Ok', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, bind_return_key=True, font=None,focus=False): | def Ok(button_text='Ok', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, bind_return_key=True, font=None,focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  CANCEL BUTTON Element lazy function  ------------------------- # | # -------------------------  CANCEL BUTTON Element lazy function  ------------------------- # | ||||||
| def Cancel(button_text='Cancel', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False): | def Cancel(button_text='Cancel', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  QUIT BUTTON Element lazy function  ------------------------- # | # -------------------------  QUIT BUTTON Element lazy function  ------------------------- # | ||||||
| def Quit(button_text='Quit', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False): | def Quit(button_text='Quit', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  Exit BUTTON Element lazy function  ------------------------- # | # -------------------------  Exit BUTTON Element lazy function  ------------------------- # | ||||||
| def Exit(button_text='Exit', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False): | def Exit(button_text='Exit', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  YES BUTTON Element lazy function  ------------------------- # | # -------------------------  YES BUTTON Element lazy function  ------------------------- # | ||||||
| def Yes(button_text='Yes', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None,font=None, bind_return_key=True, focus=False): | def Yes(button_text='Yes', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None,font=None, bind_return_key=True, focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  NO BUTTON Element lazy function  ------------------------- # | # -------------------------  NO BUTTON Element lazy function  ------------------------- # | ||||||
| def No(button_text='No', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None,font=None, bind_return_key=False, focus=False): | def No(button_text='No', scale=(None, None), size=(None, None), auto_size_button=None, button_color=None,font=None, bind_return_key=False, focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_CLOSES_WIN, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| 
 | 
 | ||||||
| # -------------------------  GENERIC BUTTON Element lazy function  ------------------------- # | # -------------------------  GENERIC BUTTON Element lazy function  ------------------------- # | ||||||
| # this is the only button that REQUIRES button text field | # this is the only button that REQUIRES button text field | ||||||
| def SimpleButton(button_text, image_filename=None, image_size=(None, None), image_subsample=None, border_width=None, scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False): | def SimpleButton(button_text, image_filename=None, image_size=(None, None), image_subsample=None, border_width=None, scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_CLOSES_WIN, image_filename=image_filename, image_size=image_size, image_subsample=image_subsample, button_text=button_text, border_width=border_width, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_CLOSES_WIN, image_filename=image_filename, image_size=image_size, image_subsample=image_subsample, button_text=button_text, border_width=border_width, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| # -------------------------  GENERIC BUTTON Element lazy function  ------------------------- # | # -------------------------  GENERIC BUTTON Element lazy function  ------------------------- # | ||||||
| # this is the only button that REQUIRES button text field | # this is the only button that REQUIRES button text field | ||||||
| def ReadFormButton(button_text, image_filename=None, image_size=(None, None),image_subsample=None,border_width=None,scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False): | def ReadFormButton(button_text, image_filename=None, image_size=(None, None),image_subsample=None,border_width=None,scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_READ_FORM, image_filename=image_filename, image_size=image_size, image_subsample=image_subsample, border_width=border_width, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_READ_FORM, image_filename=image_filename, image_size=image_size, image_subsample=image_subsample, border_width=border_width, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| 
 | 
 | ||||||
| def RealtimeButton(button_text, image_filename=None, image_size=(None, None),image_subsample=None,border_width=None,scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False): | def RealtimeButton(button_text, image_filename=None, image_size=(None, None),image_subsample=None,border_width=None,scale=(None, None), size=(None, None), auto_size_button=None, button_color=None, font=None, bind_return_key=False, focus=False, pad=None): | ||||||
|     return Button(BUTTON_TYPE_REALTIME, image_filename=image_filename, image_size=image_size, image_subsample=image_subsample, border_width=border_width, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus) |     return Button(BUTTON_TYPE_REALTIME, image_filename=image_filename, image_size=image_size, image_subsample=image_subsample, border_width=border_width, button_text=button_text, scale=scale, size=size, auto_size_button=auto_size_button, button_color=button_color, font=font, bind_return_key=bind_return_key, focus=focus, pad=pad) | ||||||
| 
 | 
 | ||||||
| #####################################  -----  RESULTS   ------ ################################################## | #####################################  -----  RESULTS   ------ ################################################## | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue