return {
callbacks = {
{
name = "conf",
tag = "callbacks",
summary = "Called to read configuration settings at startup.",
description = "The `lovr.conf` callback lets you configure default settings for LÖVR. It is called once right before the game starts. Make sure you put `lovr.conf` in a file called `conf.lua`, a special file that's loaded before the rest of the framework initializes.",
key = "lovr.conf",
module = "lovr",
variants = {
{
arguments = {
{
name = "t",
type = "table",
description = "The table to edit the configuration settings on.",
table = {
{
name = "identity",
type = "string",
description = "A unique label for this project."
},
{
name = "modules",
type = "table",
description = "The set of enabled modules to use.",
table = {
{
name = "audio",
type = "boolean",
description = "Whether the audio module should be enabled."
},
{
name = "event",
type = "boolean",
description = "Whether the event module should be enabled."
},
{
name = "filesystem",
type = "boolean",
description = "Whether the filesystem module should be enabled."
},
{
name = "graphics",
type = "boolean",
description = "Whether the graphics module should be enabled."
},
{
name = "headset",
type = "boolean",
description = "Whether the headset module should be enabled."
},
{
name = "math",
type = "boolean",
description = "Whether the math module should be enabled."
},
{
name = "timer",
type = "boolean",
description = "Whether the timer module should be enabled."
}
}
}
}
}
},
returns = {}
}
},
related = {
"lovr.load"
},
examples = {
{
description = "A noop conf.lua that sets all configuration settings to their defaults:",
code = "function lovr.conf(t)\n -- Set the project identity\n t.identity = 'default'\n\n -- Enable or disable different modules\n t.modules.audio = true\n t.modules.event = true\n t.modules.graphics = true\n t.modules.headset = true\n t.modules.math = true\n t.modules.timer = true\nend"
}
},
notes = "Disabling the `headset` module can improve startup time a lot if you aren't intending to use `lovr.headset`."
},
{
name = "controlleradded",
tag = "callbacks",
summary = "Called when a Controller is connected.",
description = "This callback is called when a Controller is connected, discovered, or woken up.",
key = "lovr.controlleradded",
module = "lovr",
related = {
"lovr.controllerremoved",
"lovr.headset.getControllers",
"lovr.headset.getControllerCount"
},
variants = {
{
arguments = {
{
name = "controller",
type = "Controller",
description = "The new controller object."
}
},
returns = {}
}
}
},
{
name = "controllerremoved",
tag = "callbacks",
summary = "Called when a Controller is disconnected.",
description = "This callback is called when a Controller is disconnected or turned off.",
key = "lovr.controllerremoved",
module = "lovr",
related = {
"lovr.controlleradded",
"lovr.headset.getControllers",
"lovr.headset.getControllerCount"
},
variants = {
{
arguments = {
{
name = "controller",
type = "Controller",
description = "The controller that was removed."
}
},
returns = {}
}
}
},
{
name = "draw",
tag = "callbacks",
summary = "Called continuously to render frames to the display.",
description = "This callback is called every frame. Use it to render the scene. If a VR headset is connected, this function will be called twice per frame (once for each eye) and the function will instead draw to the headset's display.",
key = "lovr.draw",
module = "lovr",
related = {
"lovr.headset.renderTo"
},
variants = {
{
arguments = {
{
name = "eye",
type = "HeadsetEye",
description = "The eye currently being rendered to."
}
},
returns = {}
}
}
},
{
name = "load",
tag = "callbacks",
summary = "Called once at startup.",
description = "This callback is called once when the app starts. It should be used to perform initial setup work, like loading resources and initializing classes and variables.",
key = "lovr.load",
module = "lovr",
variants = {
{
arguments = {
{
name = "args",
type = "table",
description = "The command line arguments provided to the program."
}
},
returns = {}
}
},
examples = {
{
code = "function lovr.load(args)\n model = lovr.graphics.newModel('cena.fbx')\n texture = lovr.graphics.newTexture('cena.png')\n levelGeometry = lovr.graphics.newBuffer(1000)\n effects = lovr.graphics.newShader('vert.glsl', 'frag.glsl')\n loadLevel(1)\nend"
}
},
related = {
"lovr.quit"
}
},
{
name = "quit",
tag = "callbacks",
summary = "Called before quitting.",
description = "This callback is called right before the game is about to quit. Use it to perform any cleanup you need to do. You can also return a \"truthy\" value from this callback to abort quitting.",
key = "lovr.quit",
module = "lovr",
variants = {
{
arguments = {},
returns = {
{
name = "abort",
type = "boolean",
description = "Whether quitting should be aborted."
}
}
}
},
examples = {
{
code = "function lovr.quit()\n if shouldQuit() then\n return false\n else\n return true\n end\nend"
}
},
related = {
"lovr.event.quit",
"lovr.load"
}
},
{
name = "run",
tag = "callbacks",
summary = "The main loop.",
description = "This callback contains the main loop to run everything. The default is usually suitable, but sometimes it is helpful to override this callback for custom behavior.",
key = "lovr.run",
module = "lovr",
variants = {
{
arguments = {},
returns = {}
}
},
examples = {
{
description = "The default `lovr.run`:",
code = "function lovr.run()\n if lovr.load then\n lovr.load()\n end\n\n while true do\n lovr.event.pump()\n\n for name, a, b, c, d in lovr.event.poll() do\n if name == 'quit' and (not lovr.quit or not lovr.quit()) then\n return a\n end\n\n lovr.handlers[name](a, b, c, d)\n end\n\n local dt = lovr.timer.step()\n\n if lovr.audio then\n lovr.audio.update()\n if lovr.headset and lovr.headset.isPresent() then\n lovr.audio.setPosition(lovr.headset.getPosition())\n lovr.audio.setOrientation(lovr.headset.getOrientation())\n end\n end\n\n if lovr.update then\n lovr.update(dt)\n end\n\n lovr.graphics.clear()\n lovr.graphics.origin()\n if lovr.draw then\n if lovr.headset and lovr.headset.isPresent() then\n lovr.headset.renderTo(lovr.draw)\n else\n lovr.draw()\n end\n end\n lovr.graphics.present()\n\n lovr.timer.sleep(.001)\n end\nend"
}
},
related = {
"lovr.load",
"lovr.quit"
}
},
{
name = "update",
tag = "callbacks",
summary = "Called every frame to update the application logic.",
description = "The `lovr.update` callback should be used to update your game's logic. It receives a single parameter, `dt`, which represents the amount of elapsed time between frames. You can use this value to scale timers, physics, and animations in your game so they play at a smooth, consistent speed.",
key = "lovr.update",
module = "lovr",
variants = {
{
arguments = {
{
name = "dt",
type = "number",
description = "The number of seconds elapsed since the last update."
}
},
returns = {}
}
},
examples = {
{
code = "function lovr.update(dt)\n ball.vy = ball.vy + ball.gravity * dt\n ball.y = ball.y + ball.vy * dt\nend"
}
},
related = {
"lovr.timer.getDelta"
}
}
},
modules = {
{
name = "lovr",
summary = "In the beginning, there was nothing.",
description = "`lovr` is the single global table that is exposed to every LÖVR app. It contains a set of **modules** and a set of **callbacks**.",
key = "lovr",
enums = {},
sections = {
{
name = "Modules",
tag = "modules",
description = "Modules are the **what** of your app; you can use the functions in modules to tell LÖVR to do things. For example, you can draw things on the screen, figure out what buttons on a controller are pressed, or load a 3D model from a file. Each module does what it says on the tin, so the `lovr.graphics` module deals with rendering graphics and `lovr.headset` allows you to interact with VR hardware."
},
{
name = "Callbacks",
tag = "callbacks",
description = "Callbacks are the **when** of the application; you write code inside callbacks which LÖVR then calls at certain points in time. For example, the `lovr.load` callback is called once at startup and `lovr.controlleradded` is called when controllers are connected."
},
{
name = "System",
tag = "system",
description = "The lovr module also exposes some functions for retrieving information about the system."
}
},
functions = {
{
name = "getVersion",
tag = "system",
summary = "Get the current version.",
description = "Get the current major, minor, and patch version of LÖVR.",
key = "lovr.getVersion",
module = "lovr",
variants = {
{
arguments = {},
returns = {
{
name = "major",
type = "number",
description = "The major version."
},
{
name = "minor",
type = "number",
description = "The minor version."
},
{
name = "patch",
type = "number",
description = "The patch number."
}
}
}
}
}
},
objects = {}
},
{
name = "audio",
tag = "modules",
summary = "Plays sound.",
description = "The `lovr.audio` module is responsible for playing sound effects and music. Currently, the only supported audio format is .ogg (Vorbis). Playing a sound involves creating a `Source` object for the sound and calling `Source:play` on it.",
key = "lovr.audio",
sections = {
{
name = "Sources",
tag = "sources",
description = "Sources are objects that represent a single sound instance."
},
{
name = "Listener",
tag = "listener",
description = "The listener is a virtual object in 3D space that \"hears\" all the sounds that are playing. The listener can be positioned and oriented in 3D space, which controls how Sources in the world are heard. For example, sounds further away from the listener will be more quiet, and sounds to the left of the listener will be heard from the left speaker. By default, the listener will be synchronized with any connected headset so audio is positioned properly as the headset is moved around and rotated."
}
},
enums = {
{
name = "TimeUnit",
summary = "Time units for sound samples.",
description = "When figuring out how long a Source is or seeking to a specific position in the sound file, units can be expressed in terms of seconds or in terms of samples.",
key = "TimeUnit",
module = "audio",
values = {
{
name = "seconds",
description = "Seconds."
},
{
name = "samples",
description = "Samples."
}
}
}
},
functions = {
{
name = "getOrientation",
tag = "listener",
summary = "Get the orientation of the listener.",
description = "Returns the orientation of the virtual audio listener in angle/axis representation.",
key = "lovr.audio.getOrientation",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "angle",
type = "number",
description = "The number of radians the listener is rotated around its axis of rotation."
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation."
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation."
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation."
}
}
}
}
},
{
name = "getPosition",
tag = "listener",
summary = "Get the position of the listener.",
description = "Returns the position of the virtual audio listener.",
key = "lovr.audio.getPosition",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "x",
type = "number",
description = "The x position of the listener."
},
{
name = "y",
type = "number",
description = "The y position of the listener."
},
{
name = "z",
type = "number",
description = "The z position of the listener."
}
}
}
}
},
{
name = "getVolume",
tag = "listener",
summary = "Get the master volume.",
description = "Returns the master volume. All Source objects have their volume multiplied by this factor.",
key = "lovr.audio.getVolume",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "volume",
type = "number",
description = "The master volume."
}
}
}
},
notes = "The default is 1.0."
},
{
name = "newSource",
tag = "sources",
summary = "Create a new Source.",
description = "Creates a new Source from an ogg file.",
key = "lovr.audio.newSource",
module = "lovr.audio",
variants = {
{
arguments = {
{
name = "filename",
type = "string",
description = "The filename of the sound to load."
}
},
returns = {
{
name = "source",
type = "Source",
description = "The new Source."
}
}
}
}
},
{
name = "pause",
tag = "sources",
summary = "Pause all Sources.",
description = "Pause all playing audio.",
key = "lovr.audio.pause",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {}
}
}
},
{
name = "resume",
tag = "sources",
summary = "Resume all Sources.",
description = "Resume all Sources. Has no effect on Sources that are playing or stopped.",
key = "lovr.audio.resume",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {}
}
}
},
{
name = "rewind",
tag = "sources",
summary = "Rewind all Sources.",
description = "Rewind all playing audio.",
key = "lovr.audio.rewind",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {}
}
},
notes = "Sources that are paused will remain paused. Sources that are currently playing will restart from the beginning."
},
{
name = "setOrientation",
tag = "listener",
summary = "Set the orientation of the listener.",
description = "Sets the orientation of the virtual audio listener in angle/axis representation.",
key = "lovr.audio.setOrientation",
module = "lovr.audio",
variants = {
{
arguments = {
{
name = "angle",
type = "number",
description = "The number of radians the listener should be rotated around its rotation axis."
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation."
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation."
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation."
}
},
returns = {}
}
}
},
{
name = "setPosition",
tag = "listener",
summary = "Set the position of the listener.",
description = "Sets the position of the virtual audio listener.",
key = "lovr.audio.setPosition",
module = "lovr.audio",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x position of the listener."
},
{
name = "y",
type = "number",
description = "The y position of the listener."
},
{
name = "z",
type = "number",
description = "The z position of the listener."
}
},
returns = {}
}
}
},
{
name = "setVolume",
tag = "listener",
summary = "Set the master volume.",
description = "Sets the master volume. The volume of all Sources will be multiplied by this factor.",
key = "lovr.audio.setVolume",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "volume",
type = "number",
description = "The master volume."
}
}
}
},
notes = "The default is 1.0."
},
{
name = "stop",
tag = "sources",
summary = "Stop all Sources.",
description = "Stops all audio.",
key = "lovr.audio.stop",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {}
}
},
notes = "If you want to resume the stopped audio later, see `lovr.audio.pause`."
},
{
name = "update",
tag = "sources",
summary = "Updates the audio system.",
description = "Updates all playing sources. This must be called regularly for audio playback to occur. Normally this is called for you by `lovr.run`.",
key = "lovr.audio.update",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {}
}
}
}
},
objects = {
{
name = "Source",
summary = "A playable sound object.",
description = "A Source is an object representing a single sound. Currently, only ogg sounds are supported. Sources can be in three different states:\n\n
\n \n Playing | \n The source is currently playing. It can be stopped, paused, or rewound. | \n
\n \n Paused | \n The source is paused. It can be stopped, played/resumed, or rewound. | \n
\n \n Stopped | \n The source has been stopped. It can be played. | \n
",
key = "Source",
module = "lovr.audio",
methods = {
{
name = "getBitDepth",
summary = "Get the bit depth of the Source.",
description = "Returns the number of bits per sample in the Source. This is a rough indicator of the resolution of the Source, and is usually 16.",
key = "Source:getBitDepth",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "bits",
type = "number",
description = "The number of bits per sample."
}
}
}
}
},
{
name = "getChannels",
summary = "Get the number of channels in the Source.",
description = "Returns the number of channels in the Source. Mono sounds have 1 channel and stereo sounds have 2 channels.",
key = "Source:getChannels",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "channels",
type = "number",
description = "The number of channels."
}
}
}
}
},
{
name = "getDuration",
summary = "Get the duration of the Source.",
description = "Returns the duration of the Source.",
key = "Source:getDuration",
module = "lovr.audio",
variants = {
{
arguments = {
{
name = "unit",
type = "TimeUnit",
description = "The unit to return.",
default = "'seconds'"
}
},
returns = {
{
name = "duration",
type = "number",
description = "The duration of the Source."
}
}
}
}
},
{
name = "getOrientation",
summary = "Get the direction vector of the Source.",
description = "Returns the direction vector of the Source (the direction it's playing in).",
key = "Source:getOrientation",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "x",
type = "number",
description = "The x component of the direction vector."
},
{
name = "y",
type = "number",
description = "The y component of the direction vector."
},
{
name = "z",
type = "number",
description = "The z component of the direction vector."
}
}
}
}
},
{
name = "getPitch",
summary = "Get the pitch of the Source.",
description = "Returns the current pitch factor of the Source. The default is 1.0.",
key = "Source:getPitch",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "pitch",
type = "number",
description = "The current pitch."
}
}
}
}
},
{
name = "getPosition",
summary = "Get the position of the Source.",
description = "Returns the position of the Source in space.",
key = "Source:getPosition",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "x",
type = "number",
description = "The x coordinate."
},
{
name = "y",
type = "number",
description = "The y coordinate."
},
{
name = "z",
type = "number",
description = "The z coordinate."
}
}
}
}
},
{
name = "getSampleRate",
summary = "Get the sample rate of the Source.",
description = "Returns the number of samples per second in the Source. This is usually a high number like 44100.",
key = "Source:getSampleRate",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "frequency",
type = "number",
description = "The number of samples per second in the Source."
}
}
}
}
},
{
name = "getVolume",
summary = "Get the volume of the Source.",
description = "Returns the current volume factor for the Source. 1.0 is the default and the maximum.",
key = "Source:getVolume",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "volume",
type = "number",
description = "The volume of the Source."
}
}
}
}
},
{
name = "isLooping",
summary = "Check if the Source is looping.",
description = "Returns whether or not the Source will loop when it finishes.",
key = "Source:isLooping",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "looping",
type = "boolean",
description = "Whether or not the Source is looping."
}
}
}
}
},
{
name = "isPaused",
summary = "Check if the Source is paused.",
description = "Returns whether or not the Source is paused.",
key = "Source:isPaused",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "paused",
type = "boolean",
description = "Whether the Source is paused."
}
}
}
}
},
{
name = "isPlaying",
summary = "Check if the Source is playing.",
description = "Returns whether or not the Source is playing.",
key = "Source:isPlaying",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "playing",
type = "boolean",
description = "Whether the Source is playing."
}
}
}
}
},
{
name = "isStopped",
summary = "Check if the Source is stopped.",
description = "Returns whether or not the Source is stopped.",
key = "Source:isStopped",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {
{
name = "stopped",
type = "boolean",
description = "Whether the Source is stopped."
}
}
}
}
},
{
name = "pause",
summary = "Pause the Source.",
description = "Pauses the source. It can be resumed with `Source:resume` or `Source:play`. If a paused source is rewound, it will remain paused.",
key = "Source:pause",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {}
}
}
},
{
name = "play",
summary = "Play the Source.",
description = "Plays the Source. This has no effect if the Source is already playing.",
key = "Source:play",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {}
}
}
},
{
name = "resume",
summary = "Resume the Source.",
description = "Resumes the Source.",
key = "Source:resume",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {}
}
}
},
{
name = "rewind",
summary = "Rewind the Source.",
description = "Rewinds the Source, starting it over at the beginning. Paused Sources will remain paused.",
key = "Source:rewind",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {}
}
}
},
{
name = "seek",
summary = "Set the playback position of the Source.",
description = "Seeks the Source to the specified position.",
key = "Source:seek",
module = "lovr.audio",
variants = {
{
arguments = {
{
name = "position",
type = "number",
description = "The position to seek to."
},
{
name = "unit",
type = "TimeUnit",
description = "The units for the seek position.",
default = "'seconds'"
}
},
returns = {}
}
}
},
{
name = "setLooping",
summary = "Set whether or not the Source loops.",
description = "Sets whether or not the Source loops.",
key = "Source:setLooping",
module = "lovr.audio",
variants = {
{
arguments = {
{
name = "loop",
type = "boolean",
description = "Whether or not the Source will loop."
}
},
returns = {}
}
}
},
{
name = "setOrientation",
summary = "Set the direction vector of the Source.",
description = "Sets the direction vector of the Source (the direction it's playing in).",
key = "Source:setOrientation",
module = "lovr.audio",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x component of the direction vector."
},
{
name = "y",
type = "number",
description = "The y component of the direction vector."
},
{
name = "z",
type = "number",
description = "The z component of the direction vector."
}
},
returns = {}
}
}
},
{
name = "setPitch",
summary = "Set the pitch of the Source.",
description = "Sets the pitch of the Source. The default is 1.0.",
key = "Source:setPitch",
module = "lovr.audio",
variants = {
{
arguments = {
{
name = "pitch",
type = "number",
description = "The new pitch."
}
},
returns = {}
}
}
},
{
name = "setPosition",
summary = "Set the position of the Source.",
description = "Sets the position of the Source in space.",
key = "Source:setPosition",
module = "lovr.audio",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x coordinate."
},
{
name = "y",
type = "number",
description = "The y coordinate."
},
{
name = "z",
type = "number",
description = "The z coordinate."
}
},
returns = {}
}
}
},
{
name = "setVolume",
summary = "Set the volume of the Source.",
description = "Sets the current volume factor for the Source. 1.0 is the default and the maximum.",
key = "Source:setVolume",
module = "lovr.audio",
variants = {
{
arguments = {
{
name = "volume",
type = "number",
description = "The new volume."
}
},
returns = {}
}
}
},
{
name = "stop",
summary = "Stop the Source.",
description = "Stops the source.",
key = "Source:stop",
module = "lovr.audio",
variants = {
{
arguments = {},
returns = {}
}
}
},
{
name = "tell",
summary = "Get the playback position of the Source.",
description = "Returns the current playback position of the Source.",
key = "Source:tell",
module = "lovr.audio",
variants = {
{
arguments = {
{
name = "unit",
type = "TimeUnit",
description = "The unit to return.",
default = "'seconds'"
}
},
returns = {
{
name = "position",
type = "number",
description = "The current playback position."
}
}
}
}
}
},
constructors = {
"lovr.audio.newSource"
}
}
}
},
{
name = "event",
tag = "modules",
summary = "Handles events from the operating system.",
description = "The `lovr.event` module handles events from the operating system.\n\nDue to its low-level nature, it's rare to use `lovr.event` in simple projects.",
key = "lovr.event",
functions = {
{
name = "clear",
summary = "Clear the event queue.",
description = "Clears the event queue, removing any unprocessed events.",
key = "lovr.event.clear",
module = "lovr.event",
variants = {
{
arguments = {},
returns = {}
}
}
},
{
name = "poll",
summary = "Iterate over unprocessed events in the queue.",
description = "This function returns a Lua iterator for all of the unprocessed items in the event queue. Each event consists of a name as a string, followed by event-specific arguments. Typically this function is automatically called for you by `lovr.run`.",
key = "lovr.event.poll",
module = "lovr.event",
variants = {
{
arguments = {},
returns = {
{
name = "iterator",
type = "function",
description = "The iterator function, usable in a for loop.",
arguments = {},
returns = {}
}
}
}
}
},
{
name = "pump",
summary = "Pump new events into the queue for processing.",
description = "Fills the event queue with unprocessed events from the operating system. This function should be called often, otherwise the operating system will consider your application unresponsive. By default, this function is called automatically by `lovr.run`.",
key = "lovr.event.pump",
module = "lovr.event",
related = {
"lovr.event.poll"
},
variants = {
{
arguments = {},
returns = {}
}
}
},
{
name = "push",
summary = "Manually push an event onto the queue.",
description = "Pushes an event onto the event queue. It will be processed the next time `lovr.event.poll` is called. For an event to be processed properly, there needs to be a function in the `lovr.handlers` table with a key that's the same as the event name.",
key = "lovr.event.push",
module = "lovr.event",
related = {
"lovr.event.poll",
"lovr.event.quit"
},
variants = {
{
arguments = {
{
name = "name",
type = "string",
description = "The name of the event."
},
{
name = "...",
type = "*",
description = "The arguments for the event."
}
},
returns = {}
}
}
},
{
name = "quit",
summary = "Quit the application.",
description = "Pushes an event to quit the game. An optional number can be passed to set the exit code for the application. An exit code of zero indicates normal termination, whereas a nonzero exit code indicates that an error occurred.",
key = "lovr.event.quit",
module = "lovr.event",
related = {
"lovr.quit",
"lovr.event.poll"
},
variants = {
{
arguments = {
{
name = "code",
type = "number",
description = "The exit code of the program.",
default = "0"
}
},
returns = {}
}
},
notes = "This function is equivalent to:\n\n lovr.event.push('quit', code)\n\nThe program won't actually exit until the next time `lovr.event.poll` is called."
}
},
examples = {
{
description = "Adding a custom event.",
code = "function lovr.load()\n lovr.handlers['customevent'] = function(a, b, c)\n print('custom event handled with args:', a, b, c)\n end\n\n lovr.event.push('customevent', 1, 2, 3)\nend"
}
},
enums = {},
objects = {},
notes = "You can define your own custom events by adding a function to the `lovr.handlers` table with a key of the name of the event you want to add. Then, push the event using `lovr.event.push`."
},
{
name = "filesystem",
tag = "modules",
summary = "Provides access to the filesystem.",
description = "The `lovr.filesystem` module provides access to the filesystem.",
key = "lovr.filesystem",
enums = {},
notes = "LÖVR programs can only write to a single directory, called the save directory. The location of the save directory is platform-specific:\n\n\n \n Windows | \n C:\\Users\\<user>\\AppData\\Roaming\\LOVR\\<identity> | \n
\n \n macOS | \n /Users/<user>/Library/Application Support/LOVR/<identity> | \n
\n \n Linux | \n /home/<user>/.local/share/LOVR/<identity> | \n
\n\n`` should be a unique identifier for your app. It can be set either in `lovr.conf` or by using `lovr.filesystem.setIdentity`.\n\nAll filenames are relative to either the save directory or the directory containing the project source. Files in the save directory take precedence over files in the project.",
functions = {
{
name = "append",
summary = "Append content to the end of a file.",
description = "Appends content to the end of the file.",
key = "lovr.filesystem.append",
module = "lovr.filesystem",
notes = "If the file does not exist, it is created.",
variants = {
{
arguments = {
{
name = "filename",
type = "string",
description = "The file to append to."
},
{
name = "content",
type = "string",
description = "A string to write to the end of the file."
}
},
returns = {
{
name = "bytes",
type = "number",
description = "The number of bytes written."
}
}
}
}
},
{
name = "exists",
summary = "Check whether a file exists.",
description = "Determine if a file exists.",
key = "lovr.filesystem.exists",
module = "lovr.filesystem",
notes = "This function checks both the source directory and the save directory.",
variants = {
{
arguments = {
{
name = "path",
type = "string",
description = "The path to check."
}
},
returns = {
{
name = "exists",
type = "boolean",
description = "Whether the path is a file or directory."
}
}
}
}
},
{
name = "getExecutablePath",
summary = "Get the path of the LÖVR executable.",
description = "Returns the absolute path of the LÖVR executable.",
key = "lovr.filesystem.getExecutablePath",
module = "lovr.filesystem",
variants = {
{
arguments = {},
returns = {
{
name = "path",
type = "string",
description = "The absolute path of the LÖVR executable."
}
}
}
}
},
{
name = "getIdentity",
summary = "Get the name of the save directory.",
description = "Returns the identity of the game, which is used as the name of the save directory. The default is `default`.",
key = "lovr.filesystem.getIdentity",
module = "lovr.filesystem",
variants = {
{
arguments = {},
returns = {
{
name = "identity",
type = "string",
description = "The name of the save directory."
}
}
}
}
},
{
name = "getRealDirectory",
summary = "Get the absolute path to a file.",
description = "Get the absolute path of a directory containing a path in the virtual filesystem. This can be used to determine if a file is in the game's source directory or the save directory.",
key = "lovr.filesystem.getRealDirectory",
module = "lovr.filesystem",
variants = {
{
arguments = {
{
name = "path",
type = "string",
description = "The path to check."
}
},
returns = {
{
name = "realpath",
type = "string",
description = "The absolute path of the directory containing `path`."
}
}
}
}
},
{
name = "getSource",
summary = "Get the location of the project source.",
description = "Get the absolute path of the project's source directory or archive.",
key = "lovr.filesystem.getSource",
module = "lovr.filesystem",
variants = {
{
arguments = {},
returns = {
{
name = "path",
type = "string",
description = "The absolute path of the project's source."
}
}
}
}
},
{
name = "getUserDirectory",
summary = "Get the location of the user's home directory.",
description = "Get the absolute path of the user's home directory.",
key = "lovr.filesystem.getUserDirectory",
module = "lovr.filesystem",
variants = {
{
arguments = {},
returns = {
{
name = "path",
type = "string",
description = "The absolute path of the user's home directory."
}
}
}
}
},
{
name = "isDirectory",
summary = "Check whether a path is a directory.",
description = "Check if a path exists and is a directory.",
key = "lovr.filesystem.isDirectory",
module = "lovr.filesystem",
related = {
"lovr.filesystem.isFile"
},
variants = {
{
arguments = {
{
name = "path",
type = "string",
description = "The path to check."
}
},
returns = {
{
name = "isDirectory",
type = "boolean",
description = "Whether or not path is a directory."
}
}
}
}
},
{
name = "isFile",
summary = "Check whether a path is a file.",
description = "Check if a path exists and is a file.",
key = "lovr.filesystem.isFile",
module = "lovr.filesystem",
related = {
"lovr.filesystem.isDirectory"
},
variants = {
{
arguments = {
{
name = "path",
type = "string",
description = "The path to check."
}
},
returns = {
{
name = "isFile",
type = "boolean",
description = "Whether or not path is a file."
}
}
}
}
},
{
name = "read",
summary = "Read a file.",
description = "Read the contents of a file.",
key = "lovr.filesystem.read",
module = "lovr.filesystem",
notes = "If the file does not exist or cannot be read, an error is thrown.",
variants = {
{
arguments = {
{
name = "filename",
type = "string",
description = "The name of the file to read."
}
},
returns = {
{
name = "contents",
type = "string",
description = "The contents of the file."
}
}
}
}
},
{
name = "setIdentity",
summary = "Set the name of the save directory.",
description = "Set the name of the save directory.",
key = "lovr.filesystem.setIdentity",
module = "lovr.filesystem",
variants = {
{
arguments = {
{
name = "identity",
type = "string",
description = "The new name of the save directory."
}
},
returns = {}
}
}
},
{
name = "setSource",
summary = "Set the project source.",
description = "Sets the location of the project's source. This can only be done once, and is usually done internally.",
key = "lovr.filesystem.setSource",
module = "lovr.filesystem",
variants = {
{
arguments = {
{
name = "identity",
type = "string",
description = "The path containing the project's source."
}
},
returns = {}
}
}
},
{
name = "write",
summary = "Write to a file.",
description = "Write to a file.",
key = "lovr.filesystem.write",
module = "lovr.filesystem",
notes = "If the file does not exist, it is created.",
variants = {
{
arguments = {
{
name = "filename",
type = "string",
description = "The file to write to."
},
{
name = "content",
type = "string",
description = "A string to write to the file."
}
},
returns = {
{
name = "bytes",
type = "number",
description = "The number of bytes written."
}
}
}
}
}
},
objects = {}
},
{
name = "graphics",
tag = "modules",
summary = "Renders graphics.",
description = "The `lovr.graphics` module renders graphics to displays. Anything rendered using this module will automatically show up in the VR headset if one is connected, otherwise it will just show up in a window on the desktop.",
key = "lovr.graphics",
sections = {
{
name = "Drawing",
tag = "graphicsPrimitives",
description = "Simple functions for drawing simple shapes."
},
{
name = "Objects",
tag = "graphicsObjects",
description = "Several graphics-related objects can be created with the graphics module. Try to avoid calling these functions in `lovr.update` or `lovr.draw`, because then the objects will be loaded every frame, which can really slow things down!"
},
{
name = "Transforms",
tag = "graphicsTransforms",
description = "These functions manipulate the 3D coordinate system. By default the negative z axis points forwards and the positive y axis points up. Manipulating the coordinate system can be used to create a hierarchy of rendered objects. Thinking in many different coordinate systems can be challenging though, so be sure to brush up on 3D math first!"
},
{
name = "State",
tag = "graphicsState",
description = "These functions get or set graphics state. Graphics state is is a collection of small settings like the background color of the scene or the active shader. Keep in mind that all this state is **global**, so if you change a setting, the change will persist until that piece of state is changed again."
},
{
name = "Window",
tag = "window",
description = "Get info about the desktop window or operate on the underlying graphics context."
}
},
enums = {
{
name = "BufferDrawMode",
summary = "Different ways buffers can be drawn.",
description = "Buffers are lists of arbitrary vertices. These vertices can be drawn in a few different ways, leading to different results.",
key = "BufferDrawMode",
module = "graphics",
values = {
{
name = "points",
description = "Draw each vertex as a single point."
},
{
name = "strip",
description = "The first three vertices define a triangle. Each vertex after that creates a triangle using the new vertex and last two vertices."
},
{
name = "triangles",
description = "Each set of three vertices represents a discrete triangle."
},
{
name = "fan",
description = "Draws a set of triangles. Each one shares the first vertex as a common point, leading to a fan-like shape."
}
}
},
{
name = "BufferUsage",
summary = "How a Buffer is going to be updated.",
description = "Buffers can have a usage hint, describing how they are planning on being updated. Setting the usage hint allows the graphics driver optimize how it handles the data in the Buffer.",
key = "BufferUsage",
module = "graphics",
values = {
{
name = "static",
description = "The buffer contents will rarely change."
},
{
name = "dynamic",
description = "The buffer contents will change often."
},
{
name = "stream",
description = "The buffer contents will change constantly, potentially multiple times each frame."
}
}
},
{
name = "CompareMode",
summary = "Different depth test modes.",
description = "The method used to compare z values when deciding how to overlap rendered objects. This is called the \"depth test\", and it happens on a pixel-by-pixel basis every time new objects are drawn. If the depth test \"passes\" for a pixel, then the pixel color will be replaced by the new color and the depth value in the depth buffer will be updated. Otherwise, the pixel will not be changed and the depth value will not be updated.",
key = "CompareMode",
module = "graphics",
values = {
{
name = "equal",
description = "The depth test passes when the depth values are equal."
},
{
name = "notequal",
description = "The depth test passes when the depth values are not equal."
},
{
name = "less",
description = "The depth test passes when the new depth value is less than the existing one."
},
{
name = "lequal",
description = "The depth test passes when the new depth value is less than or equal to the existing one."
},
{
name = "gequal",
description = "The depth test passes when the new depth value is greater than or equal to the existing one."
},
{
name = "greater",
description = "The depth test passes when the new depth value is greater than the existing one."
}
}
},
{
name = "DrawMode",
summary = "Different ways graphics primitives can be drawn.",
description = "Most graphics primitives can be drawn in one of two modes: a filled mode and a wireframe mode.",
key = "DrawMode",
module = "graphics",
values = {
{
name = "fill",
description = "The shape is drawn as a filled object."
},
{
name = "line",
description = "The shape is drawn as a wireframe object."
}
}
},
{
name = "FilterMode",
summary = "How textures are sampled.",
description = "The method used to downsample (or upsample) a texture. \"nearest\" can be used for a pixelated effect, whereas \"linear\" leads to more smooth results. Nearest is slightly faster than linear.",
key = "FilterMode",
module = "graphics",
values = {
{
name = "linear",
description = "The texture will be smoothed."
},
{
name = "nearest",
description = "The texture will be pixelated."
}
}
},
{
name = "HorizontalAlign",
summary = "Different ways to horizontally align text.",
description = "Different ways to horizontally align text when using `lovr.graphics.print`.",
key = "HorizontalAlign",
module = "graphics",
values = {
{
name = "left",
description = "Left aligned lines of text."
},
{
name = "center",
description = "Centered aligned lines of text."
},
{
name = "right",
description = "Right aligned lines of text."
}
},
related = {
"VerticalAlign",
"lovr.graphics.print"
}
},
{
name = "PolygonWinding",
summary = "Different winding directions.",
description = "Whether the points on triangles are specified in a clockwise or counterclockwise order.",
key = "PolygonWinding",
module = "graphics",
values = {
{
name = "clockwise",
description = "Triangle vertices are specified in a clockwise order."
},
{
name = "counterclockwise",
description = "Triangle vertices are specified in a counterclockwise order."
}
}
},
{
name = "TextureProjection",
summary = "Different projection types for renderable textures.",
description = "When creating Textures to be used as render targets, they can be created in either \"2d\" or \"3d\" mode. 2D mode is good for 2D user interfaces or postprocessing, whereas 3d is useful for portals, weapon scopes, mirrors, and other situations where 3D content needs to be rendered.",
key = "TextureProjection",
module = "graphics",
values = {
{
name = "2d",
description = "Use an orthographic projection."
},
{
name = "3d",
description = "Use a perspective projection."
}
}
},
{
name = "VerticalAlign",
summary = "Different ways to vertically align text.",
description = "Different ways to vertically align text when using `lovr.graphics.print`.",
key = "VerticalAlign",
module = "graphics",
values = {
{
name = "top",
description = "Align the top of the text to the origin."
},
{
name = "middle",
description = "Vertically center the text."
},
{
name = "bottom",
description = "Align the bottom of the text to the origin."
}
},
related = {
"HorizontalAlign",
"lovr.graphics.print"
}
},
{
name = "WrapMode",
summary = "How to wrap Textures.",
description = "The method used to render textures when texture coordinates are outside of the 0-1 range.",
key = "WrapMode",
module = "graphics",
values = {
{
name = "clamp",
description = "The texture will be clamped at its edges."
},
{
name = "repeat",
description = "The texture repeats."
},
{
name = "mirroredrepeat",
description = "The texture will repeat, mirroring its appearance each time it repeats."
},
{
name = "clampzero",
description = "Pixels outside of 0-1 will appear black."
}
}
}
},
functions = {
{
name = "clear",
tag = "window",
summary = "Clear the screen.",
description = "Clears the screen to the background color. This function is called automatically by `lovr.run`.",
key = "lovr.graphics.clear",
module = "lovr.graphics",
related = {
"lovr.graphics.setBackgroundColor"
},
variants = {
{
arguments = {
{
name = "color",
type = "boolean",
description = "Whether or not to clear color information on the screen.",
default = "true"
},
{
name = "depth",
type = "boolean",
description = "Whether or not to clear the depth information on the screen.",
default = "true"
}
},
returns = {}
}
}
},
{
name = "cube",
tag = "graphicsPrimitives",
summary = "Draw a cube.",
description = "Draws a cube.",
key = "lovr.graphics.cube",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "mode",
type = "DrawMode",
description = "How to draw the cube."
},
{
name = "x",
type = "number",
description = "The x coordinate of the center of the cube.",
default = "0"
},
{
name = "y",
type = "number",
description = "The y coordinate of the center of the cube.",
default = "0"
},
{
name = "z",
type = "number",
description = "The z coordinate of the center of the cube.",
default = "0"
},
{
name = "size",
type = "number",
description = "The size of the cube, in meters.",
default = "1"
},
{
name = "angle",
type = "number",
description = "The rotation of the cube around its rotation axis, in radians.",
default = "0"
},
{
name = "ax",
type = "number",
description = "The x coordinate of the cube's axis of rotation.",
default = "0"
},
{
name = "ay",
type = "number",
description = "The y coordinate of the cube's axis of rotation.",
default = "1"
},
{
name = "az",
type = "number",
description = "The z coordinate of the cube's axis of rotation.",
default = "0"
}
},
returns = {}
},
{
arguments = {
{
name = "texture",
type = "Texture",
description = "The Texture to apply to the cube faces."
},
{
name = "x",
type = "number",
description = "The x coordinate of the center of the cube.",
default = "0"
},
{
name = "y",
type = "number",
description = "The y coordinate of the center of the cube.",
default = "0"
},
{
name = "z",
type = "number",
description = "The z coordinate of the center of the cube.",
default = "0"
},
{
name = "size",
type = "number",
description = "The size of the cube, in meters.",
default = "1"
},
{
name = "angle",
type = "number",
description = "The rotation of the cube around its rotation axis, in radians.",
default = "0"
},
{
name = "ax",
type = "number",
description = "The x coordinate of the cube's axis of rotation.",
default = "0"
},
{
name = "ay",
type = "number",
description = "The y coordinate of the cube's axis of rotation.",
default = "1"
},
{
name = "az",
type = "number",
description = "The z coordinate of the cube's axis of rotation.",
default = "0"
}
},
returns = {}
},
{
arguments = {
{
name = "mode",
type = "DrawMode",
description = "How to draw the cube."
},
{
name = "transform",
type = "Transform",
description = "The cube's transform."
}
},
returns = {}
},
{
arguments = {
{
name = "texture",
type = "Texture",
description = "The Texture to apply to the cube faces."
},
{
name = "transform",
type = "Transform",
description = "The cube's transform."
}
},
returns = {}
}
}
},
{
name = "getBackgroundColor",
tag = "graphicsState",
summary = "Get the background color.",
description = "Returns the current background color. Color components are from 0 to 255.",
key = "lovr.graphics.getBackgroundColor",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "r",
type = "number",
description = "The red component of the background color."
},
{
name = "g",
type = "number",
description = "The green component of the background color."
},
{
name = "b",
type = "number",
description = "The blue component of the background color."
},
{
name = "a",
type = "number",
description = "The alpha component of the background color."
}
}
}
},
notes = "The default background color is black."
},
{
name = "getColor",
tag = "graphicsState",
summary = "Get the global color factor.",
description = "Returns the current global color factor. Color components are from 0 to 255. Every pixel drawn will be multiplied (i.e. tinted) by this color.",
key = "lovr.graphics.getColor",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "r",
type = "number",
description = "The red component of the color."
},
{
name = "g",
type = "number",
description = "The green component of the color."
},
{
name = "b",
type = "number",
description = "The blue component of the color."
},
{
name = "a",
type = "number",
description = "The alpha component of the color."
}
}
}
},
notes = "The default color is white."
},
{
name = "getColorMask",
tag = "graphicsState",
summary = "Get the color mask.",
description = "Returns the active color channels. If a color channel is active, then drawing operations will affect that particular channel.",
key = "lovr.graphics.getColorMask",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "r",
type = "boolean",
description = "Whether or not the red channel is enabled."
},
{
name = "g",
type = "boolean",
description = "Whether or not the green channel is enabled."
},
{
name = "b",
type = "boolean",
description = "Whether or not the blue channel is enabled."
},
{
name = "a",
type = "boolean",
description = "Whether or not the alpha channel is enabled."
}
}
}
},
notes = "Initially, all color channels are enabled."
},
{
name = "getDepthTest",
tag = "graphicsState",
summary = "Get the depth test mode.",
description = "Returns the current depth test. The depth test controls how overlapping objects are rendered.",
key = "lovr.graphics.getDepthTest",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "compareMode",
type = "CompareMode",
description = "The current depth test."
}
}
}
},
notes = "The default depth test is `less`."
},
{
name = "getDimensions",
tag = "window",
summary = "Get the dimensions of the window.",
description = "Returns the dimensions of the desktop window.",
key = "lovr.graphics.getDimensions",
module = "lovr.graphics",
related = {
"lovr.graphics.getWidth",
"lovr.graphics.getHeight"
},
variants = {
{
arguments = {},
returns = {
{
name = "width",
type = "number",
description = "The width of the window, in pixels."
},
{
name = "height",
type = "number",
description = "The height of the window, in pixels."
}
}
}
}
},
{
name = "getFont",
tag = "graphicsState",
summary = "Get the active font.",
description = "Returns the active font.",
key = "lovr.graphics.getFont",
module = "lovr.graphics",
related = {
"lovr.graphics.print"
},
variants = {
{
arguments = {},
returns = {
{
name = "font",
type = "Font",
description = "The active font object."
}
}
}
}
},
{
name = "getHeight",
tag = "window",
summary = "Get the height of the window.",
description = "Returns the height of the desktop window.",
key = "lovr.graphics.getHeight",
module = "lovr.graphics",
related = {
"lovr.graphics.getWidth",
"lovr.graphics.getDimensions"
},
variants = {
{
arguments = {},
returns = {
{
name = "height",
type = "number",
description = "The height of the window, in pixels."
}
}
}
}
},
{
name = "getLineWidth",
tag = "graphicsState",
summary = "Get the line width.",
description = "Returns the current line width.",
key = "lovr.graphics.getLineWidth",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "width",
type = "number",
description = "The current line width, in pixels."
}
}
}
},
related = {
"lovr.graphics.line"
},
notes = "The default line width is `1.0`."
},
{
name = "getPointSize",
tag = "graphicsState",
summary = "Get the point size.",
description = "Returns the current point size.",
key = "lovr.graphics.getPointSize",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "size",
type = "number",
description = "The current point size, in pixels."
}
}
}
},
related = {
"lovr.graphics.points"
},
notes = "The default point size is `1.0`."
},
{
name = "getPolygonWinding",
tag = "graphicsState",
summary = "Get the winding direction.",
description = "Returns the current polygon winding. The winding direction determines which face of a triangle is the front face and which is the back face. This lets the graphics engine cull the back faces of polygons, improving performance.",
key = "lovr.graphics.getPolygonWinding",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "winding",
type = "PolygonWinding",
description = "The current winding direction."
}
}
}
},
related = {
"lovr.graphics.setCullingEnabled",
"lovr.graphics.isCullingEnabled"
},
notes = "Culling is initially disabled and must be enabled using `lovr.graphics.setCullingEnabled`.\n\nThe default winding direction is counterclockwise."
},
{
name = "getScissor",
tag = "graphicsState",
summary = "Get the scissor rectangle.",
description = "Returns the current scissor. The scissor is a rectangular area of the screen. Any pixels outside the scissor region will be unaffected by drawing operations.",
key = "lovr.graphics.getScissor",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "x",
type = "number",
description = "The x position of the upper left corner of the scissor."
},
{
name = "y",
type = "number",
description = "The y position of the upper left corner of the scissor."
},
{
name = "w",
type = "number",
description = "The width of the scissor in pixels."
},
{
name = "h",
type = "number",
description = "The height of the scissor in pixels."
}
}
}
}
},
{
name = "getShader",
tag = "graphicsState",
summary = "Get the active shader.",
description = "Returns the active shader.",
key = "lovr.graphics.getShader",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "shader",
type = "Shader",
description = "The active shader object, or `nil` if none is active."
}
}
}
}
},
{
name = "getWidth",
tag = "window",
summary = "Get the width of the window.",
description = "Returns the width of the desktop window.",
key = "lovr.graphics.getWidth",
module = "lovr.graphics",
related = {
"lovr.graphics.getHeight",
"lovr.graphics.getDimensions"
},
variants = {
{
arguments = {},
returns = {
{
name = "width",
type = "number",
description = "The width of the window, in pixels."
}
}
}
}
},
{
name = "isCullingEnabled",
tag = "graphicsState",
summary = "Get whether backface culling is enabled.",
description = "Returns whether or not culling is active. Culling is an optimization that avoids rendering the back face of polygons. This improves performance by reducing the number of polygons drawn, but requires that the vertices in triangles are specified in a consistent clockwise or counter clockwise order.",
key = "lovr.graphics.isCullingEnabled",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "isEnabled",
type = "boolean",
description = "Whether or not culling is enabled."
}
}
}
},
notes = "Culling is disabled by default."
},
{
name = "isWireframe",
tag = "graphicsState",
summary = "Get whether wireframe mode is enabled.",
description = "Returns a boolean indicating whether or not wireframe rendering is enabled.",
key = "lovr.graphics.isWireframe",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "isWireframe",
type = "boolean",
description = "Whether or not wireframe rendering is enabled."
}
}
}
},
notes = "Wireframe rendering is initially disabled."
},
{
name = "line",
tag = "graphicsPrimitives",
summary = "Draw lines.",
description = "Draws lines between points. Each point will be connected to the previous point in the list.",
key = "lovr.graphics.line",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "x1",
type = "number",
description = "The x coordinate of the first point."
},
{
name = "y1",
type = "number",
description = "The y coordinate of the first point."
},
{
name = "z1",
type = "number",
description = "The z coordinate of the first point."
},
{
name = "x2",
type = "number",
description = "The x coordinate of the second point."
},
{
name = "y2",
type = "number",
description = "The y coordinate of the second point."
},
{
name = "z2",
type = "number",
description = "The z coordinate of the second point."
},
{
name = "...",
type = "number",
description = "More points."
}
},
returns = {}
},
{
arguments = {
{
name = "points",
type = "table",
description = "A table of point positions, as described above."
}
},
returns = {}
}
}
},
{
name = "newBuffer",
tag = "graphicsObjects",
summary = "Create a new Buffer.",
description = "Creates a new Buffer. You must specify either the capacity for the Buffer or an initial set of vertex data. The draw mode and usage hint can also optionally be specified.",
key = "lovr.graphics.newBuffer",
module = "lovr.graphics",
notes = "Once created, the size of the Buffer can't be changed.",
variants = {
{
arguments = {
{
name = "size",
type = "number",
description = "The maximum number of vertices the Buffer can store."
},
{
name = "mode",
type = "BufferDrawMode",
description = "How the Buffer will render its vertices.",
default = "'fan'"
},
{
name = "usage",
type = "BufferUsage",
description = "How the Buffer will be updated.",
default = "'dynamic'"
}
},
returns = {
{
name = "buffer",
type = "Buffer",
description = "The new Buffer."
}
}
},
{
arguments = {
{
name = "vertices",
type = "table",
description = "A table of vertices. Each vertex is a table containing the vertex data."
},
{
name = "mode",
type = "BufferDrawMode",
description = "How the Buffer will render its vertices.",
default = "'fan'"
},
{
name = "usage",
type = "BufferUsage",
description = "How the Buffer will be updated.",
default = "'dynamic'"
}
},
returns = {
{
name = "buffer",
type = "Buffer",
description = "The new Buffer."
}
}
},
{
description = "These variants accept a custom vertex format. For more info, see the `Buffer` page.",
arguments = {
{
name = "format",
type = "table",
description = "A table describing the attribute format for the vertices."
},
{
name = "size",
type = "number",
description = "The maximum number of vertices the Buffer can store."
},
{
name = "mode",
type = "BufferDrawMode",
description = "How the Buffer will render its vertices.",
default = "'fan'"
},
{
name = "usage",
type = "BufferUsage",
description = "How the Buffer will be updated.",
default = "'dynamic'"
}
},
returns = {
{
name = "buffer",
type = "Buffer",
description = "The new Buffer."
}
}
},
{
arguments = {
{
name = "format",
type = "table",
description = "A table describing the attribute format for the vertices."
},
{
name = "vertices",
type = "table",
description = "A table of vertices. Each vertex is a table containing the vertex data."
},
{
name = "mode",
type = "BufferDrawMode",
description = "How the Buffer will render its vertices.",
default = "'fan'"
},
{
name = "usage",
type = "BufferUsage",
description = "How the Buffer will be updated.",
default = "'dynamic'"
}
},
returns = {
{
name = "buffer",
type = "Buffer",
description = "The new Buffer."
}
}
}
}
},
{
name = "newFont",
tag = "graphicsObjects",
summary = "Create a new Font.",
description = "Creates a new Font. It can be used to render text with `lovr.graphics.print`.\n\nCurrently, the only supported font format is TTF.",
key = "lovr.graphics.newFont",
module = "lovr.graphics",
notes = "Larger font sizes will lead to sharper text at the cost of performance.",
variants = {
{
arguments = {
{
name = "filename",
type = "string",
description = "The filename of the font file."
},
{
name = "size",
type = "number",
description = "The size of the font, in pixels.",
default = "32"
}
},
returns = {
{
name = "font",
type = "Font",
description = "The new Font."
}
}
},
{
description = "Creates a new Font from the default font included with LÖVR (Cabin).",
arguments = {
{
name = "size",
type = "number",
description = "The size of the font, in pixels.",
default = "32"
}
},
returns = {
{
name = "font",
type = "Font",
description = "The new Font."
}
}
}
}
},
{
name = "newModel",
tag = "graphicsObjects",
summary = "Create a new Model.",
description = "Creates a new Model from a file. Most common 3D file formats are supported, such as `3ds`, `blend`, `dae`, `fbx`, `stl`, `obj`, and `glTF`. Models use normals and texture coordinates, if provided.\n\nThe following features are not supported yet: animations, materials, vertex colors.",
key = "lovr.graphics.newModel",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "filename",
type = "string",
description = "The filename of the model to load."
},
{
name = "texture",
type = "string",
description = "A filename for a texture to apply to the Model, or `nil` for no texture.",
default = "nil"
}
},
returns = {
{
name = "model",
type = "Model",
description = "The new Model."
}
}
}
}
},
{
name = "newShader",
tag = "graphicsObjects",
summary = "Create a new Shader.",
description = "Creates a new Shader.",
key = "lovr.graphics.newShader",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "vertex",
type = "string",
description = "The code or filename of the vertex shader. If `nil`, the default vertex shader is used."
},
{
name = "fragment",
type = "string",
description = "The code or filename of the fragment shader. If `nil`, the default fragment shader is used."
}
},
returns = {
{
name = "shader",
type = "Shader",
description = "The new Shader."
}
}
}
}
},
{
name = "newSkybox",
tag = "graphicsObjects",
summary = "Create a new Skybox.",
description = "Creates a new Skybox from a set of 6 images.",
key = "lovr.graphics.newSkybox",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "right",
type = "string",
description = "The filename of the image for the right face of the skybox."
},
{
name = "left",
type = "string",
description = "The filename of the image for the left face of the skybox."
},
{
name = "top",
type = "string",
description = "The filename of the image for the top face of the skybox."
},
{
name = "bottom",
type = "string",
description = "The filename of the image for the bottom face of the skybox."
},
{
name = "back",
type = "string",
description = "The filename of the image for the back face of the skybox."
},
{
name = "front",
type = "string",
description = "The filename of the image for the front face of the skybox."
}
},
returns = {
{
name = "skybox",
type = "Skybox",
description = "The new Skybox."
}
}
},
{
arguments = {
{
name = "images",
type = "table",
description = "A table containing 6 images, as described above."
}
},
returns = {
{
name = "skybox",
type = "Skybox",
description = "The new Skybox."
}
}
}
}
},
{
name = "newTexture",
tag = "graphicsObjects",
summary = "Create a new Texture.",
description = "Creates a new Texture from an image file.",
key = "lovr.graphics.newTexture",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "filename",
type = "string",
description = "The filename of the image to load."
}
},
returns = {
{
name = "texture",
type = "Texture",
description = "The new Texture."
}
}
},
{
arguments = {
{
name = "width",
type = "number",
description = "The width of the Texture, in pixels."
},
{
name = "height",
type = "number",
description = "The height of the Texture, in pixels."
},
{
name = "projection",
type = "TextureProjection",
description = "The type of projection to use when rendering to the Texture."
},
{
name = "msaa",
type = "number",
description = "The number of samples to use for multisample antialiasing.",
default = "0"
}
},
returns = {
{
name = "texture",
type = "Texture",
description = "The new Texture."
}
}
}
}
},
{
name = "origin",
tag = "graphicsTransforms",
summary = "Reset the coordinate system.",
description = "Resets the transformation to the origin.",
key = "lovr.graphics.origin",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {}
}
},
notes = "This is called at the beginning of every frame to reset the coordinate space."
},
{
name = "plane",
tag = "graphicsPrimitives",
summary = "Draw a plane.",
description = "Draws a plane with a given position, size, and orientation.",
key = "lovr.graphics.plane",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "mode",
type = "DrawMode",
description = "How to draw the plane."
},
{
name = "x",
type = "number",
description = "The x coordinate of the center of the plane.",
default = "0"
},
{
name = "y",
type = "number",
description = "The y coordinate of the center of the plane.",
default = "0"
},
{
name = "z",
type = "number",
description = "The z coordinate of the center of the plane.",
default = "0"
},
{
name = "size",
type = "number",
description = "The size of the plane, in meters.",
default = "1"
},
{
name = "nx",
type = "number",
description = "The x coordinate of the normal vector of the plane.",
default = "0"
},
{
name = "ny",
type = "number",
description = "The y coordinate of the normal vector of the plane.",
default = "1"
},
{
name = "nz",
type = "number",
description = "The z coordinate of the normal vector of the plane.",
default = "0"
}
},
returns = {}
},
{
description = "Draw a textured plane.",
arguments = {
{
name = "texture",
type = "Texture",
description = "The texture to apply to the plane."
},
{
name = "x",
type = "number",
description = "The x coordinate of the center of the plane.",
default = "0"
},
{
name = "y",
type = "number",
description = "The y coordinate of the center of the plane.",
default = "0"
},
{
name = "z",
type = "number",
description = "The z coordinate of the center of the plane.",
default = "0"
},
{
name = "size",
type = "number",
description = "The size of the plane, in meters.",
default = "1"
},
{
name = "nx",
type = "number",
description = "The x coordinate of the normal vector of the plane.",
default = "0"
},
{
name = "ny",
type = "number",
description = "The y coordinate of the normal vector of the plane.",
default = "1"
},
{
name = "nz",
type = "number",
description = "The z coordinate of the normal vector of the plane.",
default = "0"
}
},
returns = {}
},
{
description = "Draw a fullscreen textured plane.",
arguments = {
{
name = "texture",
type = "Texture",
description = "The texture to apply to the plane."
}
},
returns = {}
}
}
},
{
name = "points",
tag = "graphicsPrimitives",
summary = "Draw one or more points.",
description = "Draws one or more points.",
key = "lovr.graphics.points",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x coordinate of the point."
},
{
name = "y",
type = "number",
description = "The y coordinate of the point."
},
{
name = "z",
type = "number",
description = "The z coordinate of the point."
},
{
name = "...",
type = "number",
description = "More points."
}
},
returns = {}
},
{
arguments = {
{
name = "points",
type = "table",
description = "A table of points, as described above."
}
},
returns = {}
}
}
},
{
name = "pop",
tag = "graphicsTransforms",
summary = "Pop the current transform off the stack.",
description = "Pops the current transform from the stack, returning to the transformation that was applied before `lovr.graphics.push` was called.",
key = "lovr.graphics.pop",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {}
}
},
related = {
"lovr.graphics.push"
},
notes = "An error is thrown if there isn't a transform to pop. This can happen if you forget to call push before calling pop, or if you have an unbalanced sequence of pushes and pops."
},
{
name = "present",
tag = "window",
summary = "Present a frame to the window.",
description = "Presents the results of pending drawing operations to the window. This is automatically called after `lovr.draw` by the default `lovr.run` function.",
key = "lovr.graphics.present",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {}
}
}
},
{
name = "print",
tag = "graphicsPrimitives",
summary = "Render text.",
description = "Draws text in 3D space using the active font.",
key = "lovr.graphics.print",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "str",
type = "string",
description = "The text to render."
},
{
name = "x",
type = "number",
description = "The x coordinate of the center of the text.",
default = 0
},
{
name = "y",
type = "number",
description = "The y coordinate of the center of the text.",
default = 0
},
{
name = "z",
type = "number",
description = "The z coordinate of the center of the text.",
default = 0
},
{
name = "w",
type = "number",
description = "The maximum width of each line, in meters. Use zero for unlimited.",
default = 0
},
{
name = "h",
type = "number",
description = "The height of each line, in meters.",
default = 0.10000000000000001
},
{
name = "angle",
type = "number",
description = "The number of radians to rotate the text around its rotation axis.",
default = 0
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation.",
default = 0
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation.",
default = 1
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation.",
default = 0
}
},
returns = {}
}
},
related = {
"lovr.graphics.getFont",
"lovr.graphics.setFont",
"lovr.graphics.newFont",
"Font"
},
notes = "Unicode text is supported.\n\nUse `\\n` to add line breaks."
},
{
name = "push",
tag = "graphicsTransforms",
summary = "Push a copy of the current transform onto the stack.",
description = "Pushes a copy of the current transform onto the transformation stack. After changing the transform using `lovr.graphics.translate`, `lovr.graphics.rotate`, and `lovr.graphics.scale`, the original state can be restored using `lovr.graphics.pop`.",
key = "lovr.graphics.push",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {}
}
},
related = {
"lovr.graphics.pop"
},
notes = "An error is thrown if more than 64 matrices are pushed. This can happen accidentally if a push isn't followed by a corresponding pop."
},
{
name = "reset",
tag = "graphicsState",
summary = "Reset all graphics state.",
description = "Resets the graphics state. This includes the coordinate transformation, projection, shader, colors, scissor, and culling state.",
key = "lovr.graphics.reset",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {}
}
}
},
{
name = "rotate",
tag = "graphicsTransforms",
summary = "Rotate the coordinate system.",
description = "Rotates the coordinate system around an axis.\n\nThe rotation will last until `lovr.draw` returns or the transformation is popped off the transformation stack.",
key = "lovr.graphics.rotate",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "angle",
type = "number",
description = "The amount to rotate the coordinate system by, in radians."
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation."
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation."
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation."
}
},
returns = {}
}
},
related = {
"lovr.graphics.scale",
"lovr.graphics.translate",
"lovr.graphics.transform"
},
notes = "Order matters when scaling, translating, and rotating the coordinate system."
},
{
name = "scale",
tag = "graphicsTransforms",
summary = "Scale the coordinate system.",
description = "Scales the coordinate system in 3 dimensions. This will cause objects to appear bigger or smaller.\n\nThe scaling will last until `lovr.draw` returns or the transformation is popped off the transformation stack.",
key = "lovr.graphics.scale",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The amount to scale on the x axis."
},
{
name = "y",
type = "number",
description = "The amount to scale on the y axis."
},
{
name = "z",
type = "number",
description = "The amount to scale on the z axis."
}
},
returns = {}
}
},
related = {
"lovr.graphics.rotate",
"lovr.graphics.translate",
"lovr.graphics.transform"
},
notes = "Order matters when scaling, translating, and rotating the coordinate system."
},
{
name = "setBackgroundColor",
tag = "graphicsState",
summary = "Set the background color.",
description = "Sets the background color used to clear the screen. Color components are from 0 to 255.",
key = "lovr.graphics.setBackgroundColor",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "r",
type = "number",
description = "The red component of the background color."
},
{
name = "g",
type = "number",
description = "The green component of the background color."
},
{
name = "b",
type = "number",
description = "The blue component of the background color."
},
{
name = "a",
type = "number",
description = "The alpha component of the background color.",
default = "255"
}
},
returns = {}
}
},
notes = "The default background color is black."
},
{
name = "setColor",
tag = "graphicsState",
summary = "Set the global color factor.",
description = "Sets the color used for drawing objects. Color components are from 0 to 255. Every pixel drawn will be multiplied (i.e. tinted) by this color. This is a global setting, so it will affect all subsequent drawing operations.",
key = "lovr.graphics.setColor",
module = "lovr.graphics",
notes = "The default color is white.",
variants = {
{
arguments = {
{
name = "r",
type = "number",
description = "The red component of the color."
},
{
name = "g",
type = "number",
description = "The green component of the color."
},
{
name = "b",
type = "number",
description = "The blue component of the color."
},
{
name = "a",
type = "number",
description = "The alpha component of the color.",
default = "255"
}
},
returns = {}
},
{
arguments = {
{
name = "color",
type = "table",
description = "A table containing the color components."
}
},
returns = {}
},
{
arguments = {
{
name = "hex",
type = "number",
description = "An integer containing all four color components."
}
},
returns = {}
}
},
examples = {
{
description = "Draw a red cube.",
code = "function lovr.draw()\n lovr.graphics.setColor(255, 0, 0)\n lovr.graphics.cube('fill', 0, 1.7, -1, .5, lovr.timer.getTime())\nend"
}
}
},
{
name = "setColorMask",
tag = "graphicsState",
summary = "Set the color mask.",
description = "Sets which color channels are affected by drawing operations.",
key = "lovr.graphics.setColorMask",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "r",
type = "boolean",
description = "Whether or not the red channel should be enabled.",
default = "true"
},
{
name = "g",
type = "boolean",
description = "Whether or not the green channel should be enabled.",
default = "true"
},
{
name = "b",
type = "boolean",
description = "Whether or not the blue channel should be enabled.",
default = "true"
},
{
name = "a",
type = "boolean",
description = "Whether or not the alpha channel should be enabled.",
default = "true"
}
},
returns = {}
}
},
notes = "Initially, all color channels are enabled."
},
{
name = "setCullingEnabled",
tag = "graphicsState",
summary = "Enable or disable backface culling.",
description = "Enables or disables culling. Culling is an optimization that avoids rendering the back face of polygons. This improves performance by reducing the number of polygons drawn, but requires that the vertices in triangles are specified in a consistent clockwise or counter clockwise order.",
key = "lovr.graphics.setCullingEnabled",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "isEnabled",
type = "boolean",
description = "Whether or not culling should be enabled."
}
},
returns = {}
}
},
notes = "Culling is disabled by default."
},
{
name = "setDepthTest",
tag = "graphicsState",
summary = "Set or disable the depth test.",
description = "Sets the current depth test. The depth test controls how overlapping objects are rendered.",
key = "lovr.graphics.setDepthTest",
module = "lovr.graphics",
notes = "The default depth test is `less`.",
variants = {
{
description = "Set a new depth test.",
arguments = {
{
name = "compareMode",
type = "CompareMode",
description = "The new depth test."
}
},
returns = {}
},
{
description = "Disable the depth test.",
arguments = {},
returns = {}
}
}
},
{
name = "setFont",
tag = "graphicsState",
summary = "Set the active font.",
description = "Sets the active font used to render text with `lovr.graphics.print`.",
key = "lovr.graphics.setFont",
module = "lovr.graphics",
related = {
"lovr.graphics.print"
},
variants = {
{
arguments = {
{
name = "font",
type = "Font",
description = "The font to use."
}
},
returns = {}
}
}
},
{
name = "setLineWidth",
tag = "graphicsState",
summary = "Set the line width.",
description = "Sets the width of lines rendered using `lovr.graphics.line`.",
key = "lovr.graphics.setLineWidth",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "width",
type = "number",
description = "The new line width, in pixels."
}
},
returns = {}
}
},
related = {
"lovr.graphics.line"
},
notes = "The default line width is `1.0`.\n\nDriver support for line widths is poor. The actual width of lines may be different from what is set here. In particular, some graphics drivers only support a line width of `1.0`."
},
{
name = "setPointSize",
tag = "graphicsState",
summary = "Set the point size.",
description = "Sets the width of drawn points, in pixels.",
key = "lovr.graphics.setPointSize",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "size",
type = "number",
description = "The new point size."
}
},
returns = {}
}
},
related = {
"lovr.graphics.points"
},
notes = "The default point size is `1.0`."
},
{
name = "setPolygonWinding",
tag = "graphicsState",
summary = "Set the winding direction.",
description = "Sets the polygon winding. The winding direction determines which face of a triangle is the front face and which is the back face. This lets the graphics engine cull the back faces of polygons, improving performance. The default is counterclockwise.",
key = "lovr.graphics.setPolygonWinding",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "winding",
type = "PolygonWinding",
description = "The new winding direction."
}
},
returns = {}
}
},
related = {
"lovr.graphics.setCullingEnabled",
"lovr.graphics.isCullingEnabled"
},
notes = "Culling is initially disabled and must be enabled using `lovr.graphics.setCullingEnabled`.\n\nThe default winding direction is counterclockwise."
},
{
name = "setProjection",
tag = "graphicsState",
summary = "Set the camera projection.",
description = "Sets the camera projection. The projection settings define the camera frustum: How wide of a field of view the camera has and how far away the near and far clipping planes are. If an object is outside of this field of view, closer than the near clipping plane, or further away than the far clipping plane, then it will not be rendered.",
key = "lovr.graphics.setProjection",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "near",
type = "number",
description = "How far away the near clipping plane is, in meters."
},
{
name = "far",
type = "number",
description = "How far away the far clipping plane is, in meters."
},
{
name = "fov",
type = "number",
description = "The vertical field of view of the camera, in radians."
}
},
returns = {}
}
}
},
{
name = "setScissor",
tag = "graphicsState",
summary = "Set the scissor rectangle.",
description = "Sets the scissor region. The scissor is a rectangular area of the screen. Any pixels outside the scissor region will be unaffected by drawing operations.",
key = "lovr.graphics.setScissor",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x position of the upper left corner of the scissor."
},
{
name = "y",
type = "number",
description = "The y position of the upper left corner of the scissor."
},
{
name = "w",
type = "number",
description = "The width of the scissor in pixels."
},
{
name = "h",
type = "number",
description = "The height of the scissor in pixels."
}
},
returns = {}
}
}
},
{
name = "setShader",
tag = "graphicsState",
summary = "Set or disable the active shader.",
description = "Sets or disables the Shader used for drawing.",
key = "lovr.graphics.setShader",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "shader",
type = "Shader",
description = "The shader to use."
}
},
returns = {}
},
{
description = "Revert back to the default shader.",
arguments = {},
returns = {}
}
}
},
{
name = "setWireframe",
tag = "graphicsState",
summary = "Enable or disable wireframe rendering.",
description = "Enables or disables wireframe rendering. This is meant to be used as a debugging tool.",
key = "lovr.graphics.setWireframe",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "wireframe",
type = "boolean",
description = "Whether or not wireframe rendering should be enabled."
}
},
returns = {}
}
},
notes = "Wireframe rendering is initially disabled."
},
{
name = "transform",
tag = "graphicsTransforms",
summary = "Apply a general transform to the coordinate system.",
description = "Apply a transform to the coordinate system, changing its translation, rotation, and scale using a single function. A Transform object can also be used.\n\nThe transformation will last until `lovr.draw` returns or the transformation is popped off the transformation stack.",
key = "lovr.graphics.transform",
module = "lovr.graphics",
related = {
"lovr.graphics.rotate",
"lovr.graphics.scale",
"lovr.graphics.translate"
},
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x component of the translation.",
default = 0
},
{
name = "y",
type = "number",
description = "The y component of the translation.",
default = 0
},
{
name = "z",
type = "number",
description = "The z component of the translation.",
default = 0
},
{
name = "scale",
type = "number",
description = "The scale factor.",
default = 1
},
{
name = "angle",
type = "number",
description = "The number of radians to rotate around the rotation axis.",
default = 0
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation.",
default = 0
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation.",
default = 1
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation.",
default = 0
}
},
returns = {}
},
{
description = "Modify the coordinate system using a Transform object.",
arguments = {
{
name = "transform",
type = "Transform",
description = "The Transform to apply to the coordinate system."
}
},
returns = {}
}
}
},
{
name = "translate",
tag = "graphicsTransforms",
summary = "Translate the coordinate system.",
description = "Translates the coordinate system in three dimensions. All graphics operations that use coordinates will behave as if they are offset by the translation value.\n\nThe translation will last until `lovr.draw` returns or the transformation is popped off the transformation stack.",
key = "lovr.graphics.translate",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The amount to translate on the x axis."
},
{
name = "y",
type = "number",
description = "The amount to translate on the y axis."
},
{
name = "z",
type = "number",
description = "The amount to translate on the z axis."
}
},
returns = {}
}
},
related = {
"lovr.graphics.rotate",
"lovr.graphics.scale",
"lovr.graphics.transform"
},
notes = "Order matters when scaling, translating, and rotating the coordinate system."
},
{
name = "triangle",
tag = "graphicsPrimitives",
summary = "Draw a triangle.",
description = "Draws a triangle from three points.",
key = "lovr.graphics.triangle",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "mode",
type = "DrawMode",
description = "How to draw the triangle."
},
{
name = "x1",
type = "number",
description = "The x coordinate of the first point."
},
{
name = "y1",
type = "number",
description = "The y coordinate of the first point."
},
{
name = "z1",
type = "number",
description = "The z coordinate of the first point."
},
{
name = "x2",
type = "number",
description = "The x coordinate of the second point."
},
{
name = "y2",
type = "number",
description = "The y coordinate of the second point."
},
{
name = "z2",
type = "number",
description = "The z coordinate of the second point."
},
{
name = "x3",
type = "number",
description = "The x coordinate of the third point."
},
{
name = "y3",
type = "number",
description = "The y coordinate of the third point."
},
{
name = "z3",
type = "number",
description = "The z coordinate of the third point."
}
},
returns = {}
}
},
notes = "Unlike some of the other primitives, exactly 3 points are required here."
}
},
objects = {
{
name = "Buffer",
summary = "A drawable list of vertices.",
description = "A Buffer is a low-level graphics object that stores and renders a list of vertices.\n\nBuffers are really flexible since you can pack pretty much whatever you want in them. This makes them great for rendering arbitrary geometry, but it also makes them kinda difficult to use since you have to place each vertex yourself.\n\nIt's possible to batch geometry with Buffers too. Instead of drawing a shape 100 times, it's much faster to pack 100 copies of the shape into a Buffer and draw the Buffer once.\n\nBuffers are also a good choice if you have a mesh that changes its shape over time.",
key = "Buffer",
module = "lovr.graphics",
constructors = {
"lovr.graphics.newBuffer"
},
notes = "Each vertex in a buffer can hold several pieces of data. For example, you might want a vertex to keep track of its position, color, and a weight. Each one of these pieces of information is called a vertex **attribute**. A vertex attribute must have a name, a type, and a size. Here's what the \"position\" attribute would look like as a Lua table:\n\n { 'vPosition', 'float', 3 } -- 3 floats for x, y, and z\n\nEvery vertex in a Buffer must have the same set of attributes. We call this set of attributes the **format** of the Buffer, and it's specified as a simple table of attributes. For example, we could represent the format described above as:\n\n {\n { 'vPosition', 'float', 3 },\n { 'vColor', 'byte', 4 },\n { 'vWeight', 'int', 1 }\n }\n\nWhen creating a Buffer, you can give it any format you want, or use the default. The default Buffer format looks like this:\n\n {\n { 'lovrPosition', 'float', 3 },\n { 'lovrNormal', 'float', 3 },\n { 'lovrTexCoord', 'float', 2 }\n }\n\nGreat, so why do we go through the trouble of naming everything in our vertex and saying what type and size it is? The cool part is that we can access this data in a Shader. We can write a vertex Shader that has `in` variables for every vertex attribute in our Buffer:\n\n in vec3 vPosition;\n in vec4 vColor;\n in int vWeight;\n\n vec4 position(mat4 projection, mat4 transform, vec4 vertex) {\n // Here we can access the vPosition, vColor, and vWeight of each vertex in the buffer!\n }\n\nSpecifying custom vertex data is really powerful and is often used for lighting, animation, and more!",
methods = {
{
name = "draw",
summary = "Draw the Buffer.",
description = "Draws the contents of the Buffer.",
key = "Buffer:draw",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x coordinate to draw the Buffer at.",
default = "0"
},
{
name = "y",
type = "number",
description = "The y coordinate to draw the Buffer at.",
default = "0"
},
{
name = "z",
type = "number",
description = "The z coordinate to draw the Buffer at.",
default = "0"
},
{
name = "scale",
type = "number",
description = "The scale to draw the Buffer at.",
default = "1"
},
{
name = "angle",
type = "number",
description = "The angle to rotate the Buffer around its axis of rotation.",
default = "0"
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation.",
default = "0"
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation.",
default = "1"
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation.",
default = "0"
}
},
returns = {}
},
{
arguments = {
{
name = "transform",
type = "Transform",
description = "The transform to apply before drawing."
}
},
returns = {}
}
}
},
{
name = "getDrawMode",
summary = "Get the draw mode of the Buffer.",
description = "Get the draw mode of the Buffer, which controls how the vertices are connected together.",
key = "Buffer:getDrawMode",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "mode",
type = "BufferDrawMode",
description = "The draw mode of the buffer."
}
}
}
}
},
{
name = "getDrawRange",
summary = "Get the draw range of the Buffer.",
description = "Retrieve the current draw range for the buffer. The draw range is a subset of the vertices of the buffer that will be drawn.",
key = "Buffer:getDrawRange",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "start",
type = "number",
description = "The index of the first vertex that will be drawn, or `nil` if no draw range is set."
},
{
name = "count",
type = "number",
description = "The number of vertices that will be drawn, or `nil` if no draw range is set."
}
}
}
}
},
{
name = "getTexture",
summary = "Get the Texture applied to the Buffer.",
description = "Get the Texture applied to the Buffer.",
key = "Buffer:getTexture",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "texture",
type = "Texture",
description = "The current texture applied to the Buffer."
}
}
}
}
},
{
name = "getVertex",
summary = "Get a single vertex in the Buffer.",
description = "Gets the data for a single vertex in the Buffer. The set of data returned depends on the Buffer's vertex format. The default vertex format consists of 8 floating point numbers: the vertex position, the vertex normal, and the texture coordinates.",
key = "Buffer:getVertex",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "index",
type = "number",
description = "The index of the vertex to retrieve."
}
},
returns = {
{
name = "...",
type = "number",
description = "All attributes of the vertex."
}
}
}
}
},
{
name = "getVertexAttribute",
summary = "Get an attribute of a single vertex in the Buffer.",
description = "Get the components of a specific attribute of a single vertex in the Buffer.",
key = "Buffer:getVertexAttribute",
module = "lovr.graphics",
notes = "Buffers without a custom format have the vertex position as their first attribute, the normal vector as the second attribute, and the texture coordinate as the third attribute.",
variants = {
{
arguments = {
{
name = "index",
type = "number",
description = "The index of the vertex to retrieve the attribute of."
},
{
name = "attribute",
type = "number",
description = "The index of the attribute to retrieve the components of."
}
},
returns = {
{
name = "...",
type = "number",
description = "The components of the vertex attribute."
}
}
}
}
},
{
name = "getVertexCount",
summary = "Get the number of vertices the Buffer can hold.",
description = "Returns the maximum number of vertices the Buffer can hold.",
key = "Buffer:getVertexCount",
module = "lovr.graphics",
notes = "The size can only be set when creating the Buffer, and cannot be changed afterwards.",
variants = {
{
arguments = {},
returns = {
{
name = "size",
type = "number",
description = "The number of vertices the Buffer can hold."
}
}
}
}
},
{
name = "getVertexFormat",
summary = "Get the vertex format of the Buffer.",
description = "Get the format table of the Buffer's vertices. The format table describes the set of data that each vertex contains.",
key = "Buffer:getVertexFormat",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "format",
type = "table",
description = "The table of vertex attributes. Each attribute is a table containing the name of the attribute, the data type, and the number of components."
}
}
}
}
},
{
name = "getVertexMap",
summary = "Get the current vertex map of the Buffer.",
description = "Returns the current vertex map for the buffer. The vertex map is a list of indices in the buffer, allowing the reordering or reuse of vertices.",
key = "Buffer:getVertexMap",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "map",
type = "table",
description = "The list of indices in the vertex map, or `nil` if no vertex map is set."
}
}
}
}
},
{
name = "setDrawMode",
summary = "Change the draw mode of the Buffer.",
description = "Set a new draw mode for the Buffer.",
key = "Buffer:setDrawMode",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "mode",
type = "BufferDrawMode",
description = "The new draw mode for the Buffer."
}
},
returns = {}
}
}
},
{
name = "setDrawRange",
summary = "Set the draw range of the Buffer.",
description = "Set the draw range for the Buffer. The draw range is a subset of the vertices of the buffer that will be drawn.",
key = "Buffer:setDrawRange",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "start",
type = "number",
description = "The first vertex that will be drawn."
},
{
name = "count",
type = "number",
description = "The number of vertices that will be drawn."
}
},
returns = {}
}
}
},
{
name = "setTexture",
summary = "Apply a Texture to the Buffer.",
description = "Applies a Texture to the Buffer.",
key = "Buffer:setTexture",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "texture",
type = "Texture",
description = "The new texture."
}
},
returns = {}
}
}
},
{
name = "setVertex",
summary = "Update a single vertex in the Buffer.",
description = "Update a single vertex in the Buffer.",
key = "Buffer:setVertex",
module = "lovr.graphics",
notes = "Any unspecified components will be set to 0 for float and int attributes, or 255 for byte attributes.",
variants = {
{
arguments = {
{
name = "index",
type = "number",
description = "The index of the vertex to set."
},
{
name = "...",
type = "number",
description = "The attributes of the vertex."
}
},
returns = {}
},
{
arguments = {
{
name = "index",
type = "number",
description = "The index of the vertex to set."
},
{
name = "vertexData",
type = "table",
description = "A table containing the attributes of the vertex."
}
},
returns = {}
}
},
examples = {
{
description = "Set the position of a vertex:",
code = "function lovr.load()\n buffer = lovr.graphics.newBuffer({\n { -1, 1, 0, 0, 0, 1, 0, 0 },\n { 1, 1, 0, 0, 0, 1, 1, 0 },\n { -1, -1, 0, 0, 0, 1, 0, 1 },\n { 1, -1, 0, 0, 0, 1, 1, 1 }\n }, 'strip')\n\n buffer:setVertex(2, { 7, 7, 7 })\n print(buffer:getVertex(2)) -- 7, 7, 7, 0, 0, 0, 0, 0\nend"
}
}
},
{
name = "setVertexAttribute",
summary = "Update a specific attribute of a single vertex in the Buffer.",
description = "Set the components of a specific attribute of a vertex in the Buffer.",
key = "Buffer:setVertexAttribute",
module = "lovr.graphics",
notes = "Buffers without a custom format have the vertex position as their first attribute, the normal vector as the second attribute, and the texture coordinate as the third attribute.",
variants = {
{
arguments = {
{
name = "index",
type = "number",
description = "The index of the vertex to update."
},
{
name = "attribute",
type = "number",
description = "The index of the attribute to update."
},
{
name = "...",
type = "number",
description = "Thew new components for the attribute."
}
},
returns = {}
}
}
},
{
name = "setVertexMap",
summary = "Set the vertex map of the Buffer.",
description = "Sets the vertex map. The vertex map is a list of indices in the buffer, allowing the reordering or reuse of vertices.\n\nOften, a vertex map is used to improve performance, since it usually requires less data to specify the index of a vertex than it does to specify all of the data for a vertex.",
key = "Buffer:setVertexMap",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "map",
type = "table",
description = "The new vertex map. Each element of the table is an index of a vertex."
}
},
returns = {}
}
}
},
{
name = "setVertices",
summary = "Update multiple vertices in the Buffer.",
description = "Update multiple vertices in the Buffer.",
key = "Buffer:setVertices",
module = "lovr.graphics",
notes = "The number of vertices in the table should not exceed the maximum size of the Buffer.",
variants = {
{
arguments = {
{
name = "vertices",
type = "table",
description = "The new set of vertices."
}
},
returns = {}
}
}
}
},
examples = {
{
description = "Draw a circle using a Buffer.",
code = "function lovr.load()\n local x, y, z = 0, 1, -2\n local radius = .3\n local points = 40\n\n -- A table to hold the Buffer data\n local vertices = {}\n\n for i = 0, points do\n local angle = i / points * 2 * math.pi\n local vx = x + math.cos(angle)\n local vy = y + math.sin(angle)\n table.insert(vertices, { vx, vy, z })\n end\n\n buffer = lovr.graphics.newBuffer(vertices, 'fan')\nend\n\nfunction lovr.draw()\n buffer:draw()\nend"
}
}
},
{
name = "Font",
summary = "A loaded font used to render text.",
description = "A Font is an object created from a TTF file. It can be used to render text with `lovr.graphics.print`.",
key = "Font",
module = "lovr.graphics",
methods = {
{
name = "getLineHeight",
summary = "Get the line height of the Font.",
description = "Returns the current line height of the Font. The default is 1.0.",
key = "Font:getLineHeight",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "lineHeight",
type = "number",
description = "The line height."
}
}
}
}
},
{
name = "setLineHeight",
summary = "Set the line height of the Font.",
description = "Sets the line height of the Font, which controls how far lines apart lines are vertically separated. This value is a ratio and the default is 1.0.",
key = "Font:setLineHeight",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "lineHeight",
type = "number",
description = "The new line height."
}
},
returns = {}
}
}
}
},
constructors = {
"lovr.graphics.newFont"
}
},
{
name = "Model",
summary = "An asset imported from a 3D model file.",
description = "A Model is a drawable object loaded from a 3D file format. Most common 3D file formats are supported, such as `3ds`, `blend`, `dae`, `fbx`, `stl`, `obj`, and `glTF`. Models will use normals and texture coordinates, if provided.\n\nThe following advanced features are not supported yet: animations, materials, and vertex colors.",
key = "Model",
module = "lovr.graphics",
examples = {
{
code = "local model\n\nfunction lovr.load()\n model = lovr.graphics.newModel('assets/model.fbx', 'assets/texture.png')\nend\n\nfunction lovr.draw()\n model:draw(0, 1, -1, 1, lovr.timer.getTime())\nend"
}
},
constructors = {
"lovr.graphics.newModel",
"Controller:newModel"
},
methods = {
{
name = "draw",
summary = "Draw the Model.",
description = "Draw the Model.",
key = "Model:draw",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x coordinate to draw the Model at.",
default = "0"
},
{
name = "y",
type = "number",
description = "The y coordinate to draw the Model at.",
default = "0"
},
{
name = "z",
type = "number",
description = "The z coordinate to draw the Model at.",
default = "0"
},
{
name = "scale",
type = "number",
description = "The scale to draw the Model at.",
default = "1"
},
{
name = "angle",
type = "number",
description = "The angle to rotate the Model around its axis of rotation.",
default = "0"
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation.",
default = "0"
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation.",
default = "1"
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation.",
default = "0"
}
},
returns = {}
},
{
arguments = {
{
name = "transform",
type = "Transform",
description = "The transform to apply before drawing."
}
},
returns = {}
}
}
},
{
name = "getTexture",
summary = "Get the Texture applied to the Model.",
description = "Get the Texture applied to the Model.",
key = "Model:getTexture",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "texture",
type = "Texture",
description = "The current texture applied to the Model."
}
}
}
}
},
{
name = "setTexture",
summary = "Apply a Texture to the Model.",
description = "Apply a Texture to the Model.",
key = "Model:setTexture",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "texture",
type = "Texture",
description = "The texture to apply to the Model."
}
},
returns = {}
}
}
}
}
},
{
name = "Shader",
summary = "A GLSL program used for low-level control over rendering.",
description = "Shaders are GLSL programs that transform the way vertices and pixels show up on the screen. They can be used for lighting, postprocessing, particles, animation, and much more. You can use `lovr.graphics.setShader` to change the active Shader.",
key = "Shader",
module = "lovr.graphics",
constructors = {
"lovr.graphics.newShader"
},
notes = "The current GLSL version used is 150.\n\nThe default vertex shader:\n\n vec4 position(mat4 projection, mat4 transform, vec4 vertex) {\n return projection * transform * vertex;\n }\n\nThe default fragment shader:\n\n vec4 color(vec4 graphicsColor, sampler2D image, vec2 uv) {\n return graphicsColor * texture(image, uv);\n }\n\nAdditionally, the following headers are prepended to the shader source, giving you convenient access to a default set of uniform variables and vertex attributes.\n\nVertex shader header:\n\n uniform mat4 lovrTransform;\n uniform mat4 lovrProjection;\n in vec3 lovrPosition;\n in vec3 lovrNormal;\n in vec2 lovrTexCoord;\n out vec2 texCoord;\n\nFragment shader header:\n\n uniform vec4 lovrColor;\n uniform sampler2D lovrTexture;\n in vec2 texCoord;\n in vec4 gl_FragCoord;\n out vec4 lovrFragColor;",
methods = {
{
name = "send",
summary = "Update a uniform variable in the Shader.",
description = "Update a uniform variable in the Shader.",
key = "Shader:send",
module = "lovr.graphics",
notes = "The shader does not need to be active to update its uniforms. However, the types must match up. Uniform variables declared as `float`s must be sent a single number, whereas uniforms declared as `vec4`s must be sent a table containing 4 numbers, etc.\n\nAn error is thrown if the uniform does not exist or is not used in the shader.",
variants = {
{
arguments = {
{
name = "uniform",
type = "string",
description = "The name of the uniform to update."
},
{
name = "value",
type = "*",
description = "The new value of the uniform."
}
},
returns = {}
}
},
examples = {
{
description = "Updating a `vec3` uniform:",
code = "function lovr.load()\n shader = lovr.graphics.newShader [[\n uniform vec3 offset;\n vec4 position(mat4 projection, mat4 transform, vec4 vertex) {\n vertex.xyz += offset;\n return projection * transform * vertex;\n }\n ]]\n\n shader:send('offset', { .3, .7, 0 })\nend"
}
}
}
},
examples = {
{
description = "Set a simple shader that colors pixels based on vertex normals.",
code = "function lovr.load()\n lovr.graphics.setShader(lovr.graphics.newShader([[\n out vec3 vNormal; // This gets passed to the fragment shader\n\n vec4 position(mat4 projection, mat4 transform, vec4 vertex) {\n vNormal = lovrNormal;\n return projection * transform * vertex;\n }\n ]], [[\n in vec3 vNormal; // This gets passed from the vertex shader\n\n vec4 color(vec4 graphicsColor, sampler2D image, vec2 uv) {\n return vec4(vNormal * .5 + .5, 1.0);\n }\n ]]))\n\n model = lovr.graphics.newModel('model.fbx')\nend\n\nfunction lovr.draw()\n model:draw(x, y, z, 1)\nend"
}
}
},
{
name = "Skybox",
summary = "A cube wrapped around the camera, used as a 3D background.",
description = "A Skybox is a collection of six images used to apply a background to a three dimensional scene. Each image is used to texture the face of a cube, and the cube is drawn around the camera, giving an illusion of a 360-degree background.",
key = "Skybox",
module = "lovr.graphics",
constructors = {
"lovr.graphics.newSkybox"
},
notes = "To prevent problems with the depth test, make sure you draw Skyboxes before drawing other things, or disable the depth test while drawing them.",
methods = {
{
name = "draw",
summary = "Draw the Skybox.",
description = "Draws the Skybox at a specified angle.",
key = "Skybox:draw",
module = "lovr.graphics",
notes = "To prevent problems with the depth test, make sure you draw Skyboxes before drawing other things, or disable the depth test while drawing them.",
variants = {
{
arguments = {
{
name = "angle",
type = "number",
description = "The number of radians to rotate the skybox around its axis of rotation"
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation."
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation."
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation."
}
},
returns = {}
}
}
}
},
examples = {
{
description = "Drawing a Skybox in VR:",
code = "function lovr.load()\n skybox = lovr.graphics.newSkybox({\n '1.png',\n '2.png',\n '3.png',\n '4.png',\n '5.png',\n '6.png'\n })\nend\n\nfunction lovr.draw()\n lovr.graphics.setColor(255, 255, 255)\n skybox:draw(lovr.headset.getOrientation())\n\n -- Draw everything else\nend"
}
}
},
{
name = "Texture",
summary = "An image that can be applied to Buffers and Models.",
description = "A Texture is an image that can be applied to `Model`s and `Buffer`s. Supported file formats include `.png`, `.jpg`, `.tga`, and `.bmp`.",
key = "Texture",
module = "lovr.graphics",
methods = {
{
name = "getDimensions",
summary = "Get the dimensions of the Texture.",
description = "Returns the dimensions of the Texture.",
key = "Texture:getDimensions",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "width",
type = "number",
description = "The width of the Texture, in pixels."
},
{
name = "height",
type = "number",
description = "The height of the Texture, in pixels."
}
}
}
}
},
{
name = "getFilter",
summary = "Get the FilterMode for the Texture.",
description = "Returns the current FilterMode for the Texture.",
key = "Texture:getFilter",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "min",
type = "FilterMode",
description = "The filter mode used for minification."
},
{
name = "mag",
type = "FilterMode",
description = "The filter mode used for magnification."
}
}
}
}
},
{
name = "getHeight",
summary = "Get the height of the Texture.",
description = "Returns the height of the Texture.",
key = "Texture:getHeight",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "height",
type = "number",
description = "The height of the Texture, in pixels."
}
}
}
}
},
{
name = "getWidth",
summary = "Get the width of the Texture.",
description = "Returns the width of the Texture.",
key = "Texture:getWidth",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "width",
type = "number",
description = "The width of the Texture, in pixels."
}
}
}
}
},
{
name = "getWrap",
summary = "Get the WrapMode for the Texture.",
description = "Returns the current WrapMode for the Texture.",
key = "Texture:getWrap",
module = "lovr.graphics",
variants = {
{
arguments = {},
returns = {
{
name = "horizontal",
type = "WrapMode",
description = "How the texture wraps horizontally."
},
{
name = "vertical",
type = "WrapMode",
description = "How the texture wraps vertically."
}
}
}
}
},
{
name = "renderTo",
summary = "Render to a Texture.",
description = "Renders to a Texture using a function. The Texture must be created as a framebuffer by passing a width and height to `lovr.graphics.newTexture` instead of a filename.",
key = "Texture:renderTo",
module = "lovr.graphics",
notes = "Make sure you clear the contents of the Texture before rendering to it to clear any previous contents.",
variants = {
{
arguments = {
{
name = "callback",
type = "function",
description = "A function that calls drawing commands to render to the Texture."
}
},
returns = {}
}
}
},
{
name = "setFilter",
summary = "Set the FilterMode for the Texture.",
description = "Sets the `FilterMode` used by the texture when upsampling or downsampling. The default mode is `linear`.",
key = "Texture:setFilter",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "min",
type = "FilterMode",
description = "The filter mode used for minification."
},
{
name = "mag",
type = "FilterMode",
description = "The filter mode used for magnification.",
default = "min"
}
},
returns = {}
}
}
},
{
name = "setWrap",
summary = "Set the WrapMode for the Texture.",
description = "Sets the wrap mode of a texture. The wrap mode controls how the texture is sampled when texture coordinates lie outside the usual 0 - 1 range. The default for both directions is `repeat`.",
key = "Texture:setWrap",
module = "lovr.graphics",
variants = {
{
arguments = {
{
name = "horizontal",
type = "WrapMode",
description = "How the texture should wrap horizontally."
},
{
name = "vertical",
type = "WrapMode",
description = "How the texture should wrap vertically.",
default = "horizontal"
}
},
returns = {}
}
}
}
},
constructors = {
"lovr.graphics.newTexture"
}
}
}
},
{
name = "headset",
tag = "modules",
summary = "Connects to VR hardware.",
description = "The `lovr.headset` module is where all the magical VR functionality is. With it, you can access connected VR hardware and get information about the available space the player has. Note that all units are reported in meters. Position `(0, 0, 0)` is the center of the play area.",
key = "lovr.headset",
sections = {
{
name = "Headset",
tag = "headset",
description = "Functions that return information about the head mounted display (HMD) currently strapped to the player's face."
},
{
name = "Play area",
tag = "playArea",
description = "Retrieve information about the size and shape of the room the player is in, and provides information about the \"chaperone\", a visual indicator that appears whenever a player is about to run into a wall."
},
{
name = "Controllers",
tag = "controllers",
description = "Get a list of connected `Controller`s. Also see `lovr.controlleradded` and `lovr.controllerremoved`."
}
},
enums = {
{
name = "ControllerAxis",
description = "Axes on a Controller.",
key = "ControllerAxis",
module = "headset",
values = {
{
name = "trigger",
description = "The trigger."
},
{
name = "touchx",
description = "The x axis of the touchpad. Positive values are to the right."
},
{
name = "touchy",
description = "The y axis of the touchpad. Positive values are upwards."
}
}
},
{
name = "ControllerButton",
description = "Buttons on a Controller.",
key = "ControllerButton",
module = "headset",
values = {
{
name = "system",
description = "The system button."
},
{
name = "menu",
description = "The menu button."
},
{
name = "grip",
description = "The grip button."
},
{
name = "touchpad",
description = "The button on the touchpad."
}
}
},
{
name = "HeadsetEye",
summary = "The two different eyes.",
description = "Represents either the left eye or the right eye.",
key = "HeadsetEye",
module = "headset",
values = {
{
name = "left",
description = "The left eye."
},
{
name = "right",
description = "The right eye."
}
}
}
},
functions = {
{
name = "getAngularVelocity",
tag = "headset",
summary = "Get the angular velocity of the headset.",
description = "Returns the current angular velocity of the headset.",
key = "lovr.headset.getAngularVelocity",
module = "lovr.headset",
related = {
"lovr.headset.getOrientation",
"lovr.headset.getVelocity",
"lovr.headset.getPosition"
},
variants = {
{
arguments = {},
returns = {
{
name = "x",
type = "number",
description = "The x component of the angular velocity."
},
{
name = "y",
type = "number",
description = "The y component of the angular velocity."
},
{
name = "z",
type = "number",
description = "The z component of the angular velocity."
}
}
}
}
},
{
name = "getBoundsDepth",
tag = "playArea",
summary = "Get the depth of the play area.",
description = "Returns the depth of the play area, in meters.",
key = "lovr.headset.getBoundsDepth",
module = "lovr.headset",
related = {
"lovr.headset.getBoundsWidth",
"lovr.headset.getBoundsDimensions"
},
variants = {
{
arguments = {},
returns = {
{
name = "depth",
type = "number",
description = "The depth of the play area, in meters."
}
}
}
}
},
{
name = "getBoundsDimensions",
tag = "playArea",
summary = "Get the size of the play area.",
description = "Returns the size of the play area, in meters.",
key = "lovr.headset.getBoundsDimensions",
module = "lovr.headset",
related = {
"lovr.headset.getBoundsWidth",
"lovr.headset.getBoundsDepth"
},
variants = {
{
arguments = {},
returns = {
{
name = "width",
type = "number",
description = "The width of the play area, in meters."
},
{
name = "depth",
type = "number",
description = "The depth of the play area, in meters."
}
}
}
}
},
{
name = "getBoundsGeometry",
tag = "playArea",
summary = "Get a list of points that make up the play area boundary.",
description = "Returns a list of points representing the boundaries of the play area.",
key = "lovr.headset.getBoundsGeometry",
module = "lovr.headset",
variants = {
{
arguments = {},
returns = {
{
name = "points",
type = "table",
description = "A list of points representing the play area. Each point is a table consisting of an x, y, and z coordinate."
}
}
}
}
},
{
name = "getBoundsWidth",
tag = "playArea",
summary = "Get the width of the play area.",
description = "Returns the width of the play area, in meters.",
key = "lovr.headset.getBoundsWidth",
module = "lovr.headset",
related = {
"lovr.headset.getBoundsDepth",
"lovr.headset.getBoundsDimensions"
},
variants = {
{
arguments = {},
returns = {
{
name = "width",
type = "number",
description = "The width of the play area, in meters."
}
}
}
}
},
{
name = "getClipDistance",
tag = "headset",
summary = "Get the near and far clipping planes of the headset.",
description = "Returns the near and far clipping planes used to render to the headset. Objects closer than the near clipping plane or further than the far clipping plane will be clipped out of view.",
key = "lovr.headset.getClipDistance",
module = "lovr.headset",
variants = {
{
arguments = {},
returns = {
{
name = "near",
type = "number",
description = "The distance to the near clipping plane, in meters."
},
{
name = "far",
type = "number",
description = "The distance to the far clipping plane, in meters."
}
}
}
}
},
{
name = "getControllerCount",
tag = "controllers",
summary = "Get the number of currently connected controller objects.",
description = "Returns the number of currently connected controllers.",
key = "lovr.headset.getControllerCount",
module = "lovr.headset",
related = {
"lovr.headset.getControllers"
},
variants = {
{
arguments = {},
returns = {
{
name = "count",
type = "number",
description = "The number of currently connected controllers."
}
}
}
}
},
{
name = "getControllers",
tag = "controllers",
summary = "Get a list of currently connected controller objects.",
description = "Returns a list of currently connected controllers.",
key = "lovr.headset.getControllers",
module = "lovr.headset",
related = {
"lovr.headset.getControllerCount"
},
variants = {
{
arguments = {},
returns = {
{
name = "controllers",
type = "table",
description = "A list of Controller objects."
}
}
}
}
},
{
name = "getDisplayDimensions",
tag = "headset",
summary = "Get the dimensions of the headset display.",
description = "Returns the dimensions of the display for each lens of the headset, in pixels.",
key = "lovr.headset.getDisplayDimensions",
module = "lovr.headset",
related = {
"lovr.headset.getDisplayWidth",
"lovr.headset.getDisplayHeight"
},
variants = {
{
arguments = {},
returns = {
{
name = "width",
type = "number",
description = "The width of each lens."
},
{
name = "height",
type = "number",
description = "The height of each lens."
}
}
}
}
},
{
name = "getDisplayHeight",
tag = "headset",
summary = "Get the height of the headset display.",
description = "Returns the height of the display for each lens of the headset, in pixels.",
key = "lovr.headset.getDisplayHeight",
module = "lovr.headset",
related = {
"lovr.headset.getDisplayWidth",
"lovr.headset.getDisplayDimensions"
},
variants = {
{
arguments = {},
returns = {
{
name = "height",
type = "number",
description = "The height of each lens."
}
}
}
}
},
{
name = "getDisplayWidth",
tag = "headset",
summary = "Get the width of the headset display.",
description = "Returns the width of the display for each lens of the headset, in pixels.",
key = "lovr.headset.getDisplayWidth",
module = "lovr.headset",
related = {
"lovr.headset.getDisplayHeight",
"lovr.headset.getDisplayDimensions"
},
variants = {
{
arguments = {},
returns = {
{
name = "width",
type = "number",
description = "The width of each lens."
}
}
}
}
},
{
name = "getEyePosition",
tag = "headset",
summary = "Get the position of an eye.",
description = "Returns the current position of one of the eyes in 3D space.",
key = "lovr.headset.getEyePosition",
module = "lovr.headset",
related = {
"lovr.headset.getPosition"
},
variants = {
{
arguments = {
{
name = "eye",
type = "HeadsetEye",
description = "The eye to get the position of."
}
},
returns = {
{
name = "x",
type = "number",
description = "The x position of the eye."
},
{
name = "y",
type = "number",
description = "The y position of the eye."
},
{
name = "z",
type = "number",
description = "The z position of the eye."
}
}
}
}
},
{
name = "getOrientation",
tag = "headset",
summary = "Get the orientation of the headset.",
description = "Returns the current orientation of the headset.",
key = "lovr.headset.getOrientation",
module = "lovr.headset",
related = {
"lovr.headset.getPosition",
"lovr.headset.getVelocity",
"lovr.headset.getAngularVelocity"
},
variants = {
{
arguments = {},
returns = {
{
name = "angle",
type = "number",
description = "The number of radians the headset is rotated around its axis of rotation."
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation."
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation."
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation."
}
}
}
}
},
{
name = "getPosition",
tag = "headset",
summary = "Get the position of the headset.",
description = "Returns the current position of the headset.",
key = "lovr.headset.getPosition",
module = "lovr.headset",
related = {
"lovr.headset.getOrientation",
"lovr.headset.getVelocity",
"lovr.headset.getAngularVelocity"
},
variants = {
{
arguments = {},
returns = {
{
name = "x",
type = "number",
description = "The x position of the headset."
},
{
name = "y",
type = "number",
description = "The y position of the headset."
},
{
name = "z",
type = "number",
description = "The z position of the headset."
}
}
}
}
},
{
name = "getType",
tag = "headset",
summary = "Get the type of connected headset.",
description = "Get the type of headset. Currently only the HTC Vive is supported, though support for the Oculus Rift and other devices is planned.",
key = "lovr.headset.getType",
module = "lovr.headset",
variants = {
{
arguments = {},
returns = {
{
name = "type",
type = "string",
description = "The type of the headset as a string, e.g. \"Vive\" for the HTC Vive."
}
}
}
}
},
{
name = "getVelocity",
tag = "headset",
summary = "Get the linear velocity of the headset.",
description = "Returns the current linear velocity of the headset, in meters per second",
key = "lovr.headset.getVelocity",
module = "lovr.headset",
related = {
"lovr.headset.getPosition",
"lovr.headset.getOrientation",
"lovr.headset.getAngularVelocity"
},
variants = {
{
arguments = {},
returns = {
{
name = "vx",
type = "number",
description = "The x component of the linear velocity."
},
{
name = "vy",
type = "number",
description = "The y component of the linear velocity."
},
{
name = "vz",
type = "number",
description = "The z component of the linear velocity."
}
}
}
}
},
{
name = "isBoundsVisible",
tag = "playArea",
summary = "Get whether the chaperone is currently visible.",
description = "Returns whether or not the boundary indicator is visible, indicating that the user is near the edge of the play area.",
key = "lovr.headset.isBoundsVisible",
module = "lovr.headset",
variants = {
{
arguments = {},
returns = {
{
name = "isVisible",
type = "boolean",
description = "Whether or not the bounds are visible."
}
}
}
}
},
{
name = "isPresent",
tag = "headset",
summary = "Get whether or not a headset is connected.",
description = "Determine if a headset is present and ready to use.",
key = "lovr.headset.isPresent",
module = "lovr.headset",
related = {
"Controller:isPresent"
},
variants = {
{
arguments = {},
returns = {
{
name = "isPresent",
type = "boolean",
description = "Whether or not a headset is present."
}
}
}
}
},
{
name = "renderTo",
tag = "headset",
summary = "Render to the headset using a function.",
description = "Renders to each eye of the headset using a function.\n\nThis function takes care of setting the appropriate graphics transformations to ensure that the scene is rendered as though it is being viewed through each eye of the player. It also takes care of setting the correct projection for the headset lenses.\n\nIf the headset module is enabled, this function is called automatically by `lovr.run` with `lovr.draw` as the callback.",
key = "lovr.headset.renderTo",
module = "lovr.headset",
variants = {
{
arguments = {
{
name = "callback",
type = "function",
description = "The function used to render. It will be passed a string representing the current eye that is being rendered to, either \"left\" or \"right\".",
arguments = {
{
name = "eye",
type = "HeadsetEye"
}
},
returns = {}
}
},
returns = {}
}
}
},
{
name = "setBoundsVisible",
tag = "playArea",
summary = "Request that the chaperone be shown or hidden.",
description = "Requests that the boundary indicator be shown or hidden.",
key = "lovr.headset.setBoundsVisible",
module = "lovr.headset",
variants = {
{
arguments = {
{
name = "visible",
type = "boolean",
description = "Whether the bounds should be visible or invisible."
}
},
returns = {}
}
}
},
{
name = "setClipDistance",
tag = "headset",
summary = "Set the near and far clipping planes of the headset.",
description = "Sets the near and far clipping planes used to render to the headset. Objects closer than the near clipping plane or further than the far clipping plane will be clipped out of view.",
key = "lovr.headset.setClipDistance",
module = "lovr.headset",
variants = {
{
arguments = {
{
name = "near",
type = "number",
description = "The distance to the near clipping plane, in meters."
},
{
name = "far",
type = "number",
description = "The distance to the far clipping plane, in meters."
}
},
returns = {}
}
}
}
},
objects = {
{
name = "Controller",
summary = "An object used to interact with connected VR controllers.",
description = "Controller objects represent the controllers held in players' hands. To obtain a list of currently connected controllers, use `lovr.headset.getControllers`. To determine when controllers are added and removed, use `lovr.controlleradded` and `lovr.controllerremoved`. Often Controllers won't be considered \"active\" until they are moved around a bit.",
key = "Controller",
module = "lovr.headset",
examples = {
{
description = "Draw cubes for the controllers and vibrate them if the trigger is pressed.",
code = "function lovr.update(dt)\n for i, controller in ipairs(lovr.headset.getControllers()) do\n if controller:getAxis('trigger') > .9 then\n controller:vibrate(.004)\n end\n end\nend\n\nfunction lovr.draw()\n for i, controller in ipairs(lovr.headset.getControllers()) do\n local x, y, z = controller:getPosition()\n local angle, ax, ay, az = controller:getOrientation()\n lovr.graphics.cube('fill', x, y, z, .08, angle, ax, ay, az)\n end\nend"
}
},
methods = {
{
name = "getAxis",
summary = "Get the state of an axis on the Controller.",
description = "Get the current state of an axis on the Controller. Axis values are from 0 to 1.",
key = "Controller:getAxis",
module = "lovr.headset",
related = {
"ControllerAxis",
"Controller:isDown"
},
variants = {
{
arguments = {
{
name = "axis",
type = "ControllerAxis",
description = "The axis to query."
}
},
returns = {
{
name = "value",
type = "number",
description = "The current state of the axis."
}
}
}
}
},
{
name = "getOrientation",
summary = "Get the orientation of the Controller.",
description = "Returns the current orientation of the Controller.",
key = "Controller:getOrientation",
module = "lovr.headset",
related = {
"lovr.headset.getOrientation",
"Controller:getPosition"
},
variants = {
{
arguments = {},
returns = {
{
name = "angle",
type = "number",
description = "The number of radians the Controller is rotated around its axis of rotation."
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation."
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation."
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation."
}
}
}
}
},
{
name = "getPosition",
summary = "Get the position of the Controller.",
description = "Returns the current position of the Controller.",
key = "Controller:getPosition",
module = "lovr.headset",
related = {
"lovr.headset.getPosition",
"Controller:getOrientation"
},
variants = {
{
arguments = {},
returns = {
{
name = "x",
type = "number",
description = "The x position of the Controller."
},
{
name = "y",
type = "number",
description = "The y position of the Controller."
},
{
name = "z",
type = "number",
description = "The z position of the Controller."
}
}
}
},
notes = "Units are in meters."
},
{
name = "isDown",
summary = "Get the state of a button on the Controller.",
description = "Check if a button on the Controller is currently pressed.",
key = "Controller:isDown",
module = "lovr.headset",
related = {
"ControllerButton",
"Controller:getAxis"
},
variants = {
{
arguments = {
{
name = "button",
type = "ControllerButton",
description = "The button to query."
}
},
returns = {
{
name = "down",
type = "boolean",
description = "The current state of the button."
}
}
}
}
},
{
name = "isPresent",
summary = "Determine if the Controller is still connected.",
description = "Determine if the Controller is still connected.",
key = "Controller:isPresent",
module = "lovr.headset",
related = {
"lovr.headset.isPresent"
},
variants = {
{
arguments = {},
returns = {
{
name = "isPresent",
type = "boolean",
description = "Whether or not the Controller is connected."
}
}
}
}
},
{
name = "newModel",
summary = "Get a Model for the Controller.",
description = "Returns a new Model for the Controller.",
key = "Controller:newModel",
module = "lovr.headset",
notes = "The Model will have a Texture applied.",
variants = {
{
arguments = {},
returns = {
{
name = "model",
type = "Model",
description = "The new Model, or nil if a model could not be loaded."
}
}
}
},
examples = {
{
code = "local models = {}\n\nfunction lovr.draw()\n for _, controller in ipairs(lovr.headset.getControllers()) do\n local x, y, z = controller:getPosition()\n local angle, ax, ay, az = controller:getOrientation()\n models[controller] = models[controller] or controller:newModel()\n models[controller]:draw(x, y, z, 1, angle, ax, ay, az)\n end\nend"
}
}
},
{
name = "vibrate",
summary = "Make the Controller go BZZZ!",
description = "Causes the Controller to vibrate for a specified duration.",
key = "Controller:vibrate",
module = "lovr.headset",
notes = "On the HTC Vive, the value for the `duration` currently must be less than .004 seconds. Call this function several frames in a row for stronger or prolonged vibration patterns.",
variants = {
{
arguments = {
{
name = "duration",
type = "number",
description = "The amount of time to vibrate the Controller, in seconds."
}
},
returns = {}
}
}
}
}
}
}
},
{
name = "math",
tag = "modules",
summary = "Contains useful math helpers.",
description = "The `lovr.math` module provides math helpers commonly used for 3D applications. Currently, only `Transform` objects are exposed.",
key = "lovr.math",
functions = {
{
name = "newTransform",
summary = "Create a new Transform.",
description = "A transform is a 4x4, column major matrix that can be used to represent the 3D transform of an object. Most graphics primitives accept a Transform instead of the usual coordinate arguments. Transforms provide a convenient way to represent translation, rotation, and scale in a single object.",
key = "lovr.math.newTransform",
module = "lovr.math",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x position of the Transform."
},
{
name = "y",
type = "number",
description = "The x position of the Transform."
},
{
name = "z",
type = "number",
description = "The x position of the Transform."
},
{
name = "scale",
type = "number",
description = "The scale of the Transform."
},
{
name = "angle",
type = "number",
description = "The number of radians the Transform is rotated around its axis of rotation."
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation."
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation."
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation."
}
},
returns = {
{
name = "transform",
type = "Transform",
description = "The new Transform."
}
}
}
}
}
},
enums = {},
objects = {
{
name = "Transform",
summary = "A 3D transform.",
description = "A Transform represents a translation, rotation, and scale in 3D space. They're commonly used to describe how entities are arranged in a scene or how a camera is positioned.",
key = "Transform",
module = "lovr.math",
methods = {
{
name = "apply",
summary = "Combine two Transforms.",
description = "Applies a Transform onto this Transform.",
key = "Transform:apply",
module = "lovr.math",
variants = {
{
arguments = {
{
name = "other",
type = "Transform",
description = "Combine two Transforms together. Order matters, so applying Transforms in different orders will yield different results."
}
},
returns = {
{
name = "transform",
type = "Transform",
description = "The original Transform."
}
}
}
}
},
{
name = "clone",
summary = "Clone the Transform.",
description = "Returns a copy of the Transform.",
key = "Transform:clone",
module = "lovr.math",
variants = {
{
arguments = {},
returns = {
{
name = "copy",
type = "Transform",
description = "The copy of the original."
}
}
}
}
},
{
name = "inverse",
summary = "Get the inverse of the Transform.",
description = "Returns a new Transform representing the inverse of the original. The inverse \"cancels out\" the effects of the original, so applying one onto the other will result in the origin.",
key = "Transform:inverse",
module = "lovr.math",
related = {
"Transform:inverseTransformPoint"
},
variants = {
{
arguments = {},
returns = {
{
name = "inverse",
type = "Transform",
description = "The inverse transform."
}
}
}
}
},
{
name = "inverseTransformPoint",
summary = "Apply the inverse of the Transform to a point.",
description = "Applies the inverse of the Transform to a point, returning the transformed point.",
key = "Transform:inverseTransformPoint",
module = "lovr.math",
related = {
"Transform:transformPoint"
},
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x coordinate of the point."
},
{
name = "y",
type = "number",
description = "The y coordinate of the point."
},
{
name = "z",
type = "number",
description = "The z coordinate of the point."
}
},
returns = {
{
name = "x2",
type = "number",
description = "The x coordinate of the transformed point."
},
{
name = "y2",
type = "number",
description = "The y coordinate of the transformed point."
},
{
name = "z2",
type = "number",
description = "The z coordinate of the transformed point."
}
}
}
}
},
{
name = "origin",
summary = "Reset the Transform.",
description = "Resets the Transform to the origin.",
key = "Transform:origin",
module = "lovr.math",
variants = {
{
arguments = {},
returns = {
{
name = "transform",
type = "Transform",
description = "The original Transform."
}
}
}
},
examples = {
{
code = "transform = lovr.math.newTransform(3, 4, 5)\nprint(transform:transformPoint(1, 2, 2)) -- Prints 4, 6, 7\ntransform:origin()\nprint(transform:transformPoint(1, 2, 3)) -- Prints 1, 2, 3"
}
}
},
{
name = "rotate",
summary = "Rotate the Transform.",
description = "Rotates the Transform using an angle/axis rotation.",
key = "Transform:rotate",
module = "lovr.math",
variants = {
{
arguments = {
{
name = "angle",
type = "number",
description = "The number of radians to rotate around the axis of rotation."
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation."
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation."
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation."
}
},
returns = {
{
name = "transform",
type = "Transform",
description = "The original Transform."
}
}
}
}
},
{
name = "scale",
summary = "Scale the Transform.",
description = "Scales the Transform.",
key = "Transform:scale",
module = "lovr.math",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The scale factor for the x axis."
},
{
name = "y",
type = "number",
description = "The scale factor for the y axis.",
default = "x"
},
{
name = "z",
type = "number",
description = "The scale factor for the z axis.",
default = "x"
}
},
returns = {
{
name = "transform",
type = "Transform",
description = "The original Transform."
}
}
}
}
},
{
name = "setTransformation",
summary = "Set the position, rotation, and scale of the Transform.",
description = "Sets the translation, rotation, and scale of the Transform. This will override the current values in the Transform.",
key = "Transform:setTransformation",
module = "lovr.math",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x position of the Transform."
},
{
name = "y",
type = "number",
description = "The x position of the Transform."
},
{
name = "z",
type = "number",
description = "The x position of the Transform."
},
{
name = "scale",
type = "number",
description = "The scale of the Transform."
},
{
name = "angle",
type = "number",
description = "The number of radians the Transform is rotated around its axis of rotation."
},
{
name = "ax",
type = "number",
description = "The x component of the axis of rotation."
},
{
name = "ay",
type = "number",
description = "The y component of the axis of rotation."
},
{
name = "az",
type = "number",
description = "The z component of the axis of rotation."
}
},
returns = {
{
name = "transform",
type = "Transform",
description = "The original Transform."
}
}
}
}
},
{
name = "transformPoint",
summary = "Apply the Transform to a point.",
description = "Applies the Transform to a point, returning the new position.",
key = "Transform:transformPoint",
module = "lovr.math",
related = {
"Transform:inverseTransformPoint"
},
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x coordinate of the point."
},
{
name = "y",
type = "number",
description = "The y coordinate of the point."
},
{
name = "z",
type = "number",
description = "The z coordinate of the point."
}
},
returns = {
{
name = "x2",
type = "number",
description = "The x coordinate of the transformed point."
},
{
name = "y2",
type = "number",
description = "The y coordinate of the transformed point."
},
{
name = "z2",
type = "number",
description = "The z coordinate of the transformed point."
}
}
}
}
},
{
name = "translate",
summary = "Translate the Transform.",
description = "Translates the Transform.",
key = "Transform:translate",
module = "lovr.math",
variants = {
{
arguments = {
{
name = "x",
type = "number",
description = "The x component of the translation."
},
{
name = "y",
type = "number",
description = "The y component of the translation."
},
{
name = "z",
type = "number",
description = "The z component of the translation."
}
},
returns = {
{
name = "transform",
type = "Transform",
description = "The original Transform."
}
}
}
}
}
},
constructors = {
"lovr.math.newTransform"
}
}
}
},
{
name = "timer",
tag = "modules",
summary = "Exposes a high resolution timer.",
description = "The `lovr.timer` module provides a few functions that deal with time. All times are measured in seconds.",
key = "lovr.timer",
functions = {
{
name = "getDelta",
summary = "Get the time elapsed since the last update.",
description = "Returns the time between the last two frames. This is the same value as the `dt` argument provided to `lovr.update`.",
key = "lovr.timer.getDelta",
module = "lovr.timer",
related = {
"lovr.timer.getTime",
"lovr.update"
},
variants = {
{
arguments = {},
returns = {
{
name = "dt",
type = "number",
description = "The delta time, in seconds."
}
}
}
},
notes = "The return value of this function will remain the same until `lovr.timer.step` is called. This function should not be used to measure times for game behavior or benchmarking, use `lovr.timer.getTime` for that."
},
{
name = "getFPS",
summary = "Get the current frames per second.",
description = "Returns the current frames per second, averaged over the last 60 frames.",
key = "lovr.timer.getFPS",
module = "lovr.timer",
variants = {
{
arguments = {},
returns = {
{
name = "fps",
type = "number",
description = "The current FPS."
}
}
}
}
},
{
name = "getTime",
summary = "Get the current time.",
description = "Returns the time since some time in the past. This can be used to measure the difference between two points in time.",
key = "lovr.timer.getTime",
module = "lovr.timer",
variants = {
{
arguments = {},
returns = {
{
name = "time",
type = "number",
description = "The current time, in seconds."
}
}
}
}
},
{
name = "sleep",
summary = "Go to sleep.",
description = "Sleeps the application for a specified number of seconds. While the game is asleep, no code will be run, no graphics will be drawn, and the window will be unresponsive.",
key = "lovr.timer.sleep",
module = "lovr.timer",
variants = {
{
arguments = {
{
name = "duration",
type = "number",
description = "The number of seconds to sleep for."
}
},
returns = {}
}
}
},
{
name = "step",
summary = "Steps the internal clock.",
description = "Steps the timer, returning the new delta time. This is called automatically in `lovr.run` and it's used to calculate the new `dt` to pass to `lovr.update`.",
key = "lovr.timer.step",
module = "lovr.timer",
variants = {
{
arguments = {},
returns = {
{
name = "delta",
type = "number",
description = "The amount of time since the last call to this function, in seconds."
}
}
}
}
}
},
enums = {},
objects = {}
}
}
}