Class: SimIFrameClient

SimIFrameClient(frame)

new SimIFrameClient(frame)

This SimIFrameClient communicates to one and only one iframe. Dispose it when you are done with it. There is not any support for having two SimIFrameClients connect to the same sim iframe. Available in the main PhET-iO js import.
Parameters:
Name Type Description
frame Object an HTML element representing the iframe with the simulation.

Members

(static, constant) CAMEL_CASE_SIMULATION_NAME :string

The name of the simulation in lowercase camelCasing
Type:
  • string

(static, constant) PHET_IO_LIB_ABSOLUTE_PATH :string

The path where the lib file has been deployed
Type:
  • string

(static, constant) SIMULATION_NAME :string

The hyphenated name of the simulation
Type:
  • string

(static, constant) SIMULATION_VERSION :string

The version of the simulation
Type:
  • string

Methods

(static) appendQueryString(url, queryParameters) → {string}

Appends a query string to a given url.
Parameters:
Name Type Description
url may or may not already have other query parameters
queryParameters may start with '', '?' or '&'
Returns:
Type
string

(static) appendQueryStringArray(url, queryStringArray) → {string}

Helper function for multiple query strings
Parameters:
Name Type Description
url string may or may not already have other query parameters
queryStringArray Array.<string> each item may start with '', '?', or '&'
Returns:
Type
string

(static) getSimPhetioID(suffix) → {string}

Most PhET-iO IDs are prefixed by the simulation name. This method automatically prepends the simulation name to the phetioID.
Parameters:
Name Type Description
suffix string the tail of the phetioID
Returns:
Type
string

(static) getSimURL(config) → {string}

Gets the URL for launching the PhET-iO simulation HTML.
Parameters:
Name Type Description
config Object {boolean} debug, {string} relativePathToRoot
Returns:
Type
string

addOnErrorListener(callback) → {function}

Adds a callback when any invocation causes an error
Parameters:
Name Type Description
callback function with a single {Error} argument.
Returns:
wrapped function that can be removed with SimIFrameClient.removeMessageListener()
Type
function

dispose()

Release resources when the SimIFrameClient instance will no longer be used.

invoke(phetioID, method, argsopt, callbackopt)

Primary way to call a method on the simulation frame from the wrapper frame. Given an instance id, method name, and arguments, invoke the method async and return values then errors (in that order) in the callback.
Parameters:
Name Type Attributes Description
phetioID InvocationData.phetioID The id of the instance
method InvocationData.method The name of the phet-io method
args InvocationData.args <optional>
optional args
callback function <optional>
optional callback, parameters depend on method being invoked.

invokeSequence(sequence, callbackopt)

If you need to send multiple messages or if the order of messages matters, then use invokeSequence. callback is called when the entire sequence is complete.
Parameters:
Name Type Attributes Description
sequence Array.<InvocationData> Each "Invocation" entry in the array will be run async.
callback function <optional>
The arguments will depend on the return values of the methods invoked. The args will be all return values followed by all errors. i.e. if there are five invocations in a sequence call, each returning a single value, then there will be ten arguments in the callback. Further more if all are successful but the last, which returns an error, then there are still ten args, but (one indexed) args 5-9 will be null, and the tenth will hold an Error.

launchSim(optionsopt)

Main launch point for the simulation, send a message into the simulation to begin. Some options can be very helpful in customizing the simulation run before the launch command has been sent to the sim, see LaunchSimOptions object for more.
Parameters:
Name Type Attributes Description
options LaunchSimOptions <optional>
optional parameters to pass to the launch sequence

onPhETiOInitialized(callback)

Adds a callback when the sim frame is ready for intercommunication. This happens even before the sim is ready to launch.
Parameters:
Name Type Description
callback function

onSimInitialized(callback)

Adds a callback which is called when the sim has been initialized, when all screens have been constructed and the sim is ready to be displayed.
Parameters:
Name Type Description
callback function

setValues(map, callback)

Convenience function for setting several values. Note the order of application is not guaranteed.
Parameters:
Name Type Description
map Object
callback function