Skip to content
Ashley Muncaster edited this page Sep 1, 2024 · 11 revisions

A preset is a configuration of a component type with a set of properties or parameters. They are useful for defining common visual setup for components without having to define them over and over again in the components themselves.

Creating a Preset Asset

To create a preset asset, either go to AssetsCreateHackboxPreset, or right-click in the assets window, and go to CreateHackboxPreset, and then name the preset appropriately:

image

You can then edit the properties of the preset by selecting it in the assets and viewing the properties in the Inspector:

image

Type

There are several different preset/component types to choose from, each exhibiting different visual behaviour. The types available are:

  • Text, basic text display
  • Text Input, text input
  • Buzzer, simple buzzer button
  • Button, button
  • Choices, set of button options
  • Range, number/slider input
  • Sort, like Choices but is used to put the choice options into an order

Specify the type for the preset by editing it in the Inspector. More information about each type is available here.

Parameter List

There are many parameters you can adjust on a preset to give them a specific appearance and behaviour, such as color, background, text, event, value, etc.

To add parameters to a preset in the Inspector:

  • Select the parameter to add in the dropdown then hit the + button to insert it into the parameter list box

image

  • Edit the parameter properties that appear in the parameter list box

image

Creating a Preset in code

To create a preset in code:

Hackbox.UI.Preset preset = Hackbox.UI.Preset.Create("myPreset", Hackbox.UI.Preset.PresetType.Text);
preset.Add("color", Color.white);
preset.Add("background", "#000000");
preset.Add("text", "Hello world!");

Using a Preset

To use a preset, you should specify it as the preset on a UIComponent entry within a State object. This can be done either by:

  • Setting the preset property in the Inspector:

image

  • Setting Preset in code:
Hackbox.State someState;
Hackbox.UI.UIComponent component = someState["someComponent"];
component.Preset = myPreset;

Parameters

Go to the Parameters Reference page to learn more about each parameter and how it controls the appearance or behaviour of the preset/component.

Clone this wiki locally