Java-Gaming.org    
Featured games (91)
games approved by the League of Dukes
Games in Showcase (581)
games submitted by our members
Games in WIP (500)
games currently in development
News: Read the Java Gaming Resources, or peek at the official Java tutorials
 
    Home     Help   Search   Login   Register   
Pages: [1]
  ignore  |  Print  
  problem with calculation frames per second  (Read 737 times)
0 Members and 1 Guest are viewing this topic.
Offline Cyclonis

Senior Newbie





« Posted 2006-03-27 09:39:04 »

Hi,

I am practising a little bit now by making a pac-man game in Java2D. Everything is working pretty well except calculating the frames per second.

This is my run() method which continuously calls the gameloop update(Graphics2D gfx) Here you can see my futile attempt at calculating the FPS

public void run() {
        while (isRunning) {
            long starttime = System.currentTimeMillis();
            try {               
                Graphics2D gfx = (Graphics2D)getGraphics();
                update(gfx);
                Thread.currentThread().sleep(25);
               
            }
            catch (InterruptedException ex) {
                System.out.println("Something went seriously wrong!");
            }
            long duration = System.currentTimeMillis() - starttime;
            double fps = 1/(duration*0.001);
            System.out.println("FPS: " + fps);
        }
    }

To me it seems this should work, however, with a sleep of 25 milliseconds, the fastest FPS I should be able to get is 40 fps
The strange thing is, my FPS keeps on flipping between 31.5 and 61.2 fps     when I make the sleep longer, like 50, it will switch between 15.8 and 16.1 continuously.
If I put the sleep on 1 ms, it still switches between 31.5 and 61.2       when I take out the update(gfx) it will also switch to INF next to the 31.5 and 61.2

What am I doing wrong here?  Or does anyone have a way of doing this correctly?
Offline Riven
« League of Dukes »

JGO Overlord


Medals: 605
Projects: 4
Exp: 16 years


Hand over your head.


« Reply #1 - Posted 2006-03-27 09:49:03 »

Thread.sleep(x); is very inaccurate, depending on the OS

  • WinXP might have a resolution of 10ms
  • Linux might have a resolution of 1ms
  • Win98 might have a resolution of 55ms

Hi, appreciate more people! Σ ♥ = ¾
Learn how to award medals... and work your way up the social rankings
Offline Cyclonis

Senior Newbie





« Reply #2 - Posted 2006-03-27 10:38:34 »

thanx for the answer, but then what do I do? can i just leave the sleep out of it? I read somewhere that if I do that the program will crash.
Games published by our own members! Check 'em out!
Legends of Yore - The Casual Retro Roguelike
Offline tusaki

Junior Member


Medals: 1


In a mad world only the mad are sane.


« Reply #3 - Posted 2006-03-27 10:57:18 »

Get a start-time. (startTime = System.nano... for example)

in your drawing loop:
===
if (currentTime - startTime) >= 1 second {
     display or update the (fps) on screen;
     startTime = currentTime;
     fps = 0;
}
do your drawing.
Thread.yield();
fps++;
===

And be sure to let your sprite calculations be time-based, not frame-based.
Pages: [1]
  ignore  |  Print  
 
 
You cannot reply to this message, because it is very, very old.

 

Add your game by posting it in the WIP section,
or publish it in Showcase.

The first screenshot will be displayed as a thumbnail.

xsi3rr4x (57 views)
2014-04-15 18:08:23

BurntPizza (55 views)
2014-04-15 03:46:01

UprightPath (68 views)
2014-04-14 17:39:50

UprightPath (51 views)
2014-04-14 17:35:47

Porlus (68 views)
2014-04-14 15:48:38

tom_mai78101 (92 views)
2014-04-10 04:04:31

BurntPizza (153 views)
2014-04-08 23:06:04

tom_mai78101 (249 views)
2014-04-05 13:34:39

trollwarrior1 (205 views)
2014-04-04 12:06:45

CJLetsGame (212 views)
2014-04-01 02:16:10
List of Learning Resources
by SHC
2014-04-18 03:17:39

List of Learning Resources
by Longarmx
2014-04-08 03:14:44

Good Examples
by matheus23
2014-04-05 13:51:37

Good Examples
by Grunnt
2014-04-03 15:48:46

Good Examples
by Grunnt
2014-04-03 15:48:37

Good Examples
by matheus23
2014-04-01 18:40:51

Good Examples
by matheus23
2014-04-01 18:40:34

Anonymous/Local/Inner class gotchas
by Roquen
2014-03-11 15:22:30
java-gaming.org is not responsible for the content posted by its members, including references to external websites, and other references that may or may not have a relation with our primarily gaming and game production oriented community. inquiries and complaints can be sent via email to the info‑account of the company managing the website of java‑gaming.org
Powered by MySQL Powered by PHP Powered by SMF 1.1.18 | SMF © 2013, Simple Machines | Managed by Enhanced Four Valid XHTML 1.0! Valid CSS!