« July 2008 | Main | September 2008 »

August 2008 Archives

August 28, 2008

C# .NET 3D Frameworks / Wrapper Frameworks built-in obsolesence ?

I am looking into a 3D engine framework for a C# application. 3D Engines get released and abandoned at a frightful fast pace only a very few survive for a few years. As I want to use the 3D engine in an enterprise class application, it needs to have longevity which basically means open source. I have spent a good deal of my life profitably rewriting abandoned vendor frameworks, but I would rather do something else now, if I can help it.

Enterprise class meaning, an app that has to work for more than a few years.

So anyway what I found to be available for C# .NET coding is:

Wrapped Engines

NameLanguageVersion.NET WrapperWrapped VersionLatency
IrrlichtC++1.4.1Irrlicht.NET CP1.3.11 year
Horde3DC++1.0.0Horde3D .NET0.13.0 1/2 year
OgreC++1.4.9MOGRE1.4.81 month

One major problem with the wrapper frameworks is, that they are maintained outside of the main project and aren't released with the core frameworks. So there is always a latency between a core release and a wrapper release. The common theme of these frameworks is, that they are maintained by students. Students like to code for kicks but maintaining gets boring very fast and after they leave college they suddenly have no time.

There is nothing wrong with that, if you don't get paid, do what you do for fun.

Irrlicht used to have a .NET framework inside the core release, but it got abandoned in favor of the third party product...

Quick Judgements

The Irrlicht CP wrapper is just lagging too much, to be a candidate. The Horde 3D .NET wrapper also has the looks of being abandoned. So MOGRE is the sole survivor in the wrapper category.

Native Engines

NameLanguageVersionAdoptionRelease Latency
AxiomC#0.7.301 Year
Axiom Multiverse BranchC#0.7.?13 months
JAD EngineC#1.00unknown

Adoption is the number of real outside projects, that use the framework. Axiom gets a zero, because the only real project using the framework has created it's own fork.

Quick Judgements

Until I looked into the Multiverse branch, I discounted Axiom as another abandoned student project. There is little traffic in the forum and the threads that exist are all about fairly basic problems. The JAD Engine is short on developers and it sounds like its dying and can't yet boast a single outside project, that has adopted it.
So Axiom Multiverse Branch is the sole survivor in the native category.

Remote Alternatives

NameLanguageVersion.NET WrapperWrapped VersionLatency
OpenGL--TAO2.1.0
Direct X--Xna2.0

Quick Notes

Xna is not open source, but Microsoft usually - contrary to other vendors - does not abandon users at the whim of the CEO and it certainly isn't expected to go belly up in the foreseeable future. Therefore the Open Source requirement could be relaxed at this point.

Tao appears to be a collection of well maintained and ill maintained wrappers for OpenGL, SDL and some physics frameworks.

Both are a little bit too low level for my wishes (yet).

Conclusion

Without looking into any technical details yet, there are only two candidates left MOGRE and Axiom Multiverse. MOGRE carries the stigma of the wrapper with it and Axiom Multiverse is just used by one project. Both choices are not very enticing.

About August 2008

This page contains all entries posted to Nat!'s Web Journal in August 2008. They are listed from oldest to newest.

July 2008 is the previous archive.

September 2008 is the next archive.

Many more can be found on the main index page or by looking through the archives.

Powered by
Movable Type 4.25