The disclosure of Japanese Patent Application No. 2009-38450, filed on Feb. 20, 2009, is incorporated herein by reference.
1. Field of the Invention
The present invention relates to an image processing for a three-dimensional image, and more particularly to an image processing for rendering a three-dimensional virtual space by performing perspective projection transformation and depth comparison using a Z buffer.
2. Description of the Background Art
Conventionally, a technique for rending a three-dimensional image by using a so-called Z buffer algorithm is known. Further, as one of techniques for rendering a shadow and a boundary portion in a three-dimensional image, used is a technique in which polygons corresponding to the shadow and the boundary portion are produced and the polygons are rendered so as to be slightly floated.
For example, when an object of a windmill and a shadow of the windmill are rendered in a three-dimensional virtual space, a windmill object 901 is positioned on the ground as shown in
Further, for example, in order to prevent a boundary portion between a road and lawn from being too clear, the rendering process is performed such that a polygon for obscuring a boundary covers the boundary portion.
In general, a process (so-called rendering pipeline) for rendering a three-dimensional image includes three process steps, that is, a processing based on a vertex shader, rasterization, and a processing based on a pixel shader. In the processing based on the vertex shader, various coordinate transformations are performed. In a process called perspective projection transformation (or a process called projection transformation) included in the various coordinate transformations, a Z value representing a depth from a screen surface is calculated. At this time, the Z value is typically calculated by using the following equation.
Zvalue=1+N×(1+F/Cz)/(F−N) Equation 1
wherein a variable Cz represents a Z component (the depth direction as viewed from a screen is set to a negative direction) in a camera space coordinate system, and a variable N represents a near value of a clip plane used for the perspective projection transformation, and a variable F represents a far value of the clip plane used for the perspective projection transformation.
Furthermore, a relationship between a Z value calculated by using Equation 1 and a distance from a virtual camera is represented by, for example, a graph shown in
When a polygon is slightly floated like the polygon of the shadow described above, a distance between a polygon of the ground and the polygon of the shadow is substantially small. In other words, the Z value of the polygon of the ground may be approximately equal to the Z value of the polygon of the shadow. Therefore, images having the same Z value are rendered at almost the same position or a relationship in depth (which one is in front of the other) between the images is reversed in a portion in which both the shadow polygon and the ground (polygon) are to be rendered as indicated in an example shown in
A technique for solving the flickering caused by the error in Z value stored in the Z buffer is disclosed in, for example, Japanese Laid-Open Patent Publication No. 2005-173866. A three-dimensional image display apparatus disclosed in Japanese Laid-Open Patent Publication No. 2005-173866 performs rendering process based on tone rendering. The three-dimensional image display apparatus extracts a contour of an object, and renders an outline (to be accurate, an outline polygon, which corresponds to the polygon which is slightly floated) of the extracted contour. The outline is rendered so as to have an increased thickness toward the outside direction, thereby suppressing the flickering of the outline and the object. Specifically, by thickening the outline as described above, the outline is rendered such that the object and the outline do not overlap each other.
However, the three-dimensional image display apparatus as described above has the following problems. The three-dimensional image display apparatus performs rendering by thickening the outline. In other words, the three-dimensional image display apparatus performs a transformation process for thickening the outline (polygon). Therefore, costs for the processing for transforming the outline are additionally needed. Further, a problem arises that, when the polygon is transformed for suppressing the flickering as described above, the resultant three-dimensional image may be an image different from an image intended by a developer and/or may have a design different from a design intended by a developer.
Therefore, an object of the present invention is to provide a rendering processing apparatus capable of preventing flickering caused by an error in Z value stored in a Z buffer, with increase of cost for processing being suppressed.
The present invention has the following features to attain the object mentioned above. The reference numerals, supplementary descriptions and the like in the parentheses in the following description indicate an exemplary correspondence with the embodiment described below in order to aid in understanding the present invention and are not intended to limit, in any way, the scope of the present invention.
A first aspect of the present invention is directed to a rendering processing apparatus which renders a three-dimensional virtual space by using a perspective projection transformation and a depth comparison that uses a Z buffer, and the rendering processing apparatus comprises: first rendering means (10); second rendering means (10); and calculation parameter change means (10). The first rendering means performs a first rendering process for rendering at least one first-type polygon included in polygons to be rendered in a rendering process of one frame, the at least one first-type polygon being classified as a first type. The second rendering means performs a second rendering process for rendering at least one second-type polygon included in the polygons to be rendered in the rendering process of the one frame, the at least one second-type polygon being classified as a second type. The calculation parameter change means changes a parameter used for calculating, in the perspective projection transformation, a depth value used for the depth comparison that uses the Z buffer such that the depth value calculated in the first rendering process indicates a position which is closer to a virtual camera than the depth value calculated in the second rendering process. The second rendering means performs the second rendering process for rendering the at least one second-type polygon by using the parameter acquired from the calculation parameter change means.
According to the first aspect, it is possible to prevent flickering caused by an error in Z value stored in a Z buffer, thereby displaying a three-dimensional image.
In a second aspect based on the first aspect, the calculation parameter change means changes the parameter such that at least one of a position of a near clip plane and a position of a far clip plane, both of which are used by the first rendering means, is changed.
In a third aspect based on the second aspect, the calculation parameter change means changes the parameter such that a distance between the virtual camera and the at least one of the position of the near clip plane and the position of the far clip plane is increased.
According to the second and the third aspects, as the depth value calculated in the perspective projection transformation of the second rendering process, a value representing a position which is closer to the virtual camera than a position represented by the depth value calculated in the first rendering process can be calculated without transforming a polygon model in a space based on the world coordinate system.
In a fourth aspect based on the first aspect, the calculation parameter change means changes the parameter by setting a predetermined offset value to be added to the depth value calculated in the perspective projection transformation.
In a fifth aspect based on the fourth aspect, the calculation parameter change means sets the predetermined offset value by changing a parameter indicating a range of values which are stored in the Z buffer and used in the perspective projection transformation.
According to the fourth and the fifth aspects, it is possible to prevent flickering caused by an error in Z value stored in the Z buffer without increasing cost for processing.
In a sixth aspect based on the first aspect, the second rendering means renders the at least one second-type polygon so as to be displayed translucent.
According to the sixth aspect, it is possible to render a three-dimensional image with enhanced reality.
In a seventh aspect based on the first aspect, the at least one second-type polygon is positioned, in the three-dimensional virtual space, adjacent to a predetermined one of the at least one first-type polygon, so as to be closer to the virtual camera than the predetermined one of the at least one first-type polygon.
According to the seventh aspect, it is certain that, as a result of the depth comparison using the Z buffer, a predetermined one of the second-type polygon is determined as being closer to the virtual camera than the predetermined one of the first-type polygon.
In an eighth aspect based on the first aspect, each of the first rendering process performed by the first rendering means and the second rendering process performed by the second rendering means includes: a first transformation process for transforming a coordinate of a polygon in a world coordinate system to a coordinate in a camera coordinate system; a second transformation process for subjecting the coordinate in the camera coordinate system to a perspective transformation, the coordinate in the camera coordinate system being obtained through the first transformation process; a third transformation process for transforming a coordinate obtained through the perspective transformation, to a coordinate in a view port coordinate system; and a Z comparison process for rendering a pixel in accordance with the depth comparison that uses the Z buffer.
According to the eighth aspect, while a three-dimensional image rendering process which is typically used is utilized, the flickering caused by an error in Z value stored in the Z buffer can be prevented without increasing cost for processing, thereby displaying a three-dimensional image.
A ninth aspect of the present invention is directed to a computer-readable storage medium having stored therein a rendering processing program executed by a computer of a rendering processing apparatus which renders a three-dimensional virtual space by using a perspective projection transformation and a depth comparison that uses a Z buffer, and the computer is caused to function as: first rendering means (S11, S12, S13); second rendering means (S15, S16); and calculation parameter change means (S14). The first rendering means performs a first rendering process for rendering at least one first-type polygon included in polygons to be rendered in a rendering process of one frame, the at least one first-type polygon being classified as a first type. The second rendering means performs a second rendering process for rendering at least one second-type polygon included in the polygons to be rendered in the rendering process of the one frame, the at least one second-type polygon being classified as a second type. The calculation parameter change means changes a parameter used for calculating, in the perspective projection transformation, a depth value used for the depth comparison that uses the Z buffer such that the depth value calculated in the first rendering process indicates a position which is closer to a virtual camera than the depth value calculated in the second rendering process. The second rendering means performs the second rendering process for rendering the at least one second-type polygon by using the parameter acquired from the calculation parameter change means.
In a tenth aspect based on the ninth aspect, the calculation parameter change means changes the parameter such that at least one of a position of a near clip plane and a position of a far clip plane, both of which are used by the first rendering means, is changed.
In an eleventh aspect based on the tenth aspect, the calculation parameter change means changes the parameter such that a distance between the virtual camera and the at least one of the position of the near clip plane and the position of the far clip plane is increased.
In a twelfth aspect based on the ninth aspect, the calculation parameter change means changes the parameter by setting a predetermined offset value to be added to the depth value calculated in the perspective projection transformation.
In a thirteenth aspect based on the twelfth aspect, the calculation parameter change means sets the predetermined offset value by changing a parameter indicating a range of values which are stored in the Z buffer and used in the perspective projection transformation.
In a fourteenth aspect based on the ninth aspect, the second rendering means renders the at least one second-type polygon so as to be displayed translucent.
In a fifteenth aspect based on the ninth aspect, the at least one second-type polygon is positioned, in the three-dimensional virtual space, adjacent to a predetermined one of the at least one first-type polygon, so as to be closer to the virtual camera than the predetermined one of the at least one first-type polygon.
In a sixteenth aspect based on the ninth aspect, each of the first rendering process performed by the first rendering means and the second rendering process performed by the second rendering means includes: a first transformation process (S34) for transforming a coordinate of a polygon in a world coordinate system to a coordinate in a camera coordinate system; a second transformation process (S36) for subjecting the coordinate in the camera coordinate system to a perspective transformation, the coordinate in the camera coordinate system being obtained through the first transformation process; a third transformation process (S37) for transforming a coordinate obtained through the perspective transformation, to a coordinate in a view port coordinate system; and a Z comparison process (S40, S41, S42) for rendering a pixel in accordance with the depth comparison that uses the Z buffer.
The computer-readable storage medium having stored therein the rendering processing program of the present invention enables the same effect as obtained by the rendering process apparatus according to the present invention.
According to the present invention, it is possible to prevent flickering caused by an error in Z value stored in a Z buffer while suppressing increase of cost for processing performed by a computer.
These and other objects, features, aspects and advantages of the present invention will become more apparent from the following detailed description of the present invention when taken in conjunction with the accompanying drawings.
(Overall Configuration of Game System)
With reference to
Into the game apparatus 3, the optical disc 4, which typifies an information storage medium and is exchangeable with respect to the game apparatus 3, is detachably inserted. In the optical disc 4, the game program executed by the game apparatus 3 is stored. The game apparatus 3 has, on the front surface thereof, an opening through which the optical disc 4 is inserted. The game apparatus 3 executes the game processing by reading and executing the game program stored in the optical disc 4 which is inserted in the game apparatus 3 through the opening.
The game apparatus 3 is connected through a connection cord to the television 2 typifying a display device. The television 2 displays a game image generated through the game processing executed by the game apparatus 3. Further, the marker section 8 is provided in the vicinity of the screen of the television 2 (on the top surface of the screen of the television 2 in
The controller 7 is an input device for supplying, to the game apparatus 3, operation data representing a content of an operation performed on the controller 7. The controller 7 is connected to the game apparatus 3 by wireless communication. In the embodiments, for example, the Bluetooth (registered trademark) technology is used for the wireless communication between the controller 7 and the game apparatus 3. In another embodiment, the controller 7 and the game apparatus 3 may communicate with each other by a wired connection.
(Internal Structure of Game Apparatus 3)
Next, with reference to
The CPU 10, serving as a game processor, executes the game program stored in the optical disc 4 so as to perform the game processing. The CPU 10 is connected to the system LSI 11. In addition to the CPU 10, the external main memory 12, the ROM/RTC 13, the disc drive 14, and the AV-IC 15 are also connected to the system LSI 11. The system LSI 11 performs processing such as control of data transmission between respective components connected thereto, generation of an image to be displayed, and acquisition of data from an external apparatus. An internal structure of the system LSI 11 will be described below. The external main memory 12, which is of a volatile type, stores programs, such as a game program loaded from the optical disc 4 or a flash memory 17, and various data, and is used as a work area and a buffer area for the CPU 10. The ROM/RTC 13 includes a ROM (so-called a boot ROM) incorporating a program for booting the game apparatus 3, and a clock circuit (RTC: real time clock) for counting time. The disc drive 14 reads, from the optical disc 4, program data, texture data and the like, and writes the read data into an internal main memory 11e described below or the external main memory 12.
Provided in the system LSI 11 are an input/output processor 11a, a GPU (graphics processor unit) 11b, a DSP (digital signal processor) 11c, a VRAM 11d, and the internal main memory 11e. These component 11a, 11b, 11c, 11d and 11e are connected to each other via an internal bus not shown.
The GPU 11b, which is a part of rendering means, generates an image in accordance with a graphics command (draw command) supplied from the CPU 10. More specifically, the GPU 11b performs a calculation process necessary for displaying 3D graphics in accordance with the graphics command, such as a process of transforming a 3D coordinate to a 2D coordinate, which corresponds to a preprocessing for rendering, and a final rendering process such as texture mapping, thereby generating game image data. The CPU 10 supplies, to the GPU 11b, a command based on an image generation program necessary for generating the game image data in addition to the graphics command. The VRAM 11d stores data (such as polygon data and texture data) necessary for the GPU 11b to execute the graphics command. When an image is generated, the GPU 11b generates image data by using the data stored in the VRAM 11d.
The DSP 11c functions as an audio processor, and generates audio data by using sound data and sound waveform (tone quality) data stored in the internal main memory 11e and the external main memory 12. The internal main memory 11e stores a program and various data, and is used as a work area and a buffer area for the CPU 10, as with the external main memory 12.
The image data and the audio data generated as described above, are read by the AV-IC 15. The AV-IC 15 outputs the read image data to the television 2 via an AV connector 16, and also outputs the read audio data to a speaker 2a of the television 2. Thus, an image is displayed on the television 2, and a sound is outputted from the speaker 2a.
The input/output processor (I/O processor) 11a executes data reception and transmission among the components connected thereto and download of data from an external apparatus. The I/O processor 11a is connected to the flash memory 17, a wireless communication module 18, a wireless controller module 19, an extension connector 20, and a memory card connector 21. To the wireless communication module 18, an antenna 22 is connected, and to the wireless controller module 19, an antenna 23 is connected.
The I/O processor 11a is connected to a network via the wireless communication module 18 and the antenna 22 so as to communicate with other game apparatuses or various servers connected to the network. The I/O processor 11a accesses the flash memory 17 at regular time intervals so as to detect for data to be transmitted to the network. When the data to be transmitted is detected, the data is transmitted to the network via the wireless communication module 18 and the antenna 22. Further, the I/O processor 11a receives, via the network, the antenna 22 and the wireless communication module 18, data transmitted from the other game apparatuses or data downloaded from a download server, and stores the received data in the flash memory 17. The CPU 10 executes the game program so as to read the data stored in the flash memory 17, thereby using the read data on the game program. The flash memory 17 may store not only the data transmitted and received among the game apparatus 3, and other game apparatuses or the various servers, but also saved data (result data or intermediate step data of the game) of a game played with the game apparatus 3.
Further, the I/O processor 11a receives the operation data transmitted from the controller 7, via the antenna 23 and the wireless controller module 19, and (temporarily) stores the operation data in a buffer area of the internal main memory 11e or the external main memory 12.
Further, the I/O processor 11a is connected to the extension connector 20 and the memory card connector 21. The extension connector 20 is a connector used for interface such as a USB and an SCSI, and is connected to a medium such as an external storage medium, or a peripheral device such as another controller, or a wired communication connector so as to allow communication with the network, without using the wireless communication module 18. The memory card connector 21 is a connector for connecting to the memory card connector 21 the external storage medium such as a memory card. For example, the I/O processor 11a accesses the external storage medium via the extension connector 20 or the memory card connector 21, so as to store data in the external storage medium or read data from the external storage medium.
The game apparatus 3 includes a power button 24, a reset button 25, and an eject button 26. The power button 24 and the reset button 25 are connected to the system LSI 11. When the power button 24 is pressed so as to be ON, the power is supplied to the respective components of the game apparatus 3 via an AC adapter which is not shown. Further, when the power button 24, which is ON, is pressed again, the game apparatus 3 shifts to a low power standby mode. Also in this state, power is being supplied to the game apparatus 3, and therefore the game apparatus 3 continues to be connected to the network such as the Internet. When the power supply, which is ON, is to be OFF, the power supply can be OFF by pressing the power button 24 for a predetermined time period or longer period. When the reset button 25 is pressed, the system LSI 11 restarts a boot program of the game apparatus 3. The eject button 26 is connected to the disc drive 14. When the eject button 26 is pressed, the optical disc 4 is ejected from the disc drive 14.
With reference to
As shown in
At the center of the front portion of the top surface of the housing 71, a cross key 72a is provided. The cross key 72a is a cross-shaped four-direction push switch. The cross key 72a includes operation portions corresponding to the four directions (front, rear, right and left), which are located on cross-shaped projecting portions, respectively, arranged at intervals of 90 degrees. A player selects one of the front, rear, right and left directions by pressing a corresponding one of the operation portions of the cross key 72a. Through an operation on the cross key 72a, the player can, for example, indicate a direction in which a player character or the like appearing in a virtual game world is to move or select one of a plurality of options.
Although the cross key 72a is an operation section for outputting an operation signal in accordance with the aforementioned direction input operation performed by the player, such an operation section may be provided in another form. For example, the cross key 72a may be replaced with an operation section, including four push switches corresponding to directions, respectively, represented by a cross, for outputting an operation signal in accordance with the push switch having been pressed by the player. Alternatively, the cross key 72a may be replaced with an operation section including the aforementioned four push switches and a center switch provided at the center of the cross formed by the four push switches. Alternatively, the cross key 72a may be replaced with an operation section which includes an inclinable stick (so-called a joystick) projecting from the top surface of the housing 71 and outputs an operation signal in accordance with the inclining direction of the stick. Still alternatively, the cross key 72a may be replaced with an operation section which includes a disc-shaped member horizontally slidable and outputs an operation signal in accordance with the sliding direction of the disc-shaped member. Still alternatively, the cross key 72a may be replaced with a touch pad.
Behind the cross key 72a on the top surface of the housing 71, a plurality of operation buttons 72b, 72c, 72d, 72e, 72f and 72g are provided. The operation buttons 72b, 72c, 72d, 72e, 72f and 72g are operation sections for outputting operation signals assigned to the operation buttons 72b, 72c, 72d, 72e, 72f and 72g, respectively, when the player presses a head thereof. For example, the operation buttons 72b, 72c, and 72d are assigned with functions of a first button, a second button, and an A button, for example. Further, the operation buttons 72e, 72f and 72g are assigned with functions of a minus button, a home button and a plus button, for example. The operation buttons 72a, 72b, 72c, 72d, 72e, 72f and 72g are assigned with various operation functions in accordance with the game program executed by the game apparatus 3. In an exemplary arrangement shown in
In front of the cross key 72a on the top surface of the housing 71, an operation button 72h is provided. The operation button 72h is a power switch for remote-controlling the power of the game apparatus 3 to be on or off. The operation button 72h also has a top surface thereof buried in the top surface of the housing 71, so as not to be inadvertently pressed by the player.
Behind the operation button 72c on the top surface of the housing 71, a plurality of LEDs 702 are provided. The controller 7 is assigned a controller type (number) so as to be distinguishable from the other controllers 7. For example, the LEDs 702 are used for informing the player of the controller type which is currently set to controller 7 that he or she is using. Specifically, when the controller 7 transmits transmission data to the game apparatus 3, one of the plurality of LEDs 702 is lit up so as to correspond to the controller type.
On the top surface of the housing 71, a sound hole for outputting a sound from a speaker (speaker 706 shown in
On the bottom surface of the housing 71, a recessed portion is formed. As described below in detail, the recessed portion is formed at a position at which an index finger or middle finger of a player is located when the player holds the controller 7 with one hand so as to orient the front surface thereof to the markers 8L and 8R. On a slope surface of the recessed portion on the bottom surface of the housing 71, an operation button 72i is provided. The operation button 72i is an operation section acting as, for example, a B button.
On the front surface of the housing 71, an image pickup element 743 included in the imaging information calculation section 74 is provided. The imaging information calculation section 74 is a system for analyzing image data taken by the controller 7 and detecting the position of the center of gravity, the size and the like of an area having a high brightness in the image data. The imaging information calculation section 74 has, for example, a maximum sampling period of about 200 frames/sec., and therefore can trace and analyze even a relatively fast motion of the controller 7. The imaging information calculation section 74 will be described below in detail. On the rear surface of the housing 71, a connector 73 is provided. The connector 73 is, for example, an edge connector, and is used for engaging and connecting the controller 7 with, for example, a connection cable.
Here, for giving specific description, a coordinate system is defined for the controller 7. As shown in
With reference to
As shown in
The wireless module 753 (see
As shown in
On the bottom main surface of the substrate 700, a vibrator 704 is provided. The vibrator 704 may be, for example, a vibration motor or a solenoid. The vibrator 704 is connected to the microcomputer 751 by a wiring formed on the substrate 700 or the like, and is controlled so as to be ON/OFF in accordance with vibration data transmitted from the game apparatus 3. The controller 7 is vibrated by an actuation of the vibrator 704, and the vibration is conveyed to the player's hand holding the controller 7. Thus, a so-called vibration-feedback game is realized. The vibrator 704 is positioned slightly in front of the longitudinal center of the housing 71, and therefore a vibration of the housing 71 is enhanced so as to allow a player holding the controller 7 to easily feel the controller 7 vibrating.
With reference to
As shown in
The imaging information calculation section 74 includes the infrared filter 741, the lens 742, the image pickup element 743 and the image processing circuit 744. The infrared filter 741 allows only infrared light to pass therethrough, among light incident on the front surface of the controller 7. The lens 742 collects the infrared light which has passed through the infrared filter 741 and outputs the infrared light to the image pickup element 743. The image pickup element 743 is a solid-state image pickup device such as, for example, a CMOS sensor or a CCD. The image pickup element 743 takes an image of the infrared light collected by the lens 742. Accordingly, the image pickup element 743 takes an image of only the infrared light which has passed through the infrared filter 741 and generates image data. The image data generated by the image pickup element 743 is processed by the image processing circuit 744. Specifically, the image processing circuit 744 processes the image data obtained from the image pickup element 743, identifies a spot thereof having a high brightness, and outputs, to the communication section 75, process result data representing a position coordinate point and the area size of the identified spot. The imaging information calculation section 74 is fixed to the housing 71 of the controller 7. The imaging direction of the imaging information calculation section 74 can be changed by changing the direction of the housing 71. A signal corresponding to a position and/or a movement of the controller 7 can be obtained based on the process result data outputted by the imaging information calculation section 74.
The controller 7 preferably includes a three-axis (x-axis, y-axis, and z-axis) acceleration sensor 701. The three-axis acceleration sensor 701 detects a linear acceleration in three directions, i.e., the up/down direction, the left/right direction, and the forward/backward direction. Further, in another embodiment, a two-axis acceleration detection means which detects for only a linear acceleration along each of the up/down and left/right directions (or other pair of directions) may be used depending on the type of control signals used in the game process. For example, the three-axis or two-axis acceleration sensor 701 may be of the type available from Analog Devices, Inc. or STMicroelectronics N.V. The acceleration sensor 701 may be of an electrostatic capacitance (capacitance-coupling) type that is based on silicon micro-machined MEMS (Micro Electro Mechanical Systems) technology. However, an acceleration detection technology (e.g., piezoelectric type or piezoresistance type) now existing or any other suitable technology later developed may be used to provide the three-axis or two-axis acceleration sensor 701.
As one skilled in the art understands, the acceleration detection means, as used in the acceleration sensor 701, are capable of detecting for only an acceleration (linear acceleration) along a straight line corresponding to each axis of the acceleration sensor. In other words, the direct output of the acceleration sensor 701 is limited to signals indicative of linear acceleration (static or dynamic) along each of the two or three axes thereof. As a result, the acceleration sensor 701 cannot directly detect movement along a non-linear (e.g. arcuate) path, rotation, rotational movement, angular displacement, tilt, position, attitude or any other physical characteristic.
However, when a computer such as a processor (for example, the CPU 10) of a game apparatus or a processor (for example, the microcomputer 751) of the controller performs a process based on a signal of an acceleration outputted by the acceleration sensor 701, additional information relating to the controller 7 can be inferred or calculated (determined), as one skilled in the art will readily understand from the description herein. For example, a case where the computer will perform a process assuming that a controller including the acceleration sensor is in a static state (that is, a case where it is anticipated that an acceleration detected by the acceleration sensor will include only a gravitational acceleration) will be described. When the controller is actually in the static state, it is possible to determine whether or not the controller tilts relative to the gravity direction and to also determine a degree of the tilt, based on the acceleration having been detected. Specifically, when a state where 1G (gravitational acceleration) is applied to a detection axis of the acceleration sensor in the vertically downward direction represents a reference, it is possible to determine whether or not the controller tilts relative to the vertically downward direction, based on only whether or not 1G is applied in the direction of the detection axis of the acceleration sensor. Further, it is possible to determine a degree to which the controller tilts relative to the vertically downward direction, based on a magnitude of the acceleration applied in the direction of the detection axis. Further, the acceleration sensor capable of detecting an acceleration in multiaxial directions subjects, to a processing, the acceleration signals having been detected in the respective axes so as to more specifically determine the degree to which the controller tilts relative to the gravity direction. In this case, although the processor may calculate, based on the output from the acceleration sensor 701, data representing an angle at which the controller 7 tilts, an approximate degree to which the controller 7 tilts may be inferred based on the output from the acceleration sensor 701 without calculating the data representing the angle of the tilt. Thus, when the acceleration sensor 701 is used in combination with the processor, the tilt, attitude, or position of the controller 7 can be determined. On the other hand, in a case where it is anticipated that the acceleration sensor will be in a dynamic state, the acceleration sensor detects an acceleration based on a movement of the acceleration sensor, in addition to the gravitational acceleration component. Therefore, when the gravitational acceleration component is eliminated through a predetermined process, it is possible to determine, for example, a direction in which the controller 7 moves. Specifically, when the controller 7 including the acceleration sensor 701 is dynamically accelerated and moved with a hand of a user, it is possible to calculate various movements and/or positions of the controller 7 by processing the acceleration signals generated by the acceleration sensor 701. Even when it is anticipated that the acceleration sensor will be in the dynamic state, the acceleration based on the movement of the acceleration sensor is eliminated through a predetermined process, whereby it is possible to determine the tilt of the controller 7 relative to the gravity direction. In another embodiment, the acceleration sensor 701 may include an embedded signal processor or another type of dedicated processor for performing any desired processing of the acceleration signals outputted by embedded acceleration detection means prior to outputting signals to the microcomputer 751. For example, when the acceleration sensor is intended to detect static acceleration (for example, gravitational acceleration), the embedded or dedicated processor could convert the detected acceleration signal to a corresponding tilt angle (or another preferable parameter).
In another exemplary embodiment, a gyro-sensor incorporating a rotating element, vibrating element, or the like may be used as a movement sensor for detecting for a movement of the controller 7. Exemplary MEMS gyro-sensors that may be used in the embodiments are available from Analog Devices, Inc. Unlike the acceleration sensor 701, a gyro-sensor is capable of directly detecting rotation (or angular rate) around at least one axis defined by the gyroscopic element therein. Thus, due to the fundamental differences between a gyro-sensor and an acceleration sensor, corresponding changes need to be made to the processing operations that are performed on the output signals from these devices depending on which device is selected for a particular application.
More specifically, when the tilt or attitude is calculated using a gyro-sensor instead of the acceleration sensor, significant changes are necessary. Specifically, when using a gyro-sensor, the value of the tilt is initialized at the start of the detection. Then, data on the angular rate which is output from the gyro-sensor is integrated. Next, a change amount in tilt from the value of the tilt initialized is calculated. In this case, the calculated tilt corresponds to an angle. In contrast, when the acceleration sensor calculates the tilt, the tilt is calculated by comparing the value of the gravitational acceleration of each axial component with a predetermined reference. Therefore, the calculated tilt can be represented as a vector. Thus, without initialization, an absolute direction can be determined with acceleration detection means. The type of the value calculated as the tilt is also very different between a gyro sensor and an acceleration sensor; i.e., the value is an angle when a gyro sensor is used and is a vector when an acceleration sensor is used. Therefore, when a gyro sensor is used instead of an acceleration sensor or vice versa, data on tilt also needs to be processed through a predetermined conversion taking into account the fundamental differences between these two devices. Due to the fact that the nature of a gyro sensor is known to one skilled in the art, as well as the fundamental differences between the acceleration detection means and the gyro sensor, further details are not provided herein. While a gyro-sensor is advantageous in that a rotation can be directly detected, an acceleration sensor is generally more cost effective when used in connection with the controller described herein.
The communication section 75 includes the microcomputer 751, a memory 752, the wireless module 753 and the antenna 754. The microcomputer 751 controls the wireless module 753 for wirelessly transmitting the transmission data while using the memory 752 as a storage area during the processing. The microcomputer 751 controls operations of the sound IC 707 and the vibrator 704 based on the data received from the game apparatus 3 by the wireless module 753 via the antenna 754. The sound IC 707 processes the sound data and the like transmitted from the game apparatus 3 via the communication section 75. Further, the microcomputer 751 actuates the vibrator 704 based on, for example, the vibration data (for example, a signal for powering the vibrator 7040N or OFF) transmitted by the game apparatus 3 via the communication section 75.
Data from the controller 7 including an operation signal (key data) from the operation section 72, acceleration signals (x, y, and z-axial direction acceleration data, and hereinafter, simply referred to as acceleration data) from the acceleration sensor 701, and the process result data from the imaging information calculation section 74 are outputted to the microcomputer 751. The microcomputer 751 temporarily stores the respective input data (the key data, the acceleration data, and process result data) in the memory 752 as the transmission data which is to be transmitted to the wireless controller module 19. The wireless transmission from the communication section 75 to the wireless controller module 19 is performed periodically at predetermined time intervals. Since game processing is generally performed at a cycle of 1/60 sec., data needs to be transmitted at a cycle of a time period shorter than the cycle of the game processing. Specifically, the game process unit is 16.7 ms ( 1/60 sec.), and the transmission interval of the communication section 75 structured using the Bluetooth (registered trademark) technology is, for example, 5 ms. At a time at which the transmission to the wireless controller module 19 is to be performed, the microcomputer 751 outputs the transmission data stored in the memory 752 as a series of operation information to the wireless module 753. The wireless module 753 uses, for example, the Bluetooth (registered trademark) technology to transmit, from the antenna 754, operation information as a radio wave signal by using a carrier wave of a predetermined frequency. Thus, data from the controller 7 including the key data from the operation section 72, the acceleration data from the acceleration sensor 701, and the process result data from the imaging information calculation section 74 are modulated to a radio wave signal by the wireless module 753, and the radio wave signal is transmitted from the controller 7. The wireless controller module 19 of the game apparatus 3 receives the radio wave signal, and the game apparatus 3 demodulates or decodes the radio wave signal to obtain the series of operation information (the key data, the acceleration data, and the process result data). Based on the obtained operation information and the game program, the CPU 10 of the game apparatus 3 performs the game processing. When the communication section 75 is structured by using the Bluetooth (registered trademark) technology, the communication section 75 can function so as to receive transmission data which is wirelessly transmitted from another device.
Next, an outline of a rendering process according to the present embodiment will be described. In the present embodiment, an image of a three-dimensional virtual space is taken by a virtual camera, and the taken image is rendered. Further, in the present embodiment, the rendering process is performed by using a so-called Z buffer algorithm.
Further, in the present embodiment, used is a technique in which, in order to represent a shadow of a windmill object 101 and the like, a polygon 102 for the shadow is positioned so as to be slightly floated above the ground as in an image shown in
In the processing according to the present embodiment, polygons to be rendered (in a frame) are classified into two types. One is referred to as a normal polygon, and the other is referred to as a floated polygon. For example, in an example shown in
A rendering process for the normal polygon, and a rendering process for the floated polygon are separately performed. At this time, at least one of a near value and a far value of a clip space (hereinafter, also referred to as a view volume) used in the perspective projection transformation in the rendering process for the floated polygon, is set to a value which is greater than a value used in the perspective transformation process for the normal polygon (that is, set to such a value as to increase a distance from the virtual camera).
The processing will be described in detail. Initially, the rendering process (rendering pipeline) according to the present embodiment is performed by using the following rendering manner. Specifically, performed is a processing based on a so-called vertex shader including a transformation (so-called world transformation) from local coordinates to world coordinates, a transformation (so-called viewing transformation) from the world coordinates to camera coordinates, a clipping process, the perspective projection transformation (so-called projection transformation), a transformation (so-called view port transformation, which is also referred to as a screen transformation) to screen coordinates. Thereafter, rasterization is performed, and a processing based on a so-called pixel shader (texture mapping, so-called depth test, an alpha text, and the like) is performed.
In the present embodiment, the normal polygon is firstly rendered in the processing described above. At this time, in the clipping process performed in the projection transformation, predetermined values are used as the far value and the near value, respectively, of the clip space.
The floated polygon is secondly rendered in the same processing as described above. At this time, however, as the far value and/or the near value of the clip space, a value (values) different from the value(s) used for the normal polygon is (are) used, in the present embodiment. More specifically, at least one of the near value (representing a near clip plane) and the far value (representing a far clip plane) is set to such a value as to represent a deeper position at which the distance from the camera is increased (for example, see
The settings of the far value and the near value will be described with reference to graphs shown in
As a result, for example, at a point P131, shown in
For easier understanding, in
As described above, in the present embodiment, polygons to be rendered in one frame are classified into the normal polygon and the floated polygon. The near value and the far value of the clip space used for performing the perspective projection transformation for the normal polygon, are set so as to be different from the near value and the far value of the clip space used for performing the perspective projection transformation for the floated polygon. Thus, it is certain that, as a result of the depth test performed in a following process (the processing based on the pixel shader), the floated polygon is determined as being positioned in front of (closer to the virtual camera than) the normal polygon in the virtual space, without moving or transforming the floated polygon. Therefore, it is possible to prevent flickering caused by an error in Z value stored in the Z buffer from occurring between the normal polygon and the floated polygon which are positioned substantially close to each other.
In the example shown in
Next, a game process as an exemplary image processing performed by the game apparatus 3 will be described in detail. Initially, data which is stored in the external main memory 12 in the game process will be described.
The program storage area 120 stores a game program executed by the CPU 10, and the game program includes a main process program 121, a rendering process program 122, and the like. The main process program 121 is a program for performing a processing shown in a flow chart of
The data storage area 123 stores data such as normal polygon data 124, floated polygon data 125, a clipping setting table 126, and other data necessary for the game process.
The normal polygon data 124 is data (vertex data, texture data, and the like) representing a model of a polygon classified as the normal polygon. Specifically, the normal polygon data 124 is data for polygons representing a topography object, the windmill object 101, and the like.
The floated polygon data 125 is data representing a model of a polygon classified as the floated polygon. Specifically, the floated polygon data 125 is data for polygons, such as the polygon 102 for a shadow, which are positioned so as to be slightly floated above the ground in the virtual space.
The clipping setting table 126 defines the near value and the far value of the clip space used for rendering the normal polygon, and the near value and the far value of the clip space used for rendering the floated polygon.
Next, the game process performed as an exemplary rendering process by the game apparatus 3 will be described with reference to
As shown in
Next, in step S2, the rendering process for rendering a state of the virtual game space based on the process performed in step S1 is performed.
As shown in
Next, in step S12, the “normal polygon” is selected as a polygon to be rendered. Specifically, the CPU 10 designates the normal polygon data 124 as polygon data used for rendering a polygon as described below (as data used in the processing based on the vertex shader described below).
Next, in step S13, the polygon rendering process for the normal polygon is performed.
As shown in
Next, in step S32, data corresponding to one polygon is read from the normal polygon data 124 (data corresponding to one polygon is selected from among polygon data which are not processed).
Subsequently, in step S33, coordinate transformation (world transformation) from a local coordinate to a world coordinate is performed for the read one polygon. Further, in step S34, coordinate transformation (viewing transformation) from the world coordinate to a camera coordinate is performed.
Next, the projection transformation is performed. Firstly, in step S35, the clip space is set by using the near value and the far value (the near value is 1.0 and the far value is 120000 in this case) set in step S11.
Next, in step S36, the perspective projection transformation is performed. A Z coordinate value Zclip, of the clip space, for the polygon to be processed is calculated by using, for example, the following equation.
Zclip=Zeye×(−n)/(f−n)−f×n/(f−n)
wherein a variable n represents a positive distance (that is, the near value) to a near clip plane, a variable f represents a positive distance (that is, the far value) to a far clip plane, and a variable Zeye represents a Z coordinate value of the polygon, to be processed, which has been subjected to the transformation to the camera coordinate.
Next, in step S37, coordinate transformation (view port transformation) to a coordinate in a screen coordinate system (view port coordinate system) is performed. A Z coordinate value Zscreen, of the screen space, for the polygon to be processed is calculated by using, for example, the following equation.
Wclip=−Zeye
Zscreen=Zclip/Wclip+f Equation 2
wherein a variable Wclip represents a so-called W value, that is, a value representing a scale of a view volume (a value of a homogeneous coordinate system).
After the transformation to the screen coordinate, a processing based on the pixel shader for the polygon is then performed (step S38 to S42). Initially, in step S38, whether or not all the pixels (that is, the pixels of the polygon being currently processed) to be processed have been processed is determined. When the result of the determination indicates that all the pixels have not been processed (No in step S38), a pixel to be processed is selected (a pixel to be firstly processed is selected when a process loop of the processing based on the pixel shader is started) in step S39.
Next, a so-called depth test (Z test) is performed. Specifically, in step S40, the Z value of the pixel being currently processed is compared with the Z value stored in the Z buffer. In the present embodiment, the Z values stored in the Z buffer range from 0.0 (representing a position near the virtual camera) to 1.0 (representing a deeper position). Subsequently, in step S41, whether or not the Z value of the pixel being currently processed is smaller than the Z value stored in the Z buffer (that is, whether or not the Z value of the pixel being currently processed represents a position closer to the virtual camera than the Z value stored in the Z buffer) is determined. When the result of the determination indicates that the Z value of the pixel being currently processed is smaller than the Z value stored in the Z buffer (YES in step S41), a process for rendering the pixel is performed in step S42. Thereafter, the process is returned to step S38, and the same process step as described above is repeated. On the other hand, when the result of the determination of step S41 indicates that the Z value of the pixel being currently processed is not smaller than the Z value stored in the Z buffer (NO in step S41), the process step of step S42 is not performed (that is, the pixel is not rendered), and the process is returned to step S38, and the same process step as described above is repeated.
On the other hand, when a result of the determination of step S38 indicates that all the pixels to be processed have been processed (YES in step S38), it means that the processing based on the pixel shader for the polygon being currently processed is completed. Therefore, the process is returned to step S31, and the same process step as described above is repeated. Specifically, the processing based on the vertex shader and the processing based on the pixel shader for a polygon which has not been processed are performed.
When a result of the determination of step S31 indicates that the processing based on the vertex shader for all the polygons (normal polygons in this case) to be processed has been performed (YES in step S31), the polygon rendering process is ended.
Returning to
Next, in step S15, the “floated polygon” is selected as a polygon to be rendered. Specifically, the CPU 10 designates the floated polygon data 125 as polygon data used for rendering a polygon.
Next, in step S16, the polygon rendering process for the floated polygon is performed. The polygon rendering process for the floated polygon is similar to the polygon rendering process of step S13 described above. Therefore, detailed description is not given. However, the polygon rendering process of step S16 is different from the polygon rendering process of step S13 in the following points. That is, in step S16, a polygon to be processed is the floated polygon, and the clip space based on the near value and the far value which are set in step S14 for the floated polygon is used in the perspective projection transformation of step S36. Therefore, a value representing a position which is closer to the virtual camera than a position represented by the Z value of the normal polygon is calculated as the Z value of the floated polygon as shown in the graph of
When the rendering process of step S16 for the floated polygon is completed, the polygon rendering process is ended.
Returning to
As described above, in the present embodiment, the polygons to be rendered are classified into the normal polygon and the floated polygon. The near value and the far value of the clip space are set so as to be different between the normal polygon and the floated polygon, and, for example, the perspective projection transformation for the normal polygon and the perspective projection transformation for the floated polygon are performed separately from each other based on the respective clip spaces. Therefore, it is certain that, as a result of the depth test, the floated polygon is determined as being closer to the virtual camera than the normal polygon as compared to a case where the perspective projection transformation for the floated polygon and the perspective projection transformation for the normal polygon are performed by using a common clip space (the same near value and far value are used for both the floated polygon and the normal polygon). In other words, in the depth test, the floated polygon can be determined as having been shifted toward the virtual camera. As a result, for example, when the normal polygon and the floated polygon which have close relationship, such as a relationship between a ground polygon and a shadow polygon, are to be rendered, the floated polygon can be rendered with enhanced accuracy. In other words, it is possible to prevent a state where the floated polygon is not rendered due to the floated polygon being positioned at a position deeper than the normal polygon, thereby preventing flickering caused by an error in Z value stored in the Z buffer.
In addition, it is easy to change the settings of the near value and the far value of the clip space used in the perspective transformation process. Therefore, the number of times processing is performed is not increased depending on the number of polygons. Therefore, processing costs necessary for the rendering process is not substantially increased.
Further, a position of the floated polygon is not changed in the world coordinate system or a contour of the floated polygon is not changed in order to prevent the flickering. Therefore, designs and images intended by a game creator can be represented with enhanced accuracy.
Next, a second embodiment of the present invention will be described with reference to
A concept of a processing according to the second embodiment will be described with reference to
The curved line 231 shown in
Z=(1+D)+n×(1+f/Cz)/(f−n)
wherein a variable Z represents a Z value; a variable D represents a negative constant offset value; a variable Cz represents a Z component in the camera space coordinate system; a variable n represents the near value of the clip space; and a variable f represents the far value of the clip space.
A negative value is set as the variable D, and therefore the near value represents a position at which a distance from the virtual camera is reduced. However, a minimum value of a Z buffer memory space is 0. Therefore, a value below zero is set to zero. For example, when a negative offset of 0.2 is added, values ranging from 0.0 to 1.0 shifts to values ranging from −0.2 to 0.8. At this time, values below zero are set to zero, and values ranging from 0.0 to 0.8 are used.
Next, a processing according to the second embodiment will be described in detail. Firstly, in the present embodiment, a function as described below needs to be implemented as hardware or software in order to realize the processing as described above. Specifically, it is necessary to implement a function for defining association between a Z buffer memory space, and the near value and far value of the clip space, as described below.
The function will be described. For example, the Z buffer memory space represents values ranging from 0.0 to 1.0 as shown in
Next, the process according to the second embodiment will be described in detail. Although a flow of a fundamental process is the same as described for the first embodiment, a process shown in
Next, in step S51, the allocation of the Z buffer space for the normal polygon is performed. For example, when the Z buffer memory space represents values ranging from 0.0 to 1.0 (which is a range of the Z values), a process for allocating the overall range of values for the normal polygon is performed. In the present embodiment, an exemplary case where a variable Vn and a variable Vf are used as variables for allocation of the memory space will be described. The variable Vn represents a value, in the Z buffer memory space, corresponding to the near value of the clip space. The variable Vf represents a value, in the Z buffer memory space, corresponding to the far value of the clip space. These variables are used in a process described below.
In order to set the allocation, the range may be explicitly specified as described above, or all the range may be designated as an initial value without explicitly specifying the range to be allocated.
Next, in step S12, as in the first embodiment, the “normal polygon” is selected as a polygon to be rendered.
Next, in step S13, the polygon rendering process as described with reference to
Zscreen=Zclip/Wclip×(Vf−Vn)+Vf Equation 3
When the rendering process for the normal polygon is completed, the allocation of the Z buffer space for the floated polygon is performed, that is, the offset as described above is set, in step S52. Specifically, initially, a predetermined value is set as a variable offset (for example, a value which is eight times as great as a maximum accuracy of the Z value is set as the variable offset). Next, the variable Vn and the variable Vf are calculated by using the following equation.
Vn=Vn+offset
Vf=Vf+offset
As described above, an offset is added to each of the variables Vn and Vf, thereby setting the offset as described above.
Next, in step S15, the “floated polygon” is selected as a polygon to be rendered in the same manner as described for the first embodiment.
Next, in step S16, the polygon rendering process for the floated polygon is performed. The offset is set in step S52, and therefore a value of Zscreen which is calculated by using Equation 3 contains the offset, thereby obtaining the curved line 231 shown in
As described above, in the second embodiment, although the near value and the far value are the same between the normal polygon and the floated polygon, an offset is added to the Z value in the processing for the floated polygon. Thus, as in the first embodiment, the depth test is performed in a state where the floated polygon is shifted toward the virtual camera, thereby preventing the flickering caused by an error in Z value stored in the Z buffer.
In each embodiment, the floated polygon is, for example, positioned so as to be slightly floated above the ground polygon (when, for example, the floated polygon and the ground polygon are positioned adjacent to each other). However, the floated polygon and the normal polygon may be positioned at the same position (at the same depth position). That is, even when the floated polygon is not “floated”, a result of the depth test indicates that the floated polygon is shifted toward the virtual camera, by performing the processing as described above.
Further, the floated polygon may be rendered so as to be displayed translucent. Thus, a portion of the normal polygon which is hidden behind the floated polygon may be visually confirmed, thereby generating and displaying an image with enhanced reality.
Further, as the order in which the rendering process steps are performed, the order in which the normal polygon is firstly rendered and thereafter the floated polygon is rendered is used in the embodiments. However, when the translucent display as described above is not used, the order of the rendering process steps may be opposite to that described in the embodiments. In the processing as described above, it is certain that, as a result of the depth test, the floated polygon is determined as being closer to the virtual camera than the normal polygon. Therefore, also when the normal polygon is rendered after the floated polygon is rendered, the same effect can be obtained.
In each embodiment, data for the normal polygon and data for the floated polygon are stored in a memory as separate data (as the normal polygon data 124 and the floated polygon data 125, respectively). However, each of the data for the normal polygon and the data for the floated polygon may include information for identifying each other. For example, each polygon data may contain information such as a “polygon type”. In the rendering process, a content of the “polygon type” is determined, and the polygon rendering process may be performed by using one of the setting (the near value and the far value, offset) for the floated polygon and the setting for the normal polygon, depending on the content of the “polygon type”.
Further, the technique of the first embodiment and the technique of the second embodiment may be used in combination with each other. Specifically, the technique (first embodiment) in which the near value and the far value of the clip space used for rendering the normal polygon are set so as to be different from the near value and the far value of the clip space used for rendering the floated polygon, and the technique (second embodiment) in which a predetermined offset is added to the floated polygon to be rendered may be used in combination with each other.
While the invention has been described in detail, the foregoing description is in all aspects illustrative and not restrictive. It is understood that numerous other modifications and variations can be devised without departing from the scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2009-038450 | Feb 2009 | JP | national |