Merge pull request #18454 from KidRigger/working_timer
Allows setting the Timer wait_time in start method.
This commit is contained in:
commit
e15305721d
3 changed files with 9 additions and 4 deletions
|
@ -21,8 +21,10 @@
|
|||
<method name="start">
|
||||
<return type="void">
|
||||
</return>
|
||||
<argument index="0" name="time_sec" type="float" default="-1">
|
||||
</argument>
|
||||
<description>
|
||||
Starts the timer. This also resets the remaining time to [code]wait_time[/code].
|
||||
Starts the timer. Sets [code]wait_time[/code] to [code]time_sec[/code] if [code]time_sec[/code] > 0. This also resets the remaining time to [code]wait_time[/code].
|
||||
Note: this method will not resume a paused timer. See [method set_paused].
|
||||
</description>
|
||||
</method>
|
||||
|
|
|
@ -107,7 +107,10 @@ bool Timer::has_autostart() const {
|
|||
return autostart;
|
||||
}
|
||||
|
||||
void Timer::start() {
|
||||
void Timer::start(float p_time) {
|
||||
if (p_time > 0) {
|
||||
set_wait_time(p_time);
|
||||
}
|
||||
time_left = wait_time;
|
||||
_set_process(true);
|
||||
}
|
||||
|
@ -185,7 +188,7 @@ void Timer::_bind_methods() {
|
|||
ClassDB::bind_method(D_METHOD("set_autostart", "enable"), &Timer::set_autostart);
|
||||
ClassDB::bind_method(D_METHOD("has_autostart"), &Timer::has_autostart);
|
||||
|
||||
ClassDB::bind_method(D_METHOD("start"), &Timer::start);
|
||||
ClassDB::bind_method(D_METHOD("start", "time_sec"), &Timer::start, DEFVAL(-1));
|
||||
ClassDB::bind_method(D_METHOD("stop"), &Timer::stop);
|
||||
|
||||
ClassDB::bind_method(D_METHOD("set_paused", "paused"), &Timer::set_paused);
|
||||
|
|
|
@ -64,7 +64,7 @@ public:
|
|||
void set_autostart(bool p_start);
|
||||
bool has_autostart() const;
|
||||
|
||||
void start();
|
||||
void start(float p_time = -1);
|
||||
void stop();
|
||||
|
||||
void set_paused(bool p_paused);
|
||||
|
|
Loading…
Reference in a new issue