mirror of https://github.com/ctnlaring/sm64
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
65 lines
1.5 KiB
65 lines
1.5 KiB
/*
|
|
* Framerate counter
|
|
*
|
|
* Calculates the game's current framerate by using osGetTime() and
|
|
* prints it out on the lower left side of the screen.
|
|
*
|
|
* HOW TO USE:
|
|
*
|
|
* Add this include statement to the top of game.c
|
|
*
|
|
* #include "../../enhancements/fps.inc.c"
|
|
*
|
|
* Then, at the end of the while(1) loop in the function thread5_game_loop()
|
|
* add the function call render_fps()
|
|
*
|
|
* That's it! Build the rom file and press L when the game boots up
|
|
* to toggle the FPS counter.
|
|
*/
|
|
|
|
// SDK states that 1 cycle takes about 21.33 nanoseconds
|
|
#define SECONDS_PER_CYCLE 0.00000002133f
|
|
|
|
#define FPS_COUNTER_X_POS 24
|
|
#define FPS_COUNTER_Y_POS 190
|
|
|
|
OSTime gLastOSTime = 0;
|
|
float gFrameTime = 0.0f;
|
|
u16 gFrames = 0;
|
|
u16 gFPS = 0;
|
|
u8 gRenderFPS = FALSE;
|
|
|
|
void calculate_frameTime_from_OSTime(OSTime diff)
|
|
{
|
|
gFrameTime += diff * SECONDS_PER_CYCLE;
|
|
gFrames++;
|
|
}
|
|
|
|
void render_fps(void)
|
|
{
|
|
// Toggle rendering framerate with the L button.
|
|
if (gPlayer1Controller->buttonPressed & L_TRIG)
|
|
{
|
|
gRenderFPS ^= 1;
|
|
}
|
|
|
|
if(gRenderFPS)
|
|
{
|
|
OSTime newTime = osGetTime();
|
|
|
|
calculate_frameTime_from_OSTime(newTime - gLastOSTime);
|
|
|
|
// If frame time is longer or equal to a second, update FPS counter.
|
|
if(gFrameTime >= 1.0f)
|
|
{
|
|
gFPS = gFrames;
|
|
gFrames = 0;
|
|
gFrameTime -= 1.0f;
|
|
}
|
|
|
|
print_text_fmt_int(FPS_COUNTER_X_POS, FPS_COUNTER_Y_POS, "FPS %d", gFPS);
|
|
|
|
gLastOSTime = newTime;
|
|
}
|
|
|
|
}
|