pxt-ev3/libs/core/timer.ts

68 lines
2.0 KiB
TypeScript
Raw Permalink Normal View History

namespace control {
2018-01-15 12:41:14 +01:00
/**
* A timer
*/
//% fixedInstances
export class Timer {
start: number;
constructor() {
this.start = control.millis();
}
/**
2018-02-22 23:56:15 +01:00
* Get the elapsed time in millis since the last reset
*/
//% blockId=timerMillis block="%timer|millis"
2018-02-22 23:56:15 +01:00
//% help=control/timer/millis
millis(): number {
return control.millis() - this.start;
}
/**
2018-02-22 23:56:15 +01:00
* Get the elapsed time in seconds since the last reset
*/
//% blockId=timerSeconds block="%timer|seconds"
2018-02-22 23:56:15 +01:00
//% help=control/timer/seconds
seconds(): number {
return this.millis() / 1000;
}
/**
2018-02-22 23:56:15 +01:00
* Reset the timer
*/
//% blockId=timerRest block="%timer|reset"
2018-02-22 23:56:15 +01:00
//% help=control/timer/reset
reset() {
this.start = control.millis();
}
/**
2018-02-22 23:56:15 +01:00
* Pause until the timer reaches the given amount of milliseconds
* @param ms how long to pause for, eg: 5, 100, 200, 500, 1000, 2000
*/
//% blockId=timerPauseUntil block="%timer|pause until (ms) %ms"
2018-02-22 23:56:15 +01:00
//% help=control/timer/pause-until
pauseUntil(ms: number) {
2018-02-22 23:56:15 +01:00
const remaining = ms - this.millis();
pause(Math.max(0, remaining));
}
}
//% whenUsed fixedInstance block="timer 1"
export const timer1 = new Timer();
//% whenUsed fixedInstance block="timer 2"
export const timer2 = new Timer();
//% whenUsed fixedInstance block="timer 3"
export const timer3 = new Timer();
//% whenUsed fixedInstance block="timer 4"
export const timer4 = new Timer();
//% whenUsed fixedInstance block="timer 5"
export const timer5 = new Timer();
//% whenUsed fixedInstance block="timer 6"
export const timer6 = new Timer();
//% whenUsed fixedInstance block="timer 7"
export const timer7 = new Timer();
//% whenUsed fixedInstance block="timer 8"
export const timer8 = new Timer();
}