Class: UI::HtmlDialog
- Inherits:
-
Object
- Object
- UI::HtmlDialog
- Defined in:
- lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb
Overview
The Ruby HtmlDialog class allows you to create and interact with HTML dialog boxes from Ruby. This is the best way to generate complex, embedded UIs inside SketchUp, but it does generally require HTML and JavaScript expertise.
If your goal is to simple display a website to your users, consider using #openURL, which will show them a web page in their default browser rather than inside a dialog in SketchUp.
The left, top, width, height etc. dimensions of the dialog are in logical units. This means you provide the units as if they where on a monitor with “normal” DPI. The units given will be multiplied by the same factor as returned by scale_factor.
Constant Summary collapse
- STYLE_DIALOG =
Constants
nil
- STYLE_UTILITY =
Stub value.
nil
- STYLE_WINDOW =
Stub value.
nil
Instance Method Summary collapse
-
#add_action_callback(callback_name) {|action_context, ...| ... } ⇒ Boolean
The #add_action_callback method establishes a Ruby callback method that your html dialog can call to perform some function.
-
#bring_to_front ⇒ nil
The #bring_to_front method is used to bring the window to the front, putting it on top of other windows even if its minimized.
-
#center ⇒ true
The #center method is used to center the HtmlDialog relative to the active model window.
-
#close ⇒ nil
The #close method is used to close a dialog box.
-
#execute_script(script) ⇒ nil
The #execute_script method is used to execute a JavaScript string on the html dialog asynchronously.
-
#initialize(properties) ⇒ HtmlDialog
constructor
The new method is used to create a new HtmlDialog.
-
#set_can_close ⇒ Boolean
The #set_can_close method is used to attach a block that is executed just before closing, this block has to return a boolean, if the block returns false the close will be canceled.
-
#set_file(filename) ⇒ nil
The #set_file method is used to identify a local HTML file to display in the HtmlDialog.
-
#set_html(html_string) ⇒ nil
The #set_html method is used to load a HtmlDialog with a string of provided HTML.
-
#set_on_closed ⇒ Boolean
The #set_on_closed method is used to attach a block that will be executed when a dialog is already in the process of closing, do any last minute operations within this block such as saving the current state.
-
#set_position(left, top) ⇒ true
The #set_position method is used to set the position of the HtmlDialog relative to the screen, in pixels.
-
#set_size(width, height) ⇒ true
The #set_size method is used to set the size of the HtmlDialog, in pixels.
-
#set_url(url) ⇒ nil
The #set_url method is used to load a HtmlDialog with the content at a specific URL.
-
#show ⇒ nil
The #show method is used to display a non-modal dialog box.
-
#show_modal ⇒ nil
The #show_modal method is used to display a modal dialog box.
-
#visible? ⇒ Boolean
The #visible? method is useful to tell if the dialog is shown and still alive, if the dialog is minimized or not visible on the screen this will still return
true
.
Constructor Details
#initialize(properties) ⇒ HtmlDialog
Prior to SketchUp 2019 the :width
and :height
provided is ignored if a :preference_key
is also present. To work around this bug on older versions use #set_size after you initialize the dialog.
The new method is used to create a new HtmlDialog.
The properties
hash accepts an optional key style
where the value is one of:
UI::HtmlDialog::STYLE_DIALOG
-
HtmlDialog stays at the top of SketchUp.
UI::HtmlDialog::STYLE_WINDOW
-
HtmlDialog can go behind SketchUp and doesn’t disappear when SketchUp looses focus.
UI::HtmlDialog::STYLE_UTILITY
-
HtmlDialog is shown with small titlebar and stays on top of SketchUp.
201 202 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 201 def initialize(properties) end |
Instance Method Details
#add_action_callback(callback_name) {|action_context, ...| ... } ⇒ Boolean
When an HtmlDialog is closed, all callbacks to that instance are cleared. Re-attach them if you need to open the dialog again.
The #add_action_callback method establishes a Ruby callback method that your html dialog can call to perform some function.
Use the sketchup.callback_method_name
to invoke the callback method from your html dialog. Your JavaScript in the html dialog will invoke the callback with the same number of arguments.
The call is asynchronous. JavaScript call might return before Ruby callback even called. Use onCompleted
callback to get notified for completion.
Basic types such as booleans, numbers, strings, arrays and hashes are automatically converted between Ruby and JavaScript.
75 76 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 75 def add_action_callback(callback_name) end |
#bring_to_front ⇒ nil
The #bring_to_front method is used to bring the window to the front, putting it on top of other windows even if its minimized.
87 88 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 87 def bring_to_front end |
#center ⇒ true
The #center method is used to center the HtmlDialog relative to the active model window. If there is no active model window, this function doesn’t do anything.
100 101 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 100 def center end |
#close ⇒ nil
The #close method is used to close a dialog box.
111 112 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 111 def close end |
#execute_script(script) ⇒ nil
The #execute_script method is used to execute a JavaScript string on the html dialog asynchronously.
127 128 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 127 def execute_script(script) end |
#set_can_close ⇒ Boolean
The #set_can_close method is used to attach a block that is executed just before closing, this block has to return a boolean, if the block returns false the close will be canceled.
217 218 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 217 def set_can_close end |
#set_file(filename) ⇒ nil
The #set_file method is used to identify a local HTML file to display in the HtmlDialog.
232 233 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 232 def set_file(filename) end |
#set_html(html_string) ⇒ nil
The #set_html method is used to load a HtmlDialog with a string of provided HTML.
249 250 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 249 def set_html(html_string) end |
#set_on_closed ⇒ Boolean
The #set_on_closed method is used to attach a block that will be executed when a dialog is already in the process of closing, do any last minute operations within this block such as saving the current state.
262 263 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 262 def set_on_closed end |
#set_position(left, top) ⇒ true
The #set_position method is used to set the position of the HtmlDialog relative to the screen, in pixels.
280 281 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 280 def set_position(left, top) end |
#set_size(width, height) ⇒ true
The #set_size method is used to set the size of the HtmlDialog, in pixels.
297 298 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 297 def set_size(width, height) end |
#set_url(url) ⇒ nil
The #set_url method is used to load a HtmlDialog with the content at a specific URL. This method allows you to load web sites in a HtmlDialog.
312 313 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 312 def set_url(url) end |
#show ⇒ nil
The #show method is used to display a non-modal dialog box.
323 324 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 323 def show end |
#show_modal ⇒ nil
The #show_modal method is used to display a modal dialog box.
334 335 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 334 def show_modal end |
#visible? ⇒ Boolean
The #visible? method is useful to tell if the dialog is shown and still alive, if the dialog is minimized or not visible on the screen this will still return true
.
353 354 |
# File 'lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb', line 353 def visible? end |