Java-Gaming.org
Play Revenge of the Titans! The situation is critical. We need fancy commanders to defend Earth, the moon, Mars!
Featured games (78)
games approved by the League of Dukes
Games in Showcase (407)
games submitted by our members
Games in WIP (293)
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  
  Transparency versus depth buffer  (Read 1160 times)
0 Members and 1 Guest are viewing this topic.
Offline abies

Senior Member





« Posted 2004-04-26 21:49:50 »

It looks for me that there is a small incompatibility in xith3d versus java3d. AFAIK, in java3d, setting TransparencyAttributes marked shape as transparent, which meant checking depth buffer, but not updating it. In xith3d, I need to explicitly set RenderingAttributes to avoid writing to depth buffer.

While this workaround is not hard, does it make sense to have transparent objects which at the same time write to depth buffer ? If not, it might be good to automagically avoid writes to depth buffer for anything with transparency set to BLENDED.

Artur Biesiadowski
Offline Yuri Vl. Gushchin

Senior Member




Speak Java!


« Reply #1 - Posted 2004-04-27 06:36:34 »

Hi,

In Java3D there is also View-level option for that:

Quote from Java3D JavaDoc:

Quote
public void setDepthBufferFreezeTransparent(boolean flag)

Enables or disables automatic freezing of the depth buffer for objects rendered during the transparent rendering pass (i.e., objects rendered using alpha blending) for this view. If enabled, depth buffer writes will be disabled during the transparent rendering pass regardless of the value of the depth buffer write enable flag in the RenderingAttributes object for a particular node. This flag is enabled by default.


In Java3D, behavior of RenderingAttributes.setDepthBufferWriteEnable can be overriden by option in View, but I don't think this is a good idea, because of if option in View is set, we loose fine-grained control over transparent pass.

Quote
does it make sense to have transparent objects which at the same time write to depth buffer ?


Just in some rare cases.

Quote
If not, it might be good to automagically avoid writes to depth buffer for anything with transparency set to BLENDED.


Two points:

1. In this case, we will loose some predictability of behavior, where single OpenGL state flag controlled from different places, which may cause some confusion (say, "I enable writing to depth buffer, and it is still disabled").

2. In current Xith3D implementation, Transparency and Rendering attributes are independent units and handled by separate independent shaders. Introducing dependency of RenderingAttributes on TransparencyAttributes will also require non-trivial change in OpenGL state management code.

Yuri

Yuri Vl. Gushchin
JProof Group
Offline Yuri Vl. Gushchin

Senior Member




Speak Java!


« Reply #2 - Posted 2004-04-27 06:37:47 »

...and, as of simple user-side code, maybe we should provide some factory methods/constructors for easy creation of RenderingAttributes based on TransparencyAttributes, or something like this?

Yuri

Yuri Vl. Gushchin
JProof Group
Games published by our own members! Check 'em out!
Play the free demo of Revenge of the Titans!
Offline abies

Senior Member





« Reply #3 - Posted 2004-04-27 07:11:32 »

Maybe just something like a bit of automagic to transparency attribute setter - if RenderingAttributes is null, create new one with depth-writer-disabled, in other case, leave it as it is. Unfortunately, we would also probably need to remember if it is auto set, so if transparency attributes are cleared later, it will be also cleared if not modified.

Artur Biesiadowski
Pages: [1]
  ignore  |  Print  
 
 
You cannot reply to this message, because it is very, very old.

Play Revenge of the Titans! The situation is critical. We need fancy commanders to defend Earth, the moon, Mars!
 
Get high quality music tracks for your game!

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

The first screenshot will be displayed as a thumbnail.

The invasion has landed! On Mars! And you're there to beat 'em!
cubemaster21 (97 views)
2013-05-17 21:29:12

alaslipknot (105 views)
2013-05-16 21:24:48

gouessej (135 views)
2013-05-16 00:53:38

gouessej (130 views)
2013-05-16 00:17:58

theagentd (141 views)
2013-05-15 15:01:13

theagentd (128 views)
2013-05-15 15:00:54

StreetDoggy (170 views)
2013-05-14 15:56:26

kutucuk (192 views)
2013-05-12 17:10:36

kutucuk (195 views)
2013-05-12 15:36:09

UnluckyDevil (201 views)
2013-05-12 05:09:57
Complex number cookbook
by Roquen
2013-04-24 12:47:31

2D Dynamic Lighting
by Oskuro
2013-04-17 16:46:12

2D Dynamic Lighting
by Oskuro
2013-04-17 16:45:57

2D Dynamic Lighting
by Oskuro
2013-04-17 16:23:20

Noise (bandpassed white)
by Roquen
2013-04-05 17:36:01

Noise (bandpassed white)
by Roquen
2013-04-03 16:17:38

Java Data structures
by Roquen
2013-03-29 13:21:12

Topic Request
by kutucuk
2013-03-22 21:42:01
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!
Page created in 0.065 seconds with 22 queries.