I'm struggling through putting my own 3D engine together mostly because I'm a masochist and I want to learn.

But I'm working through the different culling I want to implement (view fulstrum, occlusion) but is it true its generally cheaperto let OpenGL handle backface culling? From my flopping around on google, it looks like (besides memory usage) the GPU can dropthe backfaces faster the CPU. Is that right??

It is not a dumb question in my humble opinion. I wrote my own engine several years ago, you want to learn, I was in the same case, it does not mean you're a masochist.

Actually, performances depend on the complexity of the geometry and the power of your graphics card.

Quote

The fastest primitive is the one you don't draw.

If you can simplify the geometry that you send to the graphics card fast enough on the CPU side, you can improve the performances (especially on low end machines, mobile phones, crappy mobile chipsets or SoC on laptops).

Some culling techniques are already implemented in OpenGL, you don't need to reimplement them except for pedagogical purposes, for example backface culling and view frustum culling.

You have to try to benefit of some pieces of information which the graphics card does not know about your geometry. For example, I implemented a cells-and-portals subdivision algorithm in a simple case, it is very efficient in indoor environments, it (not my implementation of course) is even used in Fallout 3.

I think that modern 3D scenegraphs written in Java (except maybe JMonkeyEngine 3.0) have a real lack in this domain. Sending everything to the graphics card is rarely a good idea except if you adapt the minimal required configuration to the complexity of your scenes, that is what a lot of non commercial games do.

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