![]() |
The Harmony Application object.
The top level object, representing the currently running instance of Harmony and provides access to the loaded project and its contents.
Public Member Functions | |
void | process_one_event () |
Processes the next event in the application's event queue. More... | |
void | log (const QString &log) const |
Write to the application's Message Log; defaults to a trace_level log. More... | |
void | log (const QString &log, const QString &level) const |
Write to the application's Message Log with different levels as an option. More... | |
void | trace (const QString &log) const |
Write to the application's Message Log as trace output. | |
void | debug (const QString &log) const |
Write to the application's Message Log as debug output. | |
void | error (const QString &log) const |
Write to the application's Message Log as error output. | |
void | thread_lock () |
Locks the application to allow for a thread to process commands. More... | |
void | thread_unlock () |
Unlocks the application after a thread has processed commands. More... | |
void | run_function (PyFunction function) |
Runs the provided function while locking and unlocking the application as needed. More... | |
void | run_on_main (PyFunction function, bool blocking) |
Runs the provided method on the main thread. More... | |
Public Attributes | |
OMH::HarmonyProject * | project |
Get the active project from the instance of Harmony. More... | |
OMC::About * | about |
Get the active about details from the instance of Harmony. More... | |
OMC::Preferences * | preferences |
Get the active preferences from the instance of Harmony. More... | |
OMC::Actions * | actions |
Get the application's action interface. More... | |
OMC::ViewList * | views |
Get the application's available views. | |
OMC::ToolList * | tools |
Get the application's available tools - not yet available. More... | |
OMC::InterfaceManager * | interfaces |
Get the DOM interface manager - not yet available. More... | |
bool | notify_enabled |
Get/set whether application notifications are enabled. More... | |
OMC::DrawingAccess * | drawing_access |
Get the drawing access, used to modify drawings. | |
OMC::Javascript * | javascript |
Get the Javascript interface, used for interacting with Javascript scripts. | |
|
inherited |
Write to the application's Message Log; defaults to a trace_level log.
|
inherited |
Write to the application's Message Log with different levels as an option.
The Message Log supports three levels of output, which can be specified in this function.
Available log levels include:
|
inherited |
Processes the next event in the application's event queue.
In the event that the script requires updates in the GUI, process_one_event() will ublock the application from the current script and run the next event in the application queue.
|
inherited |
Runs the provided function while locking and unlocking the application as needed.
Similar to lock() and unlock(), this will run the provided function and lock and unlock the application as necessary.
|
inherited |
Runs the provided method on the main thread.
Only available in the internal Python Console
Using run_on_main will send the function-call to the main thread and it is run there safely. The external thread locks until the main thread has finished.
Note– this requires that the main thread be available to run the function at some point; the call will time out if is does not become available in a timely manner.
|
inherited |
Locks the application to allow for a thread to process commands.
When running in threads – accessing Harmony objects without a thread lock will result in an error. Instead, get the application's lock in the external thread, and release it when complete to regain activity in the main application thread afterwards.
|
inherited |
Unlocks the application after a thread has processed commands.
See thread_lock() for more information.
OMH::HarmonyApplication::about |
Get the active about details from the instance of Harmony.
The About class provides general information about the current Harmony session. This includes environment information, and general application information,
OMH::HarmonyApplication::actions |
Get the application's action interface.
The application's action interface is used to perform underlying actions within the GUI in the application. Generally, actions are only available internally within the GUI. This interface can also be used to list available actions that can be performed.
In the event that a scripted solution is not available through the DOM, an action may be available. It is worth noting that actions can require user input and subsequent application event callbacks, some of which are not supported in a scripted environment.
OMH::HarmonyApplication::interfaces |
Get the DOM interface manager - not yet available.
Not yet available.
|
readwrite |
Get/set whether application notifications are enabled.
Most actions in Harmony result in events that update the GUI and refresh the contents in the scene. Setting the notify_enabled to false will prevent these intermediate updates, and will often allow scripts to run faster. Once a script has completed, it is important that this be reenabled in order for the GUI to appropriately update with all expected changes.
OMH::HarmonyApplication::preferences |
Get the active preferences from the instance of Harmony.
The preference handler for the application provides read and write access to the current application preferences. This is useful for storing and modifying tool preferences.
OMH::HarmonyApplication::project |
Get the active project from the instance of Harmony.
The project provides access to properties of the project, and objects contained within the project (such as scenes, palettes, nodes, ect).
OMH::HarmonyApplication::tools |
Get the application's available tools - not yet available.
Not yet available.