Please enable JavaScript to view this site.

Gig Performer 4.x User Manual

Navigation: GPScript

How to control multiple parameters with a single widget?

Scroll Prev Top Next More

In Gig Performer, you can control multiple plugin parameters simultaneously:

- using widget groups,
- by assigning the same MIDI control to multiple widgets,
- using GPScript to control any number of parameters with a single widget.
 
In this chapter, we'll focus on a simple script that will allow you to control multiple parameters with a single widget.

Start Gig Performer and create a new empty gig. First, click on the Wiring view and create a simple layout. In this example, besides built-in plugins we are using two plugins - Nick Crow 8505 and OrilRiver:

GPScript-Wiring-View

Refer to this blog article for more information on how to get these plugins, insert them and connect them.

Let's say that you want to control two parameters with a single widget: one parameter from the NickCrow plugin and the second parameter from the OrilRiver plugin. To use a plugin in scripting, you need to define a GPScript handle for it. Right click on the NickCrow plugin to open its contextual menu, then expand OSC/GPScript Handle and select Set Handle... :

GPScript-Set-Handle

Type in a GPScript handle name (i.e. Nick) and check the Use in GPScript check box. Repeat the same steps for the OrilRiver plugin and set a handle name (i.e. Oril) and check the Use in GPScript check box. Now your layout looks like this:

GPScript-Wiring-View-handles-set

The next step is to insert a widget and assign it a GPScript name so you can use it in scripting. Open the Panels View in Edit mode and insert the Plastic Blue Knob onto the panel (refer to this chapter for more information):

Widget-GPScript-name

In the Widget Properties inspector, click on the Advanced tab and enter a GPScript name for this widget (i.e. Knob1).

The last information you need is a parameter number that you want to control with this widget. Click on the Wiring View and double-click on the Nick Crow plugin to open its plugin editor:

Plugin1-identify-parameter

Move the desired control (i.e. the Gain knob) and you'll immediately see its parameter number (indicated with the red arrow). Repeat the same steps for the OrilRiver plugin and note the parameter number of e.g. the Room Size knob (indicated with the red arrow):

Plugin2-identify-parameter

 

Click on the Window menu and select the Show Rackspace Script Editor menu item and insert this code:

Var

   Knob1 : Widget

   Nick, Oril : PluginBlock;

 

On WidgetValueChanged(newValue : double) from Knob1

    

   SetParameter(Nick, 0, newValue)

   SetParameter(Oril, 6, newValue)

   

    

End

 

Now click on the Compile button:

Rackspace-Script

If your script contains no errors, you'll receive a note that compilation is successful.

Open the Panels View and move the widget; you'll notice how the chosen parameters change accordingly:

gpscript-widget-parameters

 
Let's take a look at the code.

In the Var section you simply declare your variables based on the GPScript names you had previously given to them and specify their type (i.e. Knob1 : Widget or Nick, Oril : PluginBlock). If you want to control more parameters from different plugins, simply give those plugins the corresponding GPScript names and declare them in the Var section.

GPScript language is event-driven. The next section "On WidgetValueChanged(newValue : double) from Knob1" tells the compiler what event to monitor and on which widget. The newValue parameter is updated with the new value every time you move the knob (i.e. the widget value changes). Any function in GPScript that run when a certain event occurs is called a callback (another example is On Activate which runs when a rackspace activates).

The section of code inside the callback simply tells the compiler what to do when the event is detected; in this example we want to set the parameter in the plugin with the name "nick" and on the parameter number "0", with the value "newValue" (the current value of the knob widget).
 
This is a very basic demonstration of GPScript which provides you with the virtually unlimited flexibility to create sophisticated setups for your live performance.

If you are interested in learning more, join our Community to see how users incorporate GPScript into their setups.