Difference between revisions of "love.update"
(definition should contain reference to the default love.run) |
|||
(10 intermediate revisions by 6 users not shown) | |||
Line 1: | Line 1: | ||
− | Callback function used to update the state of the game every frame. | + | Callback function used by the [[love.run#The default function for 11.0, used if you don't supply your own.|default love.run]] to update the state of the game every frame. |
+ | |||
== Function == | == Function == | ||
=== Synopsis === | === Synopsis === | ||
Line 10: | Line 11: | ||
Nothing. | Nothing. | ||
== Examples == | == Examples == | ||
− | Run a function called think inside a table called npc | + | Run a function called ''think'' inside a table called ''npc'' once per second. |
<source lang="lua"> | <source lang="lua"> | ||
− | dtotal = 0 | + | dtotal = 0 -- this keeps track of how much time has passed |
function love.update(dt) | function love.update(dt) | ||
− | + | dtotal = dtotal + dt -- we add the time passed since the last update, probably a very small number like 0.01 | |
− | + | if dtotal >= 1 then | |
− | + | dtotal = dtotal - 1 -- reduce our timer by a second, but don't discard the change... what if our framerate is 2/3 of a second? | |
− | + | npc.think() | |
− | end | + | end |
+ | end | ||
+ | </source> | ||
+ | Change a variable ''var'' at a constant rate (+/- 3 per second in this example). | ||
+ | <source lang="lua"> | ||
+ | var = 10 -- arbitrary starting value | ||
+ | rate = 3 -- change to change the rate at which the var is changed | ||
+ | function love.update(dt) | ||
+ | if love.keyboard.isDown("down") then -- reduce the value | ||
+ | var = var - (dt * rate) | ||
+ | end | ||
+ | if love.keyboard.isDown("up") then -- increase the value | ||
+ | var = var + (dt * rate) | ||
+ | end | ||
end | end | ||
</source> | </source> | ||
Line 24: | Line 38: | ||
* [[parent::love]] | * [[parent::love]] | ||
* [[World:update]] | * [[World:update]] | ||
+ | * [[variable]] | ||
[[Category:Callbacks]] | [[Category:Callbacks]] | ||
{{#set:Description=Callback function used to update the state of the game every frame.}} | {{#set:Description=Callback function used to update the state of the game every frame.}} | ||
+ | {{#set:Subcategory=General}} | ||
{{#set:Since=000}} | {{#set:Since=000}} | ||
== Other Languages == | == Other Languages == | ||
{{i18n|love.update}} | {{i18n|love.update}} |
Latest revision as of 12:11, 24 December 2024
Callback function used by the default love.run to update the state of the game every frame.
Function
Synopsis
love.update( dt )
Arguments
number dt
- Time since the last update in seconds.
Returns
Nothing.
Examples
Run a function called think inside a table called npc once per second.
dtotal = 0 -- this keeps track of how much time has passed
function love.update(dt)
dtotal = dtotal + dt -- we add the time passed since the last update, probably a very small number like 0.01
if dtotal >= 1 then
dtotal = dtotal - 1 -- reduce our timer by a second, but don't discard the change... what if our framerate is 2/3 of a second?
npc.think()
end
end
Change a variable var at a constant rate (+/- 3 per second in this example).
var = 10 -- arbitrary starting value
rate = 3 -- change to change the rate at which the var is changed
function love.update(dt)
if love.keyboard.isDown("down") then -- reduce the value
var = var - (dt * rate)
end
if love.keyboard.isDown("up") then -- increase the value
var = var + (dt * rate)
end
end
See Also
Other Languages
Dansk –
Deutsch –
English –
Español –
Français –
Indonesia –
Italiano –
Lietuviškai –
Magyar –
Nederlands –
Polski –
Português –
Română –
Slovenský –
Suomi –
Svenska –
Türkçe –
Česky –
Ελληνικά –
Български –
Русский –
Српски –
Українська –
עברית –
ไทย –
日本語 –
正體中文 –
简体中文 –
Tiếng Việt –
한국어
More info