Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

unexpected depth value returned by gluUnProject

Posted on 2004-09-09
4
Medium Priority
?
431 Views
Last Modified: 2013-12-06
I've found the resources on the net to use gluUnProject() to get the world (x,y,z) values given a screen coordinate. The code seems to work, but I'm a little confused by the z value returned. The application renders a triangle strip in which all z values are -3.0f, but the z value returned from gluUnProject is -1.0f.

The application sets the viewport with

    gluPerspective(37.0, (GLfloat)w/(GLfloat)h, 1, 20.0);

The vertices get setup with
    glBegin(GL_TRIANGLE_STRIP);
    glVertex3f( xstep, ystep, -3.0f);
    ...

Any idea why the z value isn't -3.0f?
0
Comment
Question by:ctuffli
  • 3
4 Comments
 
LVL 17

Expert Comment

by:davebytes
ID: 12018593
From :
>>>>
gluUnProject() does the opposite. It takes an XYZ window coordinate and returns the back-transformed XYZ object coordinate equivalent.

The concept of window space Z is often confusing. It's the depth buffer value expressed as a GLdouble in the range 0.0 to 1.0. Assuming a default glDepthRange(), a window coordinate with a Z value of 0.0 corresponds to an eye coordinate located on the zNear clipping plane. Similarly, a window space Z value of 1.0 corresponds to an eye space coordinate located on the zFar plane. You can obtain any window space Z value by reading the depth buffer with glReadPixels().
<<<<

So, basically depending upon the screen [z] value, you'll get back different world [z] values.  If you have a particular x,y on the screen that you want to get the world coordinates for the pixel, you need to do a readpixels and get that pixel's actual z-buffer value, and pass that into UnProject.

That help?

-d
0
 
LVL 17

Expert Comment

by:davebytes
ID: 12018602
Sorry, clicked submit and didn't mean to...

That was from http://www.opengl.org/resources/faq/technical/glu.htm 

Also look at http://www.gamedev.net/community/forums/topic.asp?topic_id=268798 for another discussion of the topic.

-d
0
 
LVL 1

Author Comment

by:ctuffli
ID: 12021491
I had found the description about how window Z is confusing and added a glReadPixels call to the application to get the depth value. The depth is coming back zero which causes the UnProject to generate a -1 for Z (if I understand the above). So does this mean that the Z value will always come back either zNear or zFar? Does the application need to use the depth value to scale between zNear and zFar?
0
 
LVL 17

Accepted Solution

by:
davebytes earned 750 total points
ID: 12030378
If the pixel has nothing in it, it'll be whatever Z you ClearDepth to, and that should translate approximately to zFar.   Thought I'm not sure that things on the near or far plane have well defined values, may be clamped, which could easily be the -1 you are getting.

If the pixel has something in it, it should translate to the approximate z value.

I don't think you need to be doing any further scaling...

-d
0

Featured Post

Concerto's Cloud Advisory Services

Want to avoid the missteps to gaining all the benefits of the cloud? Learn more about the different assessment options from our Cloud Advisory team.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Artificial Intelligence comes in many forms, and for game developers, Path-Finding is an important ability for making an NPC (Non-Playable Character) maneuver through terrain.  A* is a particularly easy way to approach it.  I’ll start with the algor…
As game developers, we quickly learn that Artificial Intelligence (AI) doesn’t need to be so tough.  To reference Space Ghost: “Moltar, I have a giant brain that is able to reduce any complex machine into a simple yes or no answer. (http://www.youtu…
Video by: ITPro.TV
In this episode Don builds upon the troubleshooting techniques by demonstrating how to properly monitor a vSphere deployment to detect problems before they occur. He begins the show using tools found within the vSphere suite as ends the show demonst…
Exchange organizations may use the Journaling Agent of the Transport Service to archive messages going through Exchange. However, if the Transport Service is integrated with some email content management application (such as an anti-spam), the admin…

885 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question