Direkt zum Hauptbereich

What's wrong with Java3D? Part I

In order to get some distance from my current smart home project, I dealt with Java3D. I wanted to find out if it was possible to develop a 3D game with it. In theory, it should be possible to make a game using a 3D API based on OpenGL, like Java3D is. However, Java3D has a not unimportant catch: its complexity. Perhaps this is also the reason why there are so many beginnings and advances on the internet by some courageous developers who received little or no feedback on their projects. Many questions remained unanswered - on stackoverflow.com.

I know Java3D is old. But that is precisely why one would have to find countless answers and examples on the Internet - especially about 3D games. But that is not the case. So why? When I started to investigate whether and how it is possible to develop an FPS, I always found the same examples, but never a coherent project.

The basics of three-dimensional computer graphics are difficult to understand at the beginning. In addition, Java3D comes with the complexity of a 20 year old API (and at that time APIs were not lightweight or agile). All of these are reasons why software projects are unsuccessful. And now it was clear to me why Java3D was probably hardly ever used for games in practice.

One could say that 3D computer graphics require knowledge of "difficult" mathematics, because the nature of things requires it. Likewise, one can always argue that a lot of programming experience is required and the necessary resources. And that all of this always makes a project complex. But: complexity can always be broken down, difficult math can always be simplified. Successful APIs support such principles from the start. Because success can only be achieved if there is broad support.

Java3D had a difficult start. It could never keep up with the speed of C or C ++ projects. Now you could say that this was already a knockout criterion. But this argument could be used for any software. Since Java is quite popular in software development, this doesn't seem to be a valid argument. And there are always 3D games that do not have too high demands on performance. So why is Java successful, but Java3D is not?

One reason could be that Java sets the hurdles for entry very low. (Compared to setting up a C compiler.) The first program takes three lines of code. In addition, there is no need to worry about pointers and hardware requirements. Java owes its success to precisely these facts: simplicity. If you can't keep up with the performance of C ++, it has to be simple - and platform-independent.

If you look at Java3D in the next Parts of this blog series, you will painfully miss exactly this Java simplicity.

Dead Ends

Many simple questions about Java3D got only one or few answers with complex source code.



Kommentare

Beliebte Posts aus diesem Blog

Pi And More 11 - QMC5883 Magnetic Field Sensor Class

A little aside from the analytical topics of this blog, I also was occupied with a little ubiquitous computing project. It was about machine learning with a magnetic field sensor, the QMC5883. In the Arduino module GY-271, usually the chip HMC5883 is equipped. Unfortunately, in cheap modules from china, another chip is used: the QMC5883. And, as a matter of course, the software library used for the HMC5883 does not work with the QMC version, because the I2C adress and the usage is a little bit different. Another problem to me was, that I  didn't find any proper working source codes for that little magnetic field device, and so I had to debug a source code I found for Arduino at Github  (thanks to dthain ). Unfortunately it didn't work properly at this time, and to change it for the Raspberry Pi into Python. Below you can find the "driver" module for the GY-271 with the QMC5883 chip. Sorry for the bad documentation, but at least it will work on a Raspberry Pi 3. ...

Lazarus IDE and TOracleConnection - A How-To

Free programming IDEs are a great benefit for everybody who's interested in Programming and for little but ambitious companies. One of these free IDEs is the Lazarus IDE . It's a "clone" of the Delphi IDE by Embarcadero (originally by Borland). But actually Lazarus is much more than a clone: Using the Free Pascal-Compiler , it was platform-independent and cross-compiling since it was started. I am using Lazarus very often - especially for building GUIs easily because Java is still Stone-Age when a GUI is required (though there is a couple of GUI-building tools - they all are much less performant than Delphi / Lazarus). In defiance of all benefits of Lazarus there still is one Problem. Not all Components are designed for use on a 64 bit systems. Considering that 64 bit CPUs are common in ordinary PCs since at least 2008, this is very anpleasant. One of the components which will not be available on 64 bit installations is the TOracleConnection of Lazarus' SQLDB ...

How to use TOracleConnection under Lazarus for Win64

Lazarus Programmers have had no possibility to use TOracleConnection under 64 Bit Windows and Lazarus for years. Even if you tried to use the TOracleConnection with a correctly configured Oracle 11g client, you were not able to connect to the Oracle Database. The error message was always: ORA-12154: TNS:could not resolve the connect identifier specified Today I found a simple workaround to fix this problem. It seems like the OCI.DLL from Oracle Client 11g2 is buggy. All my attempts to find identify the error ended here. I could exclude problems with the TNS systems in Oracle - or the Free Pascal file oracleconnection.pp though the error messages suggestes those problems. After investigating the function calls with Process Monitor (Procmon) I found out, that even the file TNSNAMES.ORA was found and read correctly by the Lazarus Test applictaion. So trouble with files not found or wrong Registry keys could also be eliminated. Finally I installed the Oracle Instant Client 12.1c - aft...