mirror of
https://github.com/coop-deluxe/sm64coopdx.git
synced 2025-01-03 06:01:27 +00:00
60 lines
1.5 KiB
C
60 lines
1.5 KiB
C
|
/*
|
||
|
* 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;
|
||
|
}
|
||
|
}
|