[Ir...] Posted October 2, 2024 Share Posted October 2, 2024 Hello, Is it possible to interact with the creation of a dialog from a script? For example, can you define the columns and rows of a dialog in a scripting environment before calling the dialog? To illustrate, I’ll use a simple example. Giving these values to these variables (left image) I want to create the dialog of the right image. If the values given were different, the dialog would also change. See the image below. Is there any way I could control the dialog in this manner? Thank you in advance, Irune Link to comment Share on other sites More sharing options...
[Ma...] Posted October 4, 2024 Share Posted October 4, 2024 Hello Irune, Yes, this is possible. When you insert a dialog into the script, you can select the option "Embedded into script". You will notice that the dialog definition is a Python dictionary, which is passed to gom.script.sys.create_user_defined_dialog (). Ususally, this dictionary is created with the Dialog editor and used as a constant, but it is possible to modify it before calling gom.script.sys.create_user_defined_dialog (). For each widget in the dialog, you will see a key/value pair for "rows" and "columns" which defines its position in the dialog window. The dialog window's total number of rows and columns is calculated internally. You can create widgets by adding entries in the dictionary by your script accordingly. Best regards, Matthias Link to comment Share on other sites More sharing options...
[Mi...] Posted October 10, 2024 Share Posted October 10, 2024 Please sign in to view this username. Have you been able to make this work? Please sign in to view this username. could you please give an example of how his works in practice? I have been trying to figure this out, but I don't know how to begin without also breaking the embedded dialog code. Link to comment Share on other sites More sharing options...
[Mi...] Posted October 11, 2024 Share Posted October 11, 2024 (edited) I did some digging around and using other examples on the forums, I developed some code that can dynamically add a number of (in my case, checkboxes), as well other widgets like the continuous text widget. The code is a bit rudimentary as I am new to Python and I am not sure if it what Please sign in to view this username. was hinting at, but this code is a start. One issue it does have is that it doesn't allow me to use html formatting on the text within the continuous text field despite me using <html> tagging. import gom def createBlankForm(width, height): blankForm='<dialog>' \ '<title>Test Dialog</title>' \ '<style></style>' \ '<control id="Empty"/>' \ '<position></position>' \ '<embedding></embedding>' \ '<sizemode></sizemode>' \ '<size width="' + str(width) + '" height="' + str(height) + '"/>' \ '<content columns="10" rows="10">' return blankForm def addcheckBox(colPosition, rowPosition, checkBoxName, instance): checkBox = '<widget columnspan="1" type="input::checkbox" rowspan="1" row="' + str(rowPosition) + '"column="' + str(colPosition) + '">' \ ' <name>checkbox_' + str(instance) + '</name>' \ ' <tooltip></tooltip>' \ ' <value>true</value>' \ ' <title>' + str(checkBoxName) + '</title>' \ '</widget>' return checkBox def addContinuousText(colPosition, rowPosition, text): c_text = '<widget columnspan="1" type="display::text" rowspan="1" row="' + str(rowPosition) + '"column="' + str(colPosition) + '">' \ ' <name>text</name>' \ ' <tooltip></tooltip>' \ ' <text>' + str(text) + '</text>' \ ' <value>true</value>' \ '</widget>' return c_text def buildDialog(): dialog = createBlankForm(500, 500) dialog += addContinuousText(0,0,'<html><p align=\"center\"><span style=\"font-weight:600; color:#ff0000;\">abc</span></p></html>') startingRow = 1 startingCol = 1 for i in range(5): dialog += addcheckBox(startingCol, startingRow + i, 'Random_Name_' + str(i), i) return dialog + '</content></dialog>' def dialog_event_handler (widget): #print(widget) if widget == dialog.checkbox_1: print('Checkbox_1 was interacted with!') return 1 dialog=gom.script.sys.create_user_defined_dialog (content = buildDialog()) dialog.handler = dialog_event_handler gom.script.sys.show_user_defined_dialog (dialog=dialog) Edited October 11, 2024 minor correction Link to comment Share on other sites More sharing options...
[Ir...] Posted October 17, 2024 Author Share Posted October 17, 2024 Thank you for your responses! Please sign in to view this username. , that code was very helpful! Still, I need to look into it more deeply to fully understand it. I have been trying to do something similar myself. I attempted to define the content of the dialog outside so I could use a ‘for’ loop to add all the rows I wanted. To achieve this, I used the same format and structure as the dialog code. Here is an example of a code I wrote to create as many rows of buttons as I need: import gom number_of_rows=5 contenido=[] nombre='BUTTON' for i in range(number_of_rows): nombre1='button_'+str(i) contenidoi=[{"button_type": "toggle","columns": 1,"icon": "AAAAAA==","icon_file_name": "","icon_size": {"value": "icon"},"icon_system_size": {"value": "default"},"icon_system_type": {"value": "ok"},"icon_type": {"value": "none"},"name": nombre1,"rows": 1,"text": {"id": "","text": nombre,"translatable": True},"tooltip": {"id": "","text": "","translatable": True},"type": "button::pushbutton"}] print(contenidoi) contenido.append(contenidoi) print(contenido) DIALOG=gom.script.sys.create_user_defined_dialog (dialog={ "content": contenido, "control": { "id": "OkCancel" }, "embedding": "", "position": "", "size": { "height": 242, "width": 198 }, "sizemode": "", "style": "", "title": { "id": "", "text": "Dialog Title", "translatable": True } }) # # Event handler function called if anything happens inside of the dialog # def dialog_event_handler (widget): pass DIALOG.handler = dialog_event_handler RESULT=gom.script.sys.show_user_defined_dialog (dialog=DIALOG) Best regards, Irune Link to comment Share on other sites More sharing options...
[Mi...] Posted October 17, 2024 Share Posted October 17, 2024 (edited) Please sign in to view this username. I'm glad that my code helped. It looks like you're on the right track, and unlike me it appears you discovered how to dynamically create a dialog box using the JSON code instead of XML code (which I believe is why my HTML formatting code is not working). It seems that all we need to simply do is use '.append' to build out the dialog box using JSON code. I will try converting my code to use JSON when I have the chance. In the meantime, I used these two posts to help learn how to dynamically build a dialog box: https://qualityforum.zeiss.com/topic/1217-selection-element-list-user-defined-script-function/#comment-3959 and https://qualityforum.zeiss.com/topic/1484-create-a-dynamic-dialog/#comment-4940. I believe that GOM dialog boxes are grid based and the positions of widgets originate from a 0,0 position in the top-left corner. You can tell the script that you want 10 rows and 10 columns, but you can't have any gaps between the rows and columns unless you find a way to use seperators. Here is slightly altered code from one of these posts similar that may help you determine out how to define a number of rows and columns. def selection(prompt='', item_list=[]): if not isinstance(item_list, list): return header = '<dialog>' \ '<title>What is the meaning of life?</title>' \ '<control id="Empty"/>' \ '<position>center</position>' \ '<sizemode>fixed</sizemode>' \ '<size width="200" height="100"/>' \ '<content rows="{}" columns="{}">' \ '<widget row="0" column="0" type="label">' \ '<name>prompt</name>' \ '<text>{}</text>' \ '</widget>' button = '<widget column="{}" row="{}" type="button::pushbutton">' \ '<name>{}</name>' \ '<text>{}</text>' \ '<type>toggle</type>' \ '<focus>True</focus>' \ '</widget>' def build_dialog(): num_columns = int(len(item_list) / 5) + 1 dialog = header.format(len(item_list) + 1, num_columns, prompt) index = 0 for i in range(1, len(item_list) + 1): if i <= 5: row = i column = index if i == 5: index += 1 else: row = abs(index * 5 - i) column = index # if i % 5 == 0: #Uncomment these two lines to add a third row of buttons # index += 1 dialog += button.format(column, row, i, item_list[i - 1]) return dialog + '</content></dialog>' def dialog_event_handler(widget): global selected if isinstance(widget, gom.Widget): selected = widget.text gom.script.sys.close_user_defined_dialog(dialog=dialog) dialog = gom.script.sys.create_user_defined_dialog(content=build_dialog()) dialog.handler = dialog_event_handler gom.script.sys.show_user_defined_dialog(dialog=dialog) return selected buttonList = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13] selection('Put anything you want here', buttonList) Edited October 17, 2024 Link to comment Share on other sites More sharing options...
[Mi...] Posted October 17, 2024 Share Posted October 17, 2024 (edited) I have to move on to other tasks, but I think I've figured out a bit of how the software is interpreting JSON code and building dialog boxes. Hopefully a developer or someone more knowledgeable can chime in, however I believe this is how things are working: ----- 1) Everything appears to originate from the top left corner of the first available row. 2) For any widget(s) you wish to add, first you define the columns it will span. - If you wish to add just one widget for that given row, simply add the one widget. The next widget or widget(s) will be in the next row down. - If you wish to add multiple widgets to the same row, you need to build a list of the widgets that belong in that row. The next widget or widget(s) will be in the next row down. ----- I'm going to share some of my code below to give you an idea of how you can put together JSON based dialog boxes. I will also share commented code that can help teach you how the rows and columns are interpreted. ----- The code for my dialog box: import gom #number_of_rows=5 #contenido=[] #nombre='BUTTON' # #for i in range(number_of_rows): # nombre1='button_'+str(i) # contenidoi=[{"button_type": "toggle","columns": 1,"icon": "AAAAAA==","icon_file_name": "","icon_size": {"value": "icon"},"icon_system_size": {"value": "default"},"icon_system_type": {"value": "ok"},"icon_type": {"value": "none"},"name": nombre1,"rows": 1,"text": {"id": "","text": nombre,"translatable": True},"tooltip": {"id": "","text": "","translatable": True},"type": "button::pushbutton"}] # print(contenidoi) # contenido.append(contenidoi) nombre='BUTTON' contenidoi=[{"button_type": "toggle","columns": 1,"icon": "AAAAAA==","icon_file_name": "","icon_size": {"value": "icon"},"icon_system_size": {"value": "default"},"icon_system_type": {"value": "ok"},"icon_type": {"value": "none"},"name": nombre,"rows": 1,"text": {"id": "","text": nombre,"translatable": True},"tooltip": {"id": "","text": "","translatable": True},"type": "button::pushbutton"}] def blankForm(): base = [ { "columns": 1, "default_font_family": "", "default_font_size": 0, "name": "text", "rows": 1, "text": { "id": "", "text": "<html><p align=\"center\">Test</p><p style=\"-qt-paragraph-type:empty;\" align=\"center\"><br/></p><p align=\"center\"><span style=\"font-size:16pt; font-weight:600; color:#ff0000;\">ABC123</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False } ] return base def addContinuousText(): c_text = [ { "columns": 2, "default_font_family": "", "default_font_size": 0, "name": "text", "rows": 1, "text": { "id": "", "text": "<html><p align=\"center\">Example</p><p align=\"center\"><span style=\"font-size:12pt; font-weight:600; color:#ff0000;\">ABC123</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False } ] return c_text def addInput(default): input = [ { "columns": 2, "name": "input_scanner", "password": False, "read_only": False, "rows": 1, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "input::string", "value": default } ] return input def addCheckbox(description): checkbox = [ { "columns": 2, "name": "checkbox", "rows": 1, "title": { "id": "", "text": description, "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "input::checkbox", "value": False } ] return checkbox def addVerticalSpace(instance, size): v_spacer = [ { "columns": 2, "maximum_size": -1, "minimum_size": size, "name": "spacer_" + str(instance), "rows": 1, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "spacer::vertical" } ] return v_spacer def addSingleButton(instance, type): button = [ { "button_type": "push", "columns": 1, "icon": "AAAAAA==", "icon_file_name": "", "icon_size": { "value": "icon" }, "icon_system_size": { "value": "extra_large" }, "icon_system_type": { "value": type }, "icon_type": { "value": "system" }, "name": "button_" + str(instance), "rows": 1, "text": { "id": "", "text": "", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "button::pushbutton" } ] return button def addButtonList(firstButton, instance, type): buttonList = [] secondButton = [ { "button_type": "push", "columns": 1, "icon": "AAAAAA==", "icon_file_name": "", "icon_size": { "value": "icon" }, "icon_system_size": { "value": "extra_large" }, f"icon_system_type": { "value": type }, "icon_type": { "value": "system" }, "name": "button_" + str(instance), "rows": 1, "text": { "id": "", "text": "", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "button::pushbutton" } ] buttonList.append(firstButton[0]) buttonList.append(secondButton[0]) return buttonList blankForm = [] blankForm.append(addContinuousText()) blankForm.append(addInput('the default text')) blankForm.append(addCheckbox('Checkbox #1')) blankForm.append(addVerticalSpace(1, 5)) aButton = addSingleButton(1,'ok') buttonsAsRows = addButtonList(aButton, 2, 'cancel') blankForm.append(buttonsAsRows) blankForm.append(addVerticalSpace(2, 25)) blankForm.append(addSingleButton(3, 'warning')) blankForm.append(addSingleButton(4, 'arrow_right')) DIALOG=gom.script.sys.create_user_defined_dialog (dialog={ "content": blankForm, "control": { "id": "OkCancel" }, "embedding": "always_toplevel", "position": "automatic", "size": { "height": 500, "width": 500 }, "sizemode": "fixed", "style": "", "title": { "id": "", "text": "Dialog Title", "translatable": True } }) def dialog_event_handler (widget): pass DIALOG.handler = dialog_event_handler RESULT=gom.script.sys.show_user_defined_dialog (dialog=DIALOG) """ OPEN THE CODE BELOW IN THE GUI EDITOR TO SEE A GRID BASED LAYOUT. 1) PLAY AROUND WITH THE ROW AND COLUMNS THAT THE WIDGETS WILL EMCOMPASS. 2) NEXT TAKE A LOOK AT THE SEQUENCE THE WIDGETS IN THE CODE. PAY ATTENTION TO THE NUMBERS OF ROWS AND COLUMNS. IF YOU USE UNIQUE NAMES FOR EACH WIDGET, YOU CAN DETERMINE THE ORDER IN WHICH YOU NEED TO WRITE OUT YOUR WIDGETS DYNAMICALLY. """ DIALOG=gom.script.sys.create_user_defined_dialog (dialog={ "content": [ [ { "columns": 2, "default_font_family": "", "default_font_size": 0, "name": "text", "rows": 1, "text": { "id": "", "text": "<html><p align=\"center\"><span style=\"font-weight:600;\">Widget 1</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False }, { }, { "columns": 1, "default_font_family": "", "default_font_size": 0, "name": "text_1", "rows": 1, "text": { "id": "", "text": "<html><p align=\"center\"><span style=\"font-weight:600;\">Widget 2</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False } ], [ { "columns": 3, "default_font_family": "", "default_font_size": 0, "name": "text_2", "rows": 1, "text": { "id": "", "text": "<html><p align=\"center\"><span style=\"font-weight:600;\">Widget 3</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False }, { }, { } ], [ { "columns": 1, "default_font_family": "", "default_font_size": 0, "name": "text_3", "rows": 3, "text": { "id": "", "text": "<html><p align=\"center\"><span style=\"font-weight:600;\">Widget 4</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False }, { "columns": 1, "default_font_family": "", "default_font_size": 0, "name": "text_4", "rows": 1, "text": { "id": "", "text": "<html><p align=\"center\"><span style=\"font-weight:600;\">Widget 5</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False }, { "columns": 1, "default_font_family": "", "default_font_size": 0, "name": "text_6", "rows": 2, "text": { "id": "", "text": "<html><p align=\"center\"><span style=\"font-weight:600;\">Widget 6</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False } ], [ { }, { "columns": 1, "default_font_family": "", "default_font_size": 0, "name": "text_5", "rows": 2, "text": { "id": "", "text": "<html><p align=\"center\"><span style=\"font-weight:600;\">Widget 7</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False }, { } ], [ { }, { }, { "columns": 1, "default_font_family": "", "default_font_size": 0, "name": "text_7", "rows": 3, "text": { "id": "", "text": "<html><p align=\"center\"><span style=\"font-weight:600;\">Widget 8</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False } ], [ { "columns": 2, "default_font_family": "", "default_font_size": 0, "name": "text_10", "rows": 1, "text": { "id": "", "text": "<html><p align=\"center\"><span style=\"font-weight:600;\">Widget 9</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False }, { }, { } ], [ { "columns": 1, "default_font_family": "", "default_font_size": 0, "name": "text_8", "rows": 1, "text": { "id": "", "text": "<html><p align=\"center\"><span style=\"font-weight:600;\">Widget 10</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False }, { "columns": 1, "default_font_family": "", "default_font_size": 0, "name": "text_9", "rows": 1, "text": { "id": "", "text": "<html><p align=\"center\"><span style=\"font-weight:600;\">Widget 11</span></p></html>", "translatable": True }, "tooltip": { "id": "", "text": "", "translatable": True }, "type": "display::text", "wordwrap": False }, { } ] ], "control": { "id": "OkCancel" }, "embedding": "always_toplevel", "position": "automatic", "size": { "height": 545, "width": 539 }, "sizemode": "automatic", "style": "", "title": { "id": "", "text": "Dialog Title", "translatable": True } }) # # Event handler function called if anything happens inside of the dialog # def dialog_event_handler (widget): pass DIALOG.handler = dialog_event_handler RESULT=gom.script.sys.show_user_defined_dialog (dialog=DIALOG) Edited October 17, 2024 Link to comment Share on other sites More sharing options...
Recommended Posts
Please sign in to comment
You will be able to leave a comment after signing in