Feedbacks and Actions

So far, we have been using the included Template Behaviors to define how a component interacts with a parameter.

When we want to customize individual parts of a behavior or even create one from scratch (without selecting a Template Behavior), we need to understand Feedback Handlers and Actions (formerly known as Event Handlers).

Feedback Handlers

Feedback Handlers are the parts of the Behavior that define what a component shows. They can adjust things like LED color, display text and elements, and even the position of a motorized fader.

Every Behavior and Layer has a Default Feedback, which is shown automatically. Additionally, there are Conditional Feedbacks, which are only active when their Active-If condition returns true.

Let’s take a look at the available fields in a Feedback Handler:

There are several groups of fields:

General Feedback Fields

Description

Give your Feedback Handler a readable description. This will be shown in the header and can make your behavior easier to understand.

Intensity

Intensity defines the strength of the LED light. It can be Off, Dimmed, or On.

Color

Set the LED Color. You can select one from the color picker or even use a parameter to define the color of a component.
NOTE: You will not see a color show up if Intensity is OFF.

Text Display

Title

The title appears on top of the display.

Title Font

Select a font variation for the title.

Solid Title Bar

Select whether the Title Bar should have a solid white background or be transparent. In SKAARHOJ default configs, a transparent title bar is often used to indicate that a button "Sets" the value written on it, while displays with a solid header bar usually show the current state of a value.

**With** Solid Header Bar
**Without** Solid Header Bar

Textline 1 & Textline 2

Specify the main text for the component. You can add dynamic values with parameters into the text using the helper window or braces {}.

Textline Helper Window

Text Size

Select a specific text size. This value corresponds to the font width and height as a comma-separated pair: 0,0 = Auto, 1,1 = smallest, 3,3 = largest, 1,2 = Tall and narrow, etc.

AutoWrap

AutoWrap will automatically break the contents of Textline 1 to Textline 2 if the text exceeds the available display space.

Use Graphics for Unicode

By default, our displays do not support unicode characters. When turning on this option, text that contains unicode will automatically be rendered into an image, allowing the displays to fully support unicode.

Note: This may sometimes slightly change the rendering, or modify text size and font.

Icons

Icons

Set a condition for when to show the lock icon.

State Icon NoAccess

Set a condition for when to show the no access (forbidden sign).

State Icon Fine

Set a condition for when to show the fine icon, generally used to indicate when coarse mode is active.

Modifier Icon

Select one of several modifier icons to use. Modifier Icons are usually used to indicate what type of interaction is possible.

Tip: If you need these to be shown based on a condition, you will need to use several conditional feedback handlers.

Advanced Feedback Fields

Don't Inherit

Turning on this option will ensure no parameters are inherited from the Template Behavior for this entire Feedback. Read more about inheritance here: Behavior Inheritance.


Actions

Actions are the parts of the Behavior that define what the component does when it is interacted with in various ways. Multiple Actions can be added to each behavior to enable different types of interactions or control different parameters.

Actions can also have an Active-If condition, but unlike Conditional Feedbacks, Actions are always active by default.

General Action Settings

Let's take a look at the available fields in an Action:

Handler Type

The Handler Type is a special field that determines the other available fields for configuration.

An Action can have one main type of trigger it interacts with. The trigger types are (as described earlier in Hardware Components): Binary, Pulsed, Analog, and Speed.

  • A Binary Component can create ActDown and ActUp triggers.
  • A Pulsed Component can create Pulsed Value triggers, like +1 and -1.
  • An Analog Component can create Analog Value triggers from 0 to 1000.
  • A Speed Component can create Speed Value triggers from -500 to +500, resetting to 0 when released.

After selecting the Handler Type, you can still add PreProcessors to the Action, which define how to respond when a different trigger type is received.

General Action Fields

Parameter

Each Action can specify a different parameter to control. If no parameter is specified, the one defined at the top of the behavior form will be used.

Active If Condition

Each Action can have a condition. If the condition is false, the Action remains disabled and is not used.

Example: This can be used to specify different Actions based on the value of a variable.

Invert Condition

Specifies a condition that (if true) inverts the normal direction for control. If you would like to always invert it, simply select true.

Description

Provide a general description for the Action.

Specific Settings: Binary

Binary Type

Specify whether this handler reacts only on a down press (ActDown) or only on release (ActUp). If not set, it will fire in both cases.

Edge Filter

When mapped to a Four-Way button or encoder, use this setting to filter for a specific event, like pressing only up.

Set Mode

This allows you to specify how a press of the component will change the parameter. The following options are available:

  • Set
    Set a specific value (specified using set values, see below).

  • Cycle Up
    Cycle up through the available options.

  • Cycle Down
    Cycle down through the available options.

  • Cycle Up and Roll Over
    Cycle up through the available options and continue at the start when going over the maximum.

  • Cycle Down and Roll Over
    Cycle down through the available options and continue at the maximum when going below the start.

  • Random
    Set a completely random value out of the possible ones that is not the same as the current value.

  • Sequence
    Sequence allows you to set several values in sequence, even for different parameters. You can specify a different parameter at each step. Choose sequence and add several steps.

    Binary Sequence Example
  • Array-specific options for Variables:

    See Chapter Variables.

Set Values

Specify the list of values that this Action selects from. This defaults to using all options from the main parameter of the behavior (:All modifier).

Specific Settings - Pulsed

Rollover Condition

Specify a condition in which Rollover is allowed. Rollover means that when the end of the value range is reached, the next step jumps to the other end of the range.

Fine Step

Specify the fine step size for stepping through the parameter. You can either use the default for the behavior’s parameter (Behavior:IOReference:FineSteps) or specify your own.
For example: Select Literal Values -> then type 0.01 in the field.

The fine step size is used by default unless the CoarseCondition is true (see below).

Coarse Step

Specify the coarse step size for stepping through the parameter. You can either use the default for the behavior’s parameter (Behavior:IOReference:CoarseSteps) or specify your own.
For example: Select Literal Values -> then type 10 in the field.

The coarse step size is used when the CoarseCondition is true (see below). In Reactor built-in behaviors like Change by step for long ranges, this is used when pressing down an encoder.

Coarse Condition

Selects between using fine steps (when false) or coarse steps (when true).

In Reactor built-in behaviors like Change by step for long ranges, this is used when pressing down an encoder.

Ganged Control Mode

When set to "Relative", and the component controls multiple parameters at once, they will all be stepped relative to their own values.

Otherwise, only the first value will be stepped, and all other values will be set to the destination value of the first.

Specific Settings - Analog

Discontinuity

Discontinuity specifies what happens if the parameter being controlled has a different value than the current setting of the analog component. It defines the takeover strategy.

For example: If Iris is mapped to a RCP Joystick but has been changed on the camera in the meantime.

  • Double Linear: Double linear will map the value linearly from the current value towards each end of the value range. The rate of change (slope) may be different in each direction depending on the actual position of the analog component.

  • Offset: Offset will change the value from the current value towards the ends using the same and original rate of change. This means it may not entirely reach the end value as the analog component hits its end stop or it may reach the end value earlier than when the analog component hits its end position.

  • CatchUp: In this mode, the value won't change until the analog component is moved to the position that represents the current parameter value. At that instant, the analog component will linearly map its position to the value range of the parameter.

  • None: The value will jump to the correct mapped value when the component is moved.

Some information on this feature can be found in this YouTube video:

Note: This is not recommended to be used with MultiBehaviors.

Specific Settings - Speed

Speed handlers currently don't have configuration options exposed in the UI.

Advanced Action Fields

Event Preprocessor

Event preprocessors allow all kinds of advanced modifications, like hold down, repeat, and other tricks. See the advanced chapter on Event Preprocessors for more details.

Don't Inherit

Turning on this option will ensure no parameters are inherited from the Template Behavior for this entire Feedback. Read more about inheritance here: Behavior Inheritance.

Inheritance of Feedback and Event Handlers from Template Behaviors

When adding Feedback Handlers to a behavior that uses a Template Behavior, they will be combined with those from the template. Feedback Handlers defined in the template are marked as Inherited.

Feedback Handlers with the same index number in both the template and the behavior will be merged (overridden). The same applies to Actions with the same name.

In the example above, after modifying the Feedback Handler with index 10 (changing the color), the fields inherited from the Template Behavior's Feedback Handler with index 10 are still visible.