-
-
Notifications
You must be signed in to change notification settings - Fork 72
Lua Reference
Below is the full reference for all of the Lua functions that you can use in the entire game.
- Core Functions
- Utility Functions (u_)
- Audio Functions (a_)
- Main Timeline Functions (t_)
- Event Timeline Functions (e_)
- Level Functions (l_)
- Style Functions (s_)
- Wall Functions (w_)
- Custom Wall Functions (cw_)
- Custom Timeline Functions (ct_)
- Shader Functions (shdr_)
- Miscellaneous Functions
Below are the Core Functions, which are the base functions that help the game assemble the level together and make the level playable. Some of these functions are required and they must be implemented in order for your level to work, while others are completely optional and can be implemented to help assist you in completing certain tasks.
-
void onInit()
(Required): A core function that is called when the level is first selected upon in the menu. The Lua function is also ran upon every attempt to reset the configuration. Use this function to initialize all of the level settings and setup some parameters for the level, such as tracking variables and setting conditions with the menu selection (such as setting difficulty multiplier thresholds). -
void onLoad()
(Required): A core function that is called when the level begins. Use this function for basic event handling, such as timing messages and setting an end to the level withu_eventKill
. However, more advanced events should be handled with other Lua measures (or with the currently WIP "Events for 2.0" module). You can also initialize some values that couldn't be initialized withonInit
. -
void onStep()
(Required): A core function that is called every time when the level timeline is empty. This is the core function where all of your pattern/wall spawning logic should be happening, as this is the intended design of the function. When a level increment is called, this function temporarily stops running until the level increments successfully. -
void onIncrement()
(Required): A core function that is called every time the level increments. It doesn't run the moment the increment is called, as it has to wait for all of the walls to be cleared before this function can run. Use this to implement any custom incrementation logic. -
void onUnload()
: A core function that is called every time when the player exits the level or restarts the level. This is hardly ever used in pack developing, but some uses for it can be to help run certain events only on first playthrough of the level. -
void onUpdate(float mFrameTime)
(Required): A core function that is called continuously throughout the level, with the argumentmFrameTime
being a float representing the time elapsed for a single frame. This function is called 4 times every frame (assuming 60 FPS) or exactly 240 times per second regardless of the actual FPS. This function can be very useful to solve logic that would otherwise be impossible to do with other core functions, but be careful to not put too much code into this function. Putting too much code in this function (or putting faulty code) can be a contributing factor to causing lag, so be sure to use this function wisely. -
bool onInput(float mFrameTime, int mMovement, bool mFocus, bool mSwap)
: A core function that is called every frame throughout the level, with the argumentmFrameTime
being a float representing the time elapsed for a single frame. ThemMovement
argument represents the movement input provided by the player (-1
for counter-clockwise rotation,1
for clockwise rotation,0
otherwise). ThemFocus
andmSwap
boolean arguments are set totrue
if the focus or swap inputs are being held down, respectively. The return value of the function dictates whether the inputs should be used by the engine to move the player, or not. Returningtrue
will prevent the player from moving, focusing, or swapping --- regardless of the user input. Returningtrue
can be useful for levels that completely change the movement mechanics, or that restrict some certain actions. Use this function wisely --- the same considerations as peronUpdate
apply. -
void onCursorSwap()
: A core function that is called every time the player swaps. -
void onDeath()
: A core function that is called when the player dies. This function does not count invincibility deaths, and they must be actual deaths for this function to be called. -
void onPreDeath()
: Similar toonDeath
, but is also called if the player is invincible or if tutorial mode is enabled. -
void onPreUnload()
: A core function that is called right before the Lua environment is reset (beforeonUnload
). In special cases, this can be useful to influence the next attempt based on data from the last attempt. Note that level using this functions will not be compatible with the replay system, so its use is generally discouraged. -
void onRenderStage(int mRenderStage, float mFrameTime)
: Called for each render stage as part of the game's rendering routine. This function could be useful for shader manipulation, or to perform actions that do not affect gameplay but might affect graphics. Refer to theRenderStage
enumeration inutils.lua
for the values ofmRenderStage
.
Below are the utility functions, which can be identified with the "u_" prefix. These are overall functions that either help utilize the game engine, be incredibly beneficial to pack developers, or help simplify complex calculations.
-
float u_rndReal()
: Return a random real number in the [0; 1] range. -
float u_rndIntUpper(int upper)
: Return a random integer number in the [1;upper
] range. -
float u_rndInt(int lower, int upper)
: Return a random integer number in the [lower
;upper
] range. -
float u_rndSwitch(int mode, int lower, int upper)
: Internal replacement formath.random
. Callsu_rndReal()
withmode == 0
,u_rndIntUpper(upper)
withmode == 1
, andu_rndInt(lower, upper)
withmode == 2
. -
unsigned long long u_getAttemptRandomSeed()
: Obtain the current random seed, automatically generated at the beginning of the level.math.randomseed
is automatically initialized with the result of this function at the beginning of a level. -
bool u_inMenu()
: Returnstrue
if the script is being executed in the menu,false
otherwise. -
int u_getVersionMajor()
: Returns the major of the current version of the game -
int u_getVersionMinor()
: Returns the minor of the current version of the game -
int u_getVersionMicro()
: Returns the micro of the current version of the game -
std::string u_getVersionString()
: Returns the string representing the current version of the game -
void u_execScript(std::string scriptFilename)
: Execute the script located at<pack>/Scripts/scriptFilename
. -
void u_execDependencyScript(std::string packDisambiguator, std::string packName, std::string packAuthor, std::string scriptFilename)
: Execute the script provided by the dependee pack with disambiguatorpackDisambiguator
, namepackName
, authorpackAuthor
, located at<dependeePack>/Scripts/scriptFilename
. -
unsigned int u_getWidth()
: Return the width of the game window in pixels. -
unsigned int u_getHeight()
: Return the height of the game window in pixels. -
void u_setFlashEffect(float value)
: Flash the screen withvalue
intensity (from 0 to 255). -
void u_setFlashColor(int r, int g, int b)
: Set the color of the flash effect to{r, g, b}
. -
void u_log(std::string message)
: Print outmessage
to the console. -
bool u_isKeyPressed(int keyCode)
: Returntrue
if the keyboard key with codekeyCode
is being pressed,false
otherwise. The key code must match the definition of the SFMLsf::Keyboard::Key
enumeration. **This function is deprecated and will be removed in a future version. -
void u_haltTime(double duration)
: Pause the game timer forduration
seconds. -
void u_clearWalls()
: Remove all existing walls. -
float u_getPlayerAngle()
: Return the current angle of the player, in radians. -
void u_setPlayerAngle(float angle)
: Set the current angle of the player toangle
, in radians. -
bool u_isMouseButtonPressed(int buttonCode)
: Returntrue
if the mouse button with codebuttonCode
is being pressed,false
otherwise. The button code must match the definition of the SFMLsf::Mouse::Button
enumeration. **This function is deprecated and will be removed in a future version. -
bool u_isFastSpinning()
: Returntrue
if the camera is currently "fast spinning",false
otherwise. -
void u_forceIncrement()
: Immediately force a difficulty increment, regardless of the chosen automatic increment parameters. -
float u_getDifficultyMult()
: Return the current difficulty multiplier. -
float u_getSpeedMultDM()
: Return the current speed multiplier, adjusted for the chosen difficulty multiplier. -
float u_getDelayMultDM()
: Return the current delay multiplier, adjusted for the chosen difficulty multiplier. -
void u_swapPlayer(bool playSound)
: Force-swaps (180 degrees) the player when invoked. IfplaySound
istrue
, the swap sound will be played. -
void u_kill()
: Add to the main timeline: kill the player. This function is deprecated and will be removed in a future version. Please use t_kill instead! -
void u_eventKill()
: Add to the event timeline: kill the player. This function is deprecated and will be removed in a future version. Please use e_kill instead! -
void u_playSound(std::string soundId)
: Play the sound with idsoundId
. The id must be registered inassets.json
, under"soundBuffers"
. This function is deprecated and will be removed in a future version. Please use a_playSound instead! -
void u_playPackSound(std::string fileName)
: Dives into theSounds
folder of the current level pack and plays the specified filefileName
. This function is deprecated and will be removed in a future version. Please use a_playPackSound instead!
Below are the audio functions, which can be identified with the "a_" prefix. This library is capable of controlling everything audio with the game, including the level music and sounds. Set the music, play a specific sound, all of this is in the domain of this prefix.
-
void a_setMusic(std::string musicId)
: Stop the current music and play the music with idmusicId
. The id is defined in the music.json
file, under"id"
. -
void a_setMusicSegment(std::string musicId, int segment)
: Stop the current music and play the music with idmusicId
, starting at segmentsegment
. Segments are defined in the music.json
file, under"segments"
. Segments index from 0. -
void a_setMusicSeconds(std::string musicId, float time)
: Stop the current music and play the music with idmusicId
, starting at timetime
(in seconds). -
void a_playSound(std::string soundId)
: Play the sound with idsoundId
. The id must be registered inassets.json
, under"soundBuffers"
. -
void a_playPackSound(std::string fileName)
: Dives into theSounds
folder of the current level pack and plays the specified filefileName
. -
void a_syncMusicToDM(bool value)
: This function, when called, overrides the user's preference of adjusting the music's pitch to the difficulty multiplier. Useful for levels that rely on the music to time events. -
void a_setMusicPitch(float pitch)
: Manually adjusts the pitch of the music by multiplying it bypitch
. The amount the pitch shifts may change on DM multiplication and user's preference of the music pitch. Negative values will not work! -
void a_overrideBeepSound(std::string fileName)
: Dives into theSounds
folder of the current level pack and sets the specified filefileName
to be the new beep sound. This only applies to the particular level where this function is called. -
void a_overrideIncrementSound(std::string fileName)
: Dives into theSounds
folder of the current level pack and sets the specified filefileName
to be the new increment sound. This only applies to the particular level where this function is called. -
void a_overrideSwapSound(std::string fileName)
: Dives into theSounds
folder of the current level pack and sets the specified filefileName
to be the new swap sound. This only applies to the particular level where this function is called. -
void a_overrideDeathSound(std::string fileName)
: Dives into theSounds
folder of the current level pack and sets the specified filefileName
to be the new death sound. This only applies to the particular level where this function is called.
Below are the main timeline functions, which can be identified with the "t_" prefix. These are functions that have effects on the main timeline itself, but they mainly consist of waiting functions. Using these functions helps time out your patterns and space them in the first place.
-
void t_eval(std::string code)
: Add to the main timeline: evaluate the Lua code specified incode
. -
void t_clear()
: Clear the main timeline. -
void t_kill()
: Add to the main timeline: kill the player. -
void t_wait(double duration)
: Add to the main timeline: wait forduration
frames (under the assumption of a 60 FPS frame rate). -
void t_waitS(double duration)
: Add to the main timeline: wait forduration
seconds. -
void t_waitUntilS(double duration)
: Add to the main timeline: wait until the timer reachesduration
seconds.
Below are the event timeline functions, which can be identified with the "e_" prefix. These are functions that are similar to the Main Timeline functions, but they instead are for the event timeline as opposed to the main timeline. Use these functions to help set up basic events for the game, such as handling messages. Use e_eval
to do more advanced events.
-
void e_eval(std::string code)
: Add to the event timeline: evaluate the Lua code specified incode
. (This is the closest you'll get to 1.92 events) -
void e_kill()
: Add to the event timeline: kill the player. -
void e_stopTime(double duration)
: Add to the event timeline: pause the game timer forduration
frames (under the assumption of a 60 FPS frame rate). -
void e_stopTimeS(double duration)
: Add to the event timeline: pause the game timer forduration
seconds. -
void e_wait(double duration)
: Add to the event timeline: wait forduration
frames (under the assumption of a 60 FPS frame rate). -
void e_waitS(double duration)
: Add to the event timeline: wait forduration
seconds. -
void e_waitUntilS(double duration)
: Add to the event timeline: wait until the timer reachesduration
seconds. -
void e_messageAdd(std::string message, double duration)
: Add to the event timeline: print a message with textmessage
forduration
seconds. The message will only be printed during the first run of the level. -
void e_messageAddImportant(std::string message, double duration)
: Add to the event timeline: print a message with textmessage
forduration
seconds. The message will be printed during every run of the level. -
void e_messageAddImportantSilent(std::string message, double duration)
: Add to the event timeline: print a message with textmessage
forduration
seconds. The message will only be printed during every run of the level, and will not produce any sound. -
void e_clearMessages()
: Remove all previously scheduled messages. -
void e_eventStopTime(double duration)
: Add to the event timeline: pause the game timer forduration
frames (under the assumption of a 60 FPS frame rate). This function is deprecated and will be removed in a future version. Please use e_stopTime instead! -
void e_eventStopTimeS(double duration)
: Add to the event timeline: pause the game timer forduration
seconds. This function is deprecated and will be removed in a future version. Please use e_stopTimeS instead! -
void e_eventWait(double duration)
: Add to the event timeline: wait forduration
frames (under the assumption of a 60 FPS frame rate). This function is deprecated and will be removed in a future version. Please use e_wait instead! -
void e_eventWaitS(double duration)
: Add to the event timeline: wait forduration
seconds. This function is deprecated and will be removed in a future version. Please use e_waitS instead! -
void e_eventWaitUntilS(double duration)
: Add to the event timeline: wait until the timer reachesduration
seconds. This function is deprecated and will be removed in a future version. Please use e_waitUntilS instead!
Below are the level functions, which can be identified with the "l_" prefix. These are functions that have a role in altering the level mechanics themselves, including all level properties and attributes. These typically get called en masse in onInit
to initialize properties.
-
float l_getSpeedMult()
: Gets the speed multiplier of the level. The speed multiplier is the current speed of the walls. Is incremented bySpeedInc
every increment and caps atspeedMax
. -
void l_setSpeedMult(float value)
: Sets the speed multiplier of the level tovalue
. Changes do not apply to all walls immediately, and changes apply as soon as the next wall is created. -
float l_getPlayerSpeedMult()
: Gets the speed multiplier of the player. -
void l_setPlayerSpeedMult(float value)
: Sets the speed multiplier of the player. -
float l_getSpeedInc()
: Gets the speed increment of the level. This is applied every level increment to the speed multiplier. Increments are additive. -
void l_setSpeedInc(float value)
: Sets the speed increment of the level tovalue
. -
float l_getSpeedMax()
: Gets the maximum speed of the level. This is the highest that speed can go; speed can not get any higher than this. -
void l_setSpeedMax(float value)
: Sets the maximum speed of the level tovalue
. Keep in mind that speed keeps going past the speed max, so setting a higher speed max may make the speed instantly increase to the max. -
float l_getRotationSpeed()
: Gets the rotation speed of the level. Is incremented byRotationSpeedInc
every increment and caps atRotationSpeedMax
. -
void l_setRotationSpeed(float value)
: Sets the rotation speed of the level tovalue
. Changes apply immediately. -
float l_getRotationSpeedInc()
: Gets the rotation speed increment of the level. This is applied every level increment to the rotation speed. Increments are additive. -
void l_setRotationSpeedInc(float value)
: Sets the rotation speed increment of the level tovalue
. Is effective on the next level increment. -
float l_getRotationSpeedMax()
: Gets the maximum rotation speed of the level. This is the highest that rotation speed can go; rotation speed can not get any higher than this. -
void l_setRotationSpeedMax(float value)
: Sets the maximum rotation speed of the level tovalue
. Keep in mind that rotation speed keeps going past the max, so setting a higher rotation speed max may make the rotation speed instantly increase to the max. -
float l_getDelayMult()
: Gets the delay multiplier of the level. The delay multiplier is the multiplier used to assist in spacing patterns, especially in cases of higher / lower speeds. Is incremented byDelayInc
every increment and is clamped betweenDelayMin
andDelayMax
-
void l_setDelayMult(float value)
: Sets the delay multiplier of the level tovalue
. Changes do not apply to patterns immediately, and changes apply as soon as the next pattern is spawned. -
float l_getDelayInc()
: Gets the delay increment of the level. This is applied every level increment to the delay multiplier. Increments are additive. -
void l_setDelayInc(float value)
: Sets the delay increment of the level tovalue
. -
float l_getDelayMin()
: Gets the minimum delay of the level. This is the lowest that delay can go; delay can not get any lower than this. -
void l_setDelayMin(float value)
: Sets the minimum delay of the level tovalue
. Keep in mind that delay can go below the delay min, so setting a lower delay min may make the delay instantly decrease to the minimum. -
float l_getDelayMax()
: Gets the maximum delay of the level. This is the highest that delay can go; delay can not get any higher than this. -
void l_setDelayMax(float value)
: Sets the maximum delay of the level tovalue
. Keep in mind that delay can go above the delay max, so setting a higher delay max may make the delay instantly increase to the maximum. -
float l_getFastSpin()
: Gets the fast spin of the level. The fast spin is a brief moment that starts at level incrementation where the rotation increases speed drastically to try and throw off the player a bit. This speed quickly (or slowly, depending on the value) decelerates and fades away to the updated rotation speed. -
void l_setFastSpin(float value)
: Sets the fast spin of the level tovalue
. A higher value increases intensity and duration of the fast spin. -
float l_getIncTime()
: Get the incrementation time (in seconds) of a level. This is the length of a "level" in an Open Hexagon level (It's ambiguous but hopefully you understand what that means), and when this duration is reached, the level increments. -
void l_setIncTime(float value)
: Set the incrementation time (in seconds) of a level tovalue
. -
float l_getPulseMin()
: Gets the minimum value the pulse can be. Pulse gives variety in the wall speed of the level so the wall speed doesn't feel monotone. Can also be used to help sync a level up with it's music. -
void l_setPulseMin(float value)
: Sets the minimum pulse value tovalue
. -
float l_getPulseMax()
: Gets the maximum value the pulse can be. Pulse gives variety in the wall speed of the level so the wall speed doesn't feel monotone. Can also be used to help sync a level up with it's music. -
void l_setPulseMax(float value)
: Sets the maximum pulse value tovalue
. -
float l_getPulseSpeed()
: Gets the speed the pulse goes fromPulseMin
toPulseMax
. Can also be used to help sync a level up with it's music. -
void l_setPulseSpeed(float value)
: Sets the speed the pulse goes fromPulseMin
toPulseMax
byvalue
. Can also be used to help sync a level up with it's music. -
float l_getPulseSpeedR()
: Gets the speed the pulse goes fromPulseMax
toPulseMin
. -
void l_setPulseSpeedR(float value)
: Sets the speed the pulse goes fromPulseMax
toPulseMin
byvalue
. Can also be used to help sync a level up with it's music. -
float l_getPulseDelayMax()
: Gets the delay the level has to wait before it begins another pulse cycle. -
void l_setPulseDelayMax(float value)
: Sets the delay the level has to wait before it begins another pulse cycle withvalue
. -
float l_getPulseInitialDelay()
: Gets the initial delay the level has to wait before it begins the first pulse cycle. -
void l_setPulseInitialDelay(float value)
: Sets the initial delay the level has to wait before it begins the first pulse cycle withvalue
. -
float l_getSwapCooldownMult()
: Gets the multiplier that controls the cooldown for the player's 180 degrees swap mechanic. -
void l_setSwapCooldownMult(float value)
: Sets the multiplier that controls the cooldown for the player's 180 degrees swap mechanic tovalue
. -
float l_getBeatPulseMax()
: Gets the maximum beatpulse size of the polygon in a level. This is the highest value that the polygon will "pulse" in size. Useful for syncing the level to the music. -
void l_setBeatPulseMax(float value)
: Sets the maximum beatpulse size of the polygon in a level tovalue
. Not to be confused with using this property to resize the polygon, which you should be usingRadiusMin
. -
float l_getBeatPulseDelayMax()
: Gets the delay for how fast the beatpulse pulses in frames (assuming 60 FPS logic). This paired withBeatPulseMax
will be useful to help sync a level with the music that it's playing. -
void l_setBeatPulseDelayMax(float value)
: Sets the delay for how fast the beatpulse pulses invalue
frames (assuming 60 FPS Logic). -
float l_getBeatPulseInitialDelay()
: Gets the initial delay before beatpulse begins pulsing. This is very useful to use at the very beginning of the level to assist syncing the beatpulse with the song. -
void l_setBeatPulseInitialDelay(float value)
: Sets the initial delay before beatpulse begins pulsing tovalue
. Highly discouraged to use this here. Use this in your music JSON files. -
float l_getBeatPulseSpeedMult()
: Gets how fast the polygon pulses with the beatpulse. This is very useful to help keep your level in sync with the music. -
void l_setBeatPulseSpeedMult(float value)
: Sets how fast the polygon pulses with beatpulse tovalue
. -
float l_getRadiusMin()
: Gets the minimum radius of the polygon in a level. This is used to determine the absolute size of the polygon in the level. -
void l_setRadiusMin(float value)
: Sets the minimum radius of the polygon tovalue
. Use this to set the size of the polygon in the level, notBeatPulseMax
. -
float l_getWallSkewLeft()
: Gets the Y axis offset of the top left vertex in all walls. -
void l_setWallSkewLeft(float value)
: Sets the Y axis offset of the top left vertex tovalue
in all newly generated walls. If you would like to have more individual control of the wall vertices, please use the custom walls system under the prefixcw_
. -
float l_getWallSkewRight()
: Gets the Y axis offset of the top right vertex in all walls. -
void l_setWallSkewRight(float value)
: Sets the Y axis offset of the top right vertex tovalue
in all newly generated walls. If you would like to have more individual control of the wall vertices, please use the custom walls system under the prefixcw_
. -
float l_getWallAngleLeft()
: Gets the X axis offset of the top left vertex in all walls. -
void l_setWallAngleLeft(float value)
: Sets the X axis offset of the top left vertex tovalue
in all newly generated walls. If you would like to have more individual control of the wall vertices, please use the custom walls system under the prefixcw_
. -
float l_getWallAngleRight()
: Gets the X axis offset of the top right vertex in all walls. -
void l_setWallAngleRight(float value)
: Sets the X axis offset of the top right vertex tovalue
in all newly generated walls. If you would like to have more individual control of the wall vertices, please use the custom walls system under the prefixcw_
. -
float l_getWallSpawnDistance()
: Gets the distance at which standard walls spawn. -
void l_setWallSpawnDistance(float value)
: Sets how far away the walls can spawn from the center. Higher values make walls spawn farther away, and will increase the player's wait for incoming walls. -
bool l_get3dRequired()
: Gets whether 3D must be enabled in order to have a valid score in this level. By default, this value isfalse
. -
void l_set3dRequired(bool value)
: Sets whether 3D must be enabled tovalue
to have a valid score. Only set this totrue
if your level relies on 3D effects to work as intended. -
bool l_getShadersRequired()
: Gets whether shaders must be enabled in order to have a valid score in this level. By default, this value isfalse
. -
void l_setShadersRequired(bool value)
: Sets whether shaders must be enabled tovalue
to have a valid score. Only set this totrue
if your level relies on shader effects to work as intended. -
float l_getCameraShake()
: Gets the intensity of the camera shaking in a level. -
void l_setCameraShake(float value)
: Sets the intensity of the camera shaking in a level tovalue
. This remains permanent until you either set this to 0 or the player dies. -
unsigned int l_getSides()
: Gets the current number of sides on the polygon in a level. -
void l_setSides(unsigned int value)
: Sets the current number of sides on the polygon tovalue
. This change happens immediately and previously spawned walls will not adjust to the new side count. -
unsigned int l_getSidesMax()
: Gets the maximum range that the number of sides can possibly be at random.enableRndSideChanges
must be enabled for this property to have any use. -
void l_setSidesMax(unsigned int value)
: Sets the maximum range that the number of sides can possibly be tovalue
. -
unsigned int l_getSidesMin()
: Gets the minimum range that the number of sides can possibly be at random.enableRndSideChanges
must be enabled for this property to have any use. -
void l_setSidesMin(unsigned int value)
: Sets the minimum range that the number of sides can possibly be tovalue
. -
bool l_getSwapEnabled()
: Gets whether the swap mechanic is enabled for a level. By default, this is set tofalse
. -
void l_setSwapEnabled(bool value)
: Sets the swap mechanic's availability tovalue
. -
bool l_getTutorialMode()
: Gets whether tutorial mode is enabled. In tutorial mode, players are granted invincibility from dying to walls. This mode is typically enabled whenever a pack developer needs to demonstrate a new concept to the player so that way they can easily learn the new mechanic/concept. This invincibility will not count towards invalidating a score, but it's usually not important to score on a tutorial level. By default, this is set tofalse
. -
void l_setTutorialMode(bool value)
: Sets tutorial mode tovalue
. Remember, only enable this if you need to demonstrate a new concept for players to learn, or use it as a gimmick to a level. -
bool l_getIncEnabled()
: Gets whether the level can increment or not. This is Open Hexagon's way of establishing a difficulty curve in the level and set a sense of progression throughout the level. By default, this value is set totrue
. -
void l_setIncEnabled(bool value)
: Toggles level incrementation tovalue
. Only disable this if you feel like the level can not benefit from incrementing in any way. -
bool l_getDarkenUnevenBackgroundChunk()
: Gets whether theNth
panel of a polygon withN
sides (assumingN
is odd) will be darkened to make styles look more balanced. By default, this value is set totrue
, but there can be styles where having this darkened panel can look very unpleasing. -
void l_setDarkenUnevenBackgroundChunk(bool value)
: Sets the darkened panel tovalue
. -
bool l_getManualPulseControl()
: Gets whether the pulse effect is being controlled manually via Lua or automatically by the C++ engine. -
void l_setManualPulseControl(bool value)
: Sets whether the pulse effect is being controlled manually via Lua or automatically by the C++ engine tovalue
. -
bool l_getManualBeatPulseControl()
: Gets whether the beat pulse effect is being controlled manually via Lua or automatically by the C++ engine. -
void l_setManualBeatPulseControl(bool value)
: Sets whether the beat pulse effect is being controlled manually via Lua or automatically by the C++ engine tovalue
. -
unsigned long l_getCurrentIncrements()
: Gets the current amount of times the level has incremented. Very useful for keeping track of levels. -
void l_setCurrentIncrements(unsigned long value)
: Sets the current amount of times the level has incremented tovalue
. This function is utterly pointless to use unless you are tracking this variable. -
void l_enableRndSideChanges(bool enabled)
: Toggles random side changes toenabled
, (not) allowing sides to change betweenSidesMin
andSidesMax
inclusively every level increment. -
void l_addTracked(std::string variable, std::string name)
: Add or set the variablevariable
to the list of tracked variables, with namename
. Tracked variables are displayed in game, below the game timer. NOTE: Your variable must be global for this to work. -
void l_removeTracked(std::string variable)
: Remove the variablevariable
from the list of tracked variables -
void l_clearTracked()
: Clears all tracked variables. -
double l_getLevelTime()
: Get the current game timer value, in seconds. -
void l_resetTime()
: Resets the lever time to zero, also resets increment time and pause time. -
float l_getPulse()
: Gets the current pulse value, which will vary betweenl_getPulseMin()
andl_getPulseMax()
unless manually overridden. -
void l_setPulse(float value)
: Sets the current pulse value tovalue
. -
float l_getPulseDirection()
: Gets the current pulse direction value, which will either be-1
or1
unless manually overridden. -
void l_setPulseDirection(float value)
: Sets the current pulse direction value tovalue
. Valid choices are-1
or1
. -
float l_getPulseDelay()
: Gets the current pulse delay value, which will vary between0
andl_getPulseDelayMax()
unless manually overridden. -
void l_setPulseDelay(float value)
: Sets the current pulse delay value tovalue
. -
float l_getBeatPulse()
: Gets the current beat pulse value, which will vary between0
andl_getBeatPulseMax()
unless manually overridden. -
void l_setBeatPulse(float value)
: Sets the current beat pulse value tovalue
. -
float l_getBeatPulseDelay()
: Gets the current beat pulse delay value, which will vary between0
andl_getBeatPulseDelayMax()
unless manually overridden. -
void l_setBeatPulseDelay(float value)
: Sets the current beat pulse delay value tovalue
. -
bool l_getShowPlayerTrail()
: Gets whether the current level allows player trails to be shown. -
void l_setShowPlayerTrail(bool value)
: Sets whether the current level allows player trails to be shown tovalue
. -
void l_overrideScore(std::string variable)
: Overrides the default scoring method and determines score based off the value ofvariable
. This allows for custom scoring in levels. Avoid using strings, otherwise scores won't sort properly. NOTE: Your variable must be global for this to work. -
void l_setRotation(float angle)
: Set the background camera rotation toangle
degrees. -
float l_getRotation()
: Return the background camera rotation, in degrees. -
bool l_getOfficial()
: Returntrue
if "official mode" is enabled,false
otherwise.
Below are the style functions, which can be identified with the "s_" prefix. These are functions that have a role in altering the attributes of the current style that is on the level. Style attributes, unlike level attributes, do not get initialized in Lua and rather are premade in a JSON file (but this is subject to change).
-
float s_getHueMin()
: Gets the minimum value for the hue range of a level style. The hue attribute is an important attribute that is dedicated specifically to all colors that have thedynamic
property enabled. -
void s_setHueMin(float value)
: Sets the minimum value for the hue range tovalue
. Usually you want this value at 0 to start off at completely red. -
float s_getHueMax()
: Gets the maximum value for the hue range of a level style. Only applies to all colors with thedynamic
property enabled. -
void s_setHueMax(float value)
: Sets the maximum value for the hue range tovalue
. Usually you want this value at 360 to end off at red, to hopefully loop the colors around. -
float s_getHueInc()
: Alias tos_getHueIncrement
. Done for backwards compatibility. -
void s_setHueInc(float value)
: Alias tos_setHueIncrement
. Done for backwards compatibility. -
float s_getHueIncrement()
: Gets how fast the hue increments fromHueMin
toHueMax
. The hue value is added by this value every 1/60th of a second. -
void s_setHueIncrement(float value)
: Sets how fast the hue increments fromHueMin
toHueMax
byvalue
. Be careful with high values, as this can make your style induce epileptic seizures. -
float s_getPulseMin()
: Gets the minimum range for the multiplier of thepulse
attribute in style colors. By default, this value is set to 0. -
void s_setPulseMin(float value)
: Sets the minimum range for the multiplier of thepulse
attribute tovalue
. -
float s_getPulseMax()
: Gets the maximum range for the multiplier of thepulse
attribute in style colors. By default, this value is set to 0, but ideally it should be set to 1. -
void s_setPulseMax(float value)
: Sets the maximum range for the multiplier of thepulse
attribute tovalue
. -
float s_getPulseInc()
: Alias tos_getPulseIncrement
. Done for backwards compatibility. -
void s_setPulseInc(float value)
: Alias tos_setPulseIncrement
. Done for backwards compatibility. -
float s_getPulseIncrement()
: Gets how fast the pulse increments fromPulseMin
toPulseMax
. The pulse value is added by this value every 1/60th of a second. -
void s_setPulseIncrement(float value)
: Sets how fast the pulse increments fromPulseMin
toPulseMax
byvalue
. Be careful with high values, as this can make your style induce epileptic seizures. -
bool s_getHuePingPong()
: Gets whether the hue should goStart-End-Start-End
orStart-End, Start-End
with the hue cycling. -
void s_setHuePingPong(bool value)
: Toggles ping ponging in the hue cycling (Start-End-Start-End
) withvalue
. -
float s_getMaxSwapTime()
: Gets the amount of time that has to pass (in 1/100th of a second) before the background color offset alternates. The background colors by default alternate between 0 and 1. By default, this happens every second. -
void s_setMaxSwapTime(float value)
: Sets the amount of time that has to pass (in 1/100th of a second) tovalue
before the background color alternates. -
float s_get3dDepth()
: Gets the current amount of 3D layers that are present in the style. -
void s_set3dDepth(float value)
: Sets the amount of 3D layers in a style tovalue
. -
float s_get3dSkew()
: Gets the current value of where the 3D skew is in the style. The Skew is what gives the 3D effect in the first place, showing the 3D layers and giving the illusion of 3D in the game. -
void s_set3dSkew(float value)
: Sets the 3D skew at valuevalue
. -
float s_get3dSpacing()
: Gets the spacing that is done between 3D layers. A higher number leads to more separation between layers. -
void s_set3dSpacing(float value)
: Sets the spacing between 3D layers tovalue
. -
float s_get3dDarkenMult()
: Gets the darkening multiplier applied to the 3D layers in a style. This is taken from themain
color. -
void s_set3dDarkenMult(float value)
: Sets the darkening multiplier tovalue
for the 3D layers. -
float s_get3dAlphaMult()
: Gets the alpha (transparency) multiplier applied to the 3D layers in a style. Originally references themain
color. -
void s_set3dAlphaMult(float value)
: Sets the alpha multiplier tovalue
for the 3D layers. A higher value makes the layers more transparent. -
float s_get3dAlphaFalloff()
: Gets the alpha (transparency) multiplier applied to the 3D layers consecutively in a style. Takes reference from themain
color. -
void s_set3dAlphaFalloff(float value)
: Sets the alpha multiplier tovalue
for for the 3D layers and applies them layer after layer. This property can get finnicky. -
float s_get3dPulseMax()
: Gets the highest value that the3DSkew
can go in a style. -
void s_set3dPulseMax(float value)
: Sets the highest value the3DSkew
can go tovalue
. -
float s_get3dPulseMin()
: Gets the lowest value that the3DSkew
can go in a style. -
void s_set3dPulseMin(float value)
: Sets the lowest value the3DSkew
can go tovalue
. -
float s_get3dPulseSpeed()
: Gets how fast the3DSkew
moves between3DPulseMin
and3DPulseMax
. -
void s_set3dPulseSpeed(float value)
: Sets how fast the3DSkew
moves between3DPulseMin
and3DPulseMax
byvalue
. -
float s_get3dPerspectiveMult()
: Gets the 3D perspective multiplier of the style. Works with the attribute3DSpacing
to space out layers. -
void s_set3dPerspectiveMult(float value)
: Sets the 3D perspective multiplier tovalue
. -
float s_getBGTileRadius()
: Gets the distances of how far the background panels are drawn. By default, this is a big enough value so you do not see the border. However, feel free to shrink them if you'd like. -
void s_setBGTileRadius(float value)
: Sets how far the background panels are drawn to distancevalue
. -
unsigned int s_getBGColorOffset()
: Gets the offset of the style by how much the colors shift. Usually this sits between 0 and 1, but can easily be customized. -
void s_setBGColorOffset(unsigned int value)
: Shifts the background colors to have an offset ofvalue
. -
float s_getBGRotationOffset()
: Gets the literal rotation offset of the background panels in degrees. This usually stays at 0, but can be messed with to make some stylish level styles. -
void s_setBGRotationOffset(float value)
: Sets the rotation offset of the background panels tovalue
degrees. -
void s_setCapColorMain()
: Set the color of the center polygon to match the main style color. -
void s_setCapColorMainDarkened()
: Set the color of the center polygon to match the main style color, darkened. -
void s_setCapColorByIndex(int index)
: Set the color of the center polygon to match the style color with indexindex
. -
tuple<int, int, int, int> s_getMainColor()
: Return the current main color computed by the level style. -
tuple<int, int, int, int> s_getPlayerColor()
: Return the current player color computed by the level style. -
tuple<int, int, int, int> s_getTextColor()
: Return the current text color computed by the level style. -
tuple<int, int, int, int> s_get3DOverrideColor()
: Return the current 3D override color computed by the level style. -
tuple<int, int, int, int> s_getCapColorResult()
: Return the current cap color result color computed by the level style. -
tuple<int, int, int, int> s_getColor(int index)
: Return the current color with indexindex
computed by the level style. -
void s_setStyle(std::string styleId)
: Set the currently active style to the style with idstyleId
. Styles can be defined as.json
files in the<pack>/Styles/
folder.
Below are the basic wall functions, which can be identified with the "w_" prefix. These are the functions sole responsible for wall creation in the levels. There are a variety of walls that can be made with different degrees of complexity, all of which can be used to construct your own patterns.
-
void w_wall(int side, float thickness)
: Create a new wall at sideside
, with thicknessthickness
. The speed of the wall will be calculated by using the speed multiplier, adjusted for the current difficulty multiplier. -
void w_wallAdj(int side, float thickness, float speedMult)
: Create a new wall at sideside
, with thicknessthickness
. The speed of the wall will be calculated by using the speed multiplier, adjusted for the current difficulty multiplier, and finally multiplied byspeedMult
. -
void w_wallAcc(int side, float thickness, float speedMult, float acceleration, float minSpeed, float maxSpeed)
: Create a new wall at sideside
, with thicknessthickness
. The speed of the wall will be calculated by using the speed multiplier, adjusted for the current difficulty multiplier, and finally multiplied byspeedMult
. The wall will have a speed acceleration value ofacceleration
. The minimum and maximum speed of the wall are bounded byminSpeed
andmaxSpeed
, adjusted for the current difficulty multiplier. -
void w_wallHModSpeedData(float hueModifier, int side, float thickness, float speedMult, float acceleration, float minSpeed, float maxSpeed, bool pingPong)
: Create a new wall at sideside
, with thicknessthickness
. The speed of the wall will be calculated by using the speed multiplier, adjusted for the current difficulty multiplier, and finally multiplied byspeedMult
. The wall will have a speed acceleration value ofacceleration
. The minimum and maximum speed of the wall are bounded byminSpeed
andmaxSpeed
, adjusted for the current difficulty multiplier. The hue of the wall will be adjusted byhueModifier
. IfpingPong
is enabled, the wall will accelerate back and forth between its minimum and maximum speed. -
void w_wallHModCurveData(float hueModifier, int side, float thickness, float curveSpeedMult, float curveAcceleration, float curveMinSpeed, float curveMaxSpeed, bool pingPong)
: Create a new curving wall at sideside
, with thicknessthickness
. The curving speed of the wall will be calculated by using the speed multiplier, adjusted for the current difficulty multiplier, and finally multiplied bycurveSpeedMult
. The wall will have a curving speed acceleration value ofcurveAcceleration
. The minimum and maximum curving speed of the wall are bounded bycurveMinSpeed
andcurveMaxSpeed
, adjusted for the current difficulty multiplier. The hue of the wall will be adjusted byhueModifier
. IfpingPong
is enabled, the wall will accelerate back and forth between its minimum and maximum speed.
Below are the custom wall functions, which can be identified with the "cw_" prefix. These are functions with foundations of Object-oriented programming to allow pack developers to customize individual walls and their properties and make the most out of them.
-
int cw_create()
: Create a new custom wall and return a integer handle to it. -
int cw_createDeadly()
: Create a new deadly custom wall and return a integer handle to it. -
int cw_createNoCollision()
: Create a new custom wall without collision and return a integer handle to it. -
void cw_destroy(int cwHandle)
: Destroy the custom wall represented bycwHandle
. -
void cw_setVertexPos(int cwHandle, int vertexIndex, float x, float y)
: Given the custom wall represented bycwHandle
, set the position of its vertex with indexvertexIndex
to{x, y}
. -
void cw_moveVertexPos(int cwHandle, int vertexIndex, float offsetX, float offsetY)
: Given the custom wall represented bycwHandle
, add{offsetX, offsetY}
to the position of its vertex with indexvertexIndex
. -
void cw_moveVertexPos4Same(int cwHandle, float offsetX, float offsetY)
: Given the custom wall represented bycwHandle
, add{offsetX, offsetY}
to the position of its vertex with indices0
,1
,2
, and3
. -
void cw_setVertexColor(int cwHandle, int vertexIndex, int r, int g, int b, int a)
: Given the custom wall represented bycwHandle
, set the color of its vertex with indexvertexIndex
to{r, g, b, a}
. -
void cw_setVertexPos4(int cwHandle, float x0, float y0, float x1, float y1, float x2, float y2, float x3, float y3)
: Given the custom wall represented bycwHandle
, set the position of its vertex with index0
to{x0, y0}
, index1
to{x1, y1}
, index2
to{x2, y2}
, index3
to{x3, y3}
. More efficient than invokingcw_setVertexPos
four times in a row. -
void cw_setVertexColor4(int cwHandle, int r0, int g0, int b0, int a0, int r1, int g1, int b1, int a1, int r2, int g2, int b2, int a2, int r3, int g3, int b3, int a3)
: Given the custom wall represented bycwHandle
, set the color of its vertex with index0
to{r0, g0, b0, a0}
, index1
to{r1, g1, b1, a1}
, index2
to{r2, g2, b2, a2}
, index3
to{r3, g3, b3, a3}
. More efficient than invokingcw_setVertexColor
four times in a row. -
void cw_setVertexColor4Same(int cwHandle, int r, int g, int b, int a)
: Given the custom wall represented bycwHandle
, set the color of its vertices with indiced0
,1
,2
, and3' to
{r, g, b, a}. More efficient than invoking
cw_setVertexColor` four times in a row. -
void cw_setCollision(int cwHandle, bool collision)
: Given the custom wall represented bycwHandle
, set the collision of the custom wall tocollision
. If false, the player cannot die from this wall and can move through the wall. By default, all custom walls can collide with the player. -
void cw_setDeadly(int cwHandle, bool deadly)
: Given the custom wall represented bycwHandle
, set wherever it instantly kills player on touch. This is highly recommended for custom walls that are either very small or very thin and should definitively kill the player. -
void cw_setKillingSide(int cwHandle, unsigned int side)
: Given the custom wall represented bycwHandle
, set which one of its sides should beyond any doubt cause the death of the player. Acceptable values are0
to3
. In a standard wall, side0
is the side closer to the center. This parameter is useless if the custom wall is deadly. -
bool cw_getCollision(int cwHandle)
: Given the custom wall represented bycwHandle
, get whether it can collide with player or not. -
bool cw_getDeadly(int cwHandle)
: Given the custom wall represented bycwHandle
, get whether it instantly kills the player on touch or not. -
unsigned int cw_getKillingSide(int cwHandle)
: Given the custom wall represented bycwHandle
, get which one of its sides always causes the death of the player. -
tuple<float, float> cw_getVertexPos(int cwHandle, int vertexIndex)
: Given the custom wall represented bycwHandle
, return the position of its vertex with indexvertexIndex
. -
tuple<float, float, float, float, float, float, float, float> cw_getVertexPos4(int cwHandle)
: Given the custom wall represented bycwHandle
, return the position of its vertics with indices0
,1
,2
, and3
, as a tuple. -
void cw_clear()
: Remove all existing custom walls.
Below are the custom timeline functions, which can be identified with the "ct_" prefix. These are functions with foundations of Object-oriented programming to allow pack developers to create and manage independent timelines.
-
int ct_create()
: Create a new custom timeline and return a integer handle to it. -
void ct_eval(int handle, std::string code)
: Add to the custom timeline with handlehandle
: evaluate the Lua code specified incode
. -
void ct_kill(int handle)
: Add to the custom timeline with handlehandle
: kill the player. -
void ct_stopTime(int handle, double duration)
: Add to the custom timeline with handlehandle
: pause the game timer forduration
frames (under the assumption of a 60 FPS frame rate). -
void ct_stopTimeS(int handle, double duration)
: Add to the custom timeline with handlehandle
: pause the game timer forduration
seconds. -
void ct_wait(int handle, double duration)
: Add to the custom timeline with handlehandle
: wait forduration
frames (under the assumption of a 60 FPS frame rate). -
void ct_waitS(int handle, double duration)
: Add to the custom timeline with handlehandle
: wait forduration
seconds. -
void ct_waitUntilS(int handle, double duration)
: Add to the custom timeline with handlehandle
: wait until the timer reachesduration
seconds.
Below are the shader functions, which can be identified with the "shdr_" prefix. These are functions that enable graphical manipulation of the rendered game scene via GLSL shaders.
-
unsigned long long shdr_getShaderId(std::string shaderFilename)
: Retrieve the id of the shader with nameshaderFilename
from the current pack. The shader will be searched for in theShaders/
subfolder. The extension of the shader should be included inshaderFilename
and it will determine its type (i.e..frag
,.vert
, and.geom
). -
unsigned long long shdr_getDependencyShaderId(std::string packDisambiguator, std::string packName, std::string packAuthor, std::string shaderFilename)
: Retrieve the id of the shader with nameshaderFilename
provided by the dependee pack with disambiguatorpackDisambiguator
, namepackName
, authorpackAuthor
. The shader will be searched for in theShaders/
subfolder of the dependee. The extension of the shader should be included inpackDisambiguator
and it will determine its type (i.e..frag
,.vert
, and.geom
). -
void shdr_setUniformF(unsigned long long shaderId, std::string name, float a)
: Set the float uniform with namename
of the shader with idshaderId
toa
. -
void shdr_setUniformFVec2(unsigned long long shaderId, std::string name, float a, float b)
: Set the float vector2 uniform with namename
of the shader with idshaderId
to{a, b}
. -
void shdr_setUniformFVec3(unsigned long long shaderId, std::string name, float a, float b, float c)
: Set the float vector3 uniform with namename
of the shader with idshaderId
to{a, b, c}
. -
void shdr_setUniformFVec4(unsigned long long shaderId, std::string name, float a, float b, float c, float d)
: Set the float vector4 uniform with namename
of the shader with idshaderId
to{a, b, c, d}
. -
void shdr_setUniformI(unsigned long long shaderId, std::string name, int a)
: Set the integer uniform with namename
of the shader with idshaderId
toa
. -
void shdr_setUniformIVec2(unsigned long long shaderId, std::string name, int a, int b)
: Set the integer vector2 uniform with namename
of the shader with idshaderId
to{a, b}
. -
void shdr_setUniformIVec3(unsigned long long shaderId, std::string name, int a, int b, int c)
: Set the integer vector3 uniform with namename
of the shader with idshaderId
to{a, b, c}
. -
void shdr_setUniformIVec4(unsigned long long shaderId, std::string name, int a, int b, int c, int d)
: Set the integer vector4 uniform with namename
of the shader with idshaderId
to{a, b, c, d}
. -
void shdr_resetAllActiveFragmentShaders()
: Reset all active fragment shaders in all render stages. -
void shdr_resetActiveFragmentShader(unsigned long long renderStage)
: Reset the currently active fragment shader for the render stagerenderStage
. -
void shdr_setActiveFragmentShader(unsigned long long renderStage, unsigned long long shaderId)
: Set the currently active fragment shader for the render stagerenderStage
to the shader with idshaderId
.
Below are the miscellaneous functions, which can have a variable prefix or no prefix at all. These are other functions that are listed that cannot qualify for one of the above eight categories and achieve some other purpose, with some functions not meant to be used by pack developers at all.
-
void steam_unlockAchievement(std::string achievementId)
: Unlock the Steam achievement with idachievementId
. -
void m_messageAdd(std::string message, double duration)
: Add to the event timeline: print a message with textmessage
forduration
seconds. The message will only be printed during the first run of the level. This function is deprecated and will be removed in a future version. Please use e_messageAdd instead! -
void m_messageAddImportant(std::string message, double duration)
: Add to the event timeline: print a message with textmessage
forduration
seconds. The message will be printed during every run of the level. This function is deprecated and will be removed in a future version. Please use e_messageAddImportant instead! -
void m_messageAddImportantSilent(std::string message, double duration)
: Add to the event timeline: print a message with textmessage
forduration
seconds. The message will only be printed during every run of the level, and will not produce any sound. This function is deprecated and will be removed in a future version. Please use e_messageAddImportantSilent instead! -
void m_clearMessages()
: Remove all previously scheduled messages. This function is deprecated and will be removed in a future version. Please use e_clearMessages instead!