Search code examples
c#wpfrendering

Constant framerate in WPF for game


Im creating a simple vehicle and projectile simulation game in WPF using C#. I need to have a constant frame rate (i.e. i need to know how much to move an object with a certain velocity in each frame). This way I could subscribe an event which calculates and updates positions according to the game's physics to the CompositionTarget.Rendering event.

CompositionTarget.Rendering += UpdatePositions;

I googled it a while, and found no answer. The fps in WPF seem to be arbitrary, and using a Stopwatch to know how much time elapsed between a frame and the previous one wouldn't be clean at all.

I thought also of creating my own frame rate, by calling UpdatePositions every some amount of milliseconds and hoping for the Rendering to occur accordingly and have a smooth animation. This seems like reinventing the wheel, and I cant think of a way of implementing this in a clean and simple manner.

Thanks!


Solution

  • It is impossible to get a constant framerate in WPF. WPF is based on the idea of dynamic frame rates and this makes it near useless for any game development.

    Some related information:

    Why is Frame Rate in WPF Irregular and Not Limited To Monitor Refresh?

    http://rhnatiuk.wordpress.com/2008/12/21/wpf-video-playback-problems/

    As others have pointed out the solution is, unfortunately, not to use WPF for game development.

    I have worked with WPF animations extensively and it is an absolute pain to get anything to smoothly animate in WPF (if you do want to do this I've written down a few best practices here).

    I am sure there are many other reasons why WPF is not good for game development. One example is that you cannot create a full screen application in WPF as WPF apps are always windowed. This means that you could not change the resolution for your game to make it smooth in full screen which effectively means that you could not create a full screen game in WPF and expect good results.

    If you are serious about your game or game development in general and this is not just a prototype or just-for-fun then I recommend that you ditch WPF and use something else, otherwise you just set yourself up for disappointment and sub-par quality.