18,700
edits
(layout and language improvements, external link updates, and math fixes (last calculation was converting Z=0.975 instead of 0.925; world units are not 10 cm, they are 4 inches)) |
(moving most technical parts to Graphics to slim this down (lots more commands will be going here once this becomes BSL:Graphics)) |
||
Line 1: | Line 1: | ||
==Frustum== | ==Frustum== | ||
:'' | :''See [[Graphics#Frustum|Graphics]] for an explanation of frustum.'' | ||
;void gs_farclipplane_set(float plane) | ;void gs_farclipplane_set(float plane) | ||
:This sets the distance of the far clipping plane in world units. If you call '''gs_farclipplane_set(1000)''', then all polygons whose closest point is more than 83 | :This sets the distance of the far clipping plane in world units. If you call '''gs_farclipplane_set(1000)''', then all polygons whose closest point is more than 1,000 world units (83 ft) away from the camera will be culled. The default distance of the far clipping distance is 10,000 world units (833 ft). | ||
;void gs_fov_set(float fov_degrees) | ;void gs_fov_set(float fov_degrees) | ||
: | :This sets the angle between the top and bottom planes of the frustum. If you call '''gs_fov_set(90)''', then the angle at the camera between the top and bottom of the frustum will be 90°. The default value of that angle is 45°. | ||
:The aspect ratio of the frustum stays constant (defined by the current screen resolution), so the view will get wider as you increase the vertical FOV. For the | :The aspect ratio of the frustum stays constant (defined by the current screen resolution), so the view will get wider as you increase the vertical FOV. For the default FOV and on a 4:3 screen, the horizontal viewing angle is 2 * arctan(4/3 * tan(45° / 2)) = 57.8224° | ||
; | ;Notes | ||
:The far clip plane and FOV are only reset when Oni starts, not when you load a level, so mind their default values and the side effect of other scripts. | :The far clip plane and FOV are only reset when Oni starts, not when you load a level, so mind their default values and the side effect of other scripts. | ||
:There is no control over Oni's ''near'' clipping plane: its distance is always 4 units (16 inches). | :There is no control over Oni's ''near'' clipping plane: its distance is always 4 units (16 inches). | ||
== | ==Fog== | ||
:'' | :''See [[Graphics#Fog|Graphics]] for an explanation of fog.'' | ||
There are 5 fog-related variables: 3 color components (RGB) and 2 distances in frustum space (see below) between which the fog gradient builds up. All five values are reset to their default values at level load. | There are 5 fog-related variables: 3 color components (RGB) and 2 distances in frustum space (see below) between which the fog gradient builds up. All five values are reset to their default values at level load. | ||
Line 34: | Line 27: | ||
:;float gl_fog_start=0.925 | :;float gl_fog_start=0.925 | ||
:;float gl_fog_end=1.0 | :;float gl_fog_end=1.0 | ||
Keep in mind that those "distances" are percentages of the frustum length: 1.0 corresponds to the far clipping plane, so 0.925 corresponds to a plane about 17.7 feet from the camera if the far clip plane is at its default 833 feet (see | Keep in mind that those "distances" are percentages of the frustum length: 1.0 corresponds to the far clipping plane, so 0.925 corresponds to a plane about 17.7 feet from the camera if the far clip plane is at its default 833 feet (see [[Graphics#Fog|Graphics]] for conversion formulas). | ||
That the "end" fog plane is at 1.0 means that the fog will completely hide objects only at the far end of the viewing frustum. Objects closer than the "start" fog plane won't be affected by fog at all. In between, there will be a fog gradient. | That the "end" fog plane is at 1.0 means that the fog will completely hide objects only at the far end of the viewing frustum. Objects closer than the "start" fog plane won't be affected by fog at all. In between, there will be a fog gradient. | ||
Line 40: | Line 33: | ||
Typically, tweaking the "start" plane is enough to achieve a good-looking distance fog: once set, the fog/haze can be kept the same for the whole level. However, in some situations (e.g., in the dream level), the fog starts closer to the player. | Typically, tweaking the "start" plane is enough to achieve a good-looking distance fog: once set, the fog/haze can be kept the same for the whole level. However, in some situations (e.g., in the dream level), the fog starts closer to the player. | ||
In that case the correct values of gl_fog_start (and gl_fog_end) may be hard to guess, and you may want to have a look at the conversion | In that case the correct values of gl_fog_start (and gl_fog_end) may be hard to guess, and you may want to have a look at the conversion formulas on the Graphics page. You may also want to use smooth transitions rather than set the variables to new values instantly. | ||
The smooth transition functions are: | The smooth transition functions are: | ||
Line 51: | Line 44: | ||
Note that you can invert the effect, to obtain short-distance fog rather than the usual long-distance fog. All you have to do is to make gl_fog_end smaller than gl_fog_start (and gl_fog_start small enough so that the player character is visible). | Note that you can invert the effect, to obtain short-distance fog rather than the usual long-distance fog. All you have to do is to make gl_fog_end smaller than gl_fog_start (and gl_fog_start small enough so that the player character is visible). | ||
[[Category:Scripting tasks]] | [[Category:Scripting tasks]] |