In order for a computer to render an image of three-dimensional graphics properly, it needs to determine what objects are in front of others in a scene. A Z-buffer (or “Depth Buffer”) stores a depth value for each pixel of a rendered image, which allows the computer to determine whether each object rendered appears in front of any other object in the scene, on a per-pixel basis.
Because the Z-Buffer only offers a finite amount of precision to store the depth value for each pixel, problems can occur when multiple objects resolve to the same depth value. In addition, the amount of precision varies throughout the 3D scene, as will be described later, so it can be different for the front of the scene and the back of the scene. In particular, the available precision is affected by the choice of the near and far clipping planes for the 3D scene.
Standard systems for generating near and far clipping planes for a 3D scene only consider the bounds of the 3D scene, and ignore the fact that they sacrifice Z-buffer precision as the ratio of near clipping plane distance to far clipping plane distance approaches zero. In addition, systems which only consider the bounds of the scene can suffer from the problem where objects from the very front or very back of the scene can disappear due to precision problems, even though they lie within the near and far clipping plane.
Various technologies and techniques are disclosed that improve the automatic generation of near and far clipping planes for a 3D scene. The viewing frustum is intersected with the scene to determine the range of depth that a particular scene occupies in the viewing frustum. The ratio of the near clipping plane to far clipping plane is adjusted as appropriate to ensure a desired minimum level of Z-buffer precision is achieved. Alternatively or additionally, depending on the type of projection used for the scene, the clipping of objects which are located at the near or far clipping plane is prevented.
For orthographic projections, since the precision of the Z-buffer is uniform and related to the magnitude of the difference between the far clipping plane and the near clipping plane, there is no need to change either near or far plane to account for z-buffer precision, but both planes need to be adjusted to prevent clipping of objects located right at the clipping planes. For perspective projections, the desired minimum Z-buffer precision is ensured by adjusting the near plane to maintain a desired ratio between near and far clipping planes, and then each plane is displaced by an appropriate amount to prevent clipping at the plane.
Alternatively or additionally, an API is provided to allow other programs to retrieve the near and far clipping plane values with the desired minimum Z-buffer precision for a particular scene without having to interact with the Z-buffer.
This Summary was provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description.
This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
For the purposes of promoting an understanding of the principles of the invention, reference will now be made to the embodiments illustrated in the drawings and specific language will be used to describe the same. It will nevertheless be understood that no limitation of the scope is thereby intended. Any alterations and further modifications in the described embodiments, and any further applications of the principles as described herein are contemplated as would normally occur to one skilled in the art.
The system may be described in the general context as an application that automatically generates near and far clipping planes for a 3D scene, but the system also serves other purposes in addition to these. In one implementation, one or more of the techniques described herein can be implemented as features within a 3D graphics program, or from any other type of program or service that automatically generates near and far clipping planes for a 3D scene or interacts with another program that automatically generates near and far clipping planes for a 3D scene.
As shown in
Additionally, device 100 may also have additional features/functionality. For example, device 100 may also include additional storage (removable and/or non-removable) including, but not limited to, magnetic or optical disks or tape. Such additional storage is illustrated in
Computing device 100 includes one or more communication connections 114 that allow computing device 100 to communicate with other computers and/or applications 115. Device 100 may also have input device(s) 112 such as keyboard, mouse, pen, voice input device, touch input device, etc. Output device(s) 111 such as a display, speakers, printer, etc. may also be included. These devices are well known in the art and need not be discussed at length here. In one implementation, computing device 100 includes 3D graphics application 200, as discussed in further detail in
Turning now to
3D graphics application 200 includes program logic 204, which is responsible for carrying out some or all of the techniques described herein. Program logic 204 includes logic for intersecting the bounding boxes of all scene models with the viewing frustum to determine the range of depth that the particular scene occupies in the viewing frustum (for orthographic and/or perspective projections) 206; logic for setting the near and far clipping planes according to the scene bounds 208; logic for widening the bounds a particular amount (e.g. a small amount) to account for triangles lying on the bounds (e.g. to prevent them from being accidentally clipped) 210; logic for analyzing the ratio of the near clipping plane to the far clipping plane to determine whether there is an adequate level of numerical precision in the Z-buffer 212; logic for adjusting the near and far clipping planes appropriately if the Z-buffer precision is not adequate 214; logic for providing an API to allow a separate program to manipulate and/or retrieve the near and far clipping planes for 3D scenes 216; logic for returning the near and far clipping planes for the particular scene to a separate program with the minimum Z-buffer precision provided, whereby the separate program does not have to interact with the Z-buffer 218; and other logic for operating application 220. In one implementation, program logic 204 is operable to be called programmatically from another program, such as using a single call to a procedure in program logic 204.
Turning now to
In one implementation, which works for orthographic projections, the Z-buffer is 24 bit fixed precision. As one non-limiting example, by using a desired minimum Z-buffer value of 1.5, even the nearest objects resolve to a different value in the fixed-precision Z-buffer than the near clipping plane. Using these parameters as non-limiting examples, the stages for generating the intermediate positions for the near and far planes based on the near and far scene bounds (stage 264) while widening them slightly (stage 266) are performed by solving the following equation:
and plugging the results into the following equation to compute the near plane:
The far plane can be computed by:
In one implementation, since the precision of the Z-buffer for orthographic projections is uniform and related to the magnitude of scene far bounds minus scene near bounds, and since the model size is expected to be related as well, there is no need to change either near or far plane to account for precision (stage 268). The process ends at end point 269.
In one implementation, the near and far clipping planes in the perspective projection case can be calculated using the following formulae:
In one implementation, after performing the above calculations, a value is available for the far clipping plane f and the near clipping plane n but nothing has yet been done to control the ratio between f and n, which determines the precision of the Z-buffer.
3D graphics application 200 ensures a desired minimum of precision is available throughout the depth represented by the Z-buffer (stage 280). One way to do this is to ensure a minimum of precision is available at the back of the frustum (see
Let's look at a non-limiting example to see how this works. If you think of the frustum ranging from:
then the rate of change of Z-buffer values with respect to u is:
This indicates how sampling is scaled from linear, so at the front of the frustum
Z′(0)=k
and at the back of the frustum:
This means the precision at the back of our buffer differs from a linear precision buffer by exactly the ratio between the near and the far plane.
In this non-limiting example, the final step then is to check the ratio of near clipping plane divided by far clipping plane and ensure that when multiplied by the total precision of the Z-buffer, acceptable final precision results (stage 302). If this ratio is greater than the desired ratio value r for the desired precision, then the near clipping plane is adjusted by dividing the far clipping plane by the desired ratio value r (stage 304). This ensures as much of the scene as possible fits into the frustum while maintaining a minimum of precision (stage 306). In one implementation, 3D graphics application 200 ensures that the rear of the buffer has the same precision as a 12 bit linear precision buffer, which means r=212, since the Z buffer has 24 bits in such a scenario. Other values and variations can be used in alternate implementations. The process ends at end point 308.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims. All equivalents, changes, and modifications that come within the spirit of the implementations as described herein and/or by the following claims are desired to be protected.
Number | Name | Date | Kind |
---|---|---|---|
3816726 | Sutherland et al. | Jun 1974 | A |
5088054 | Paris, II | Feb 1992 | A |
5574835 | Duluk et al. | Nov 1996 | A |
5579455 | Greene et al. | Nov 1996 | A |
5952993 | Matsuda et al. | Sep 1999 | A |
6046746 | Deering | Apr 2000 | A |
6052129 | Fowler et al. | Apr 2000 | A |
6115047 | Deering | Sep 2000 | A |
6222555 | Christofferson et al. | Apr 2001 | B1 |
6285779 | Lapidous et al. | Sep 2001 | B1 |
6453065 | Lapidous et al. | Sep 2002 | B1 |
6628284 | Fossum et al. | Sep 2003 | B1 |
6664975 | Hatch | Dec 2003 | B1 |
7170530 | Cui et al. | Jan 2007 | B2 |
20030043147 | Heim et al. | Mar 2003 | A1 |
20040169651 | Everitt et al. | Sep 2004 | A1 |
20050156927 | Lee et al. | Jul 2005 | A1 |
Number | Date | Country | |
---|---|---|---|
20070216710 A1 | Sep 2007 | US |