2009-01-14 20:51:17 +00:00
|
|
|
// Small script that prints the FPS to screen with regular intervals.
|
2009-02-01 02:21:08 +00:00
|
|
|
class FPSTicker;
|
2009-01-14 20:51:17 +00:00
|
|
|
|
2009-01-22 20:36:36 +00:00
|
|
|
import frames;
|
2009-01-14 20:51:17 +00:00
|
|
|
|
2009-02-01 02:21:08 +00:00
|
|
|
// Set the FPS widget text
|
|
|
|
native setText(char[][] args...);
|
2009-01-20 08:29:15 +00:00
|
|
|
|
2009-02-01 02:21:08 +00:00
|
|
|
run()
|
|
|
|
{
|
|
|
|
// Sleep one frame. This makes sure that we won't start running until
|
|
|
|
// the rendering begins. Not critically important, but it prevents the
|
|
|
|
// first printed value from being 'nan'.
|
|
|
|
fsleep(1);
|
2009-01-14 20:51:17 +00:00
|
|
|
|
2009-02-01 02:21:08 +00:00
|
|
|
setText("hello!");
|
2009-01-14 20:51:17 +00:00
|
|
|
|
2009-02-01 02:21:08 +00:00
|
|
|
// counter and totalTime (in the 'frames' module) are updated
|
|
|
|
// automatically by the system.
|
|
|
|
ulong lastFrame = counter;
|
|
|
|
float lastTime = totalTime;
|
|
|
|
|
|
|
|
float delay = 1.5;
|
|
|
|
|
|
|
|
while(true)
|
|
|
|
{
|
|
|
|
sleep(delay);
|
2009-01-20 08:29:15 +00:00
|
|
|
|
2009-02-01 02:21:08 +00:00
|
|
|
// Calculate differences since last frame
|
|
|
|
ulong fdiff = counter-lastFrame;
|
|
|
|
float tdiff = totalTime-lastTime;
|
2009-01-20 08:29:15 +00:00
|
|
|
|
2009-02-01 02:21:08 +00:00
|
|
|
setText("fps: ", fdiff / tdiff);
|
2009-01-20 08:29:15 +00:00
|
|
|
|
2009-02-01 02:21:08 +00:00
|
|
|
lastFrame = counter;
|
|
|
|
lastTime = totalTime;
|
|
|
|
}
|
2009-01-14 20:51:17 +00:00
|
|
|
}
|