Increase the default Camera3D field of view to 75

A vertical FOV of 75 degrees is roughly equivalent to a 91 degree
horizontal FOV on a 4:3 display (~107.51 degrees on 16:9),
which is close to the typical default FOV used in PC games.

Note that this doesn't apply to the in-editor camera which keeps its
FOV to 70. This is because it doesn't display in fullscreen;
its viewport only displays in the center of the editor (roughly).
This means the viewport won't cover the viewer's eyes as much. Therefore,
the editor camera FOV should be slightly lower to account for this.

Since this changes the default value, this may break existing projects
slightly.

For the record, this was already done in
https://github.com/godotengine/godot-demo-projects/pull/260
for the official demo projects.
This commit is contained in:
Hugo Locurcio 2020-04-26 15:41:19 +02:00
parent 7899b3e734
commit ccc4f3899c
No known key found for this signature in database
GPG key ID: 39E8F8BE30B0A49C
3 changed files with 8 additions and 3 deletions

View file

@ -183,8 +183,13 @@
<member name="far" type="float" setter="set_zfar" getter="get_zfar" default="100.0"> <member name="far" type="float" setter="set_zfar" getter="get_zfar" default="100.0">
The distance to the far culling boundary for this camera relative to its local Z axis. The distance to the far culling boundary for this camera relative to its local Z axis.
</member> </member>
<member name="fov" type="float" setter="set_fov" getter="get_fov" default="70.0"> <member name="fov" type="float" setter="set_fov" getter="get_fov" default="75.0">
The camera's field of view angle (in degrees). Only applicable in perspective mode. Since [member keep_aspect] locks one axis, [code]fov[/code] sets the other axis' field of view angle. The camera's field of view angle (in degrees). Only applicable in perspective mode. Since [member keep_aspect] locks one axis, [code]fov[/code] sets the other axis' field of view angle.
For reference, the default vertical field of view value ([code]75.0[/code]) is equivalent to an horizontal FOV of:
- ~91.31 degrees in a 4:3 viewport
- ~101.67 degrees in a 16:10 viewport
- ~107.51 degrees in a 16:9 viewport
- ~121.63 degrees in a 21:9 viewport
</member> </member>
<member name="frustum_offset" type="Vector2" setter="set_frustum_offset" getter="get_frustum_offset" default="Vector2( 0, 0 )"> <member name="frustum_offset" type="Vector2" setter="set_frustum_offset" getter="get_frustum_offset" default="Vector2( 0, 0 )">
The camera's frustum offset. This can be changed from the default to create "tilted frustum" effects such as [url=https://zdoom.org/wiki/Y-shearing]Y-shearing[/url]. The camera's frustum offset. This can be changed from the default to create "tilted frustum" effects such as [url=https://zdoom.org/wiki/Y-shearing]Y-shearing[/url].

View file

@ -689,7 +689,7 @@ Camera3D::Camera3D() {
viewport = nullptr; viewport = nullptr;
force_change = false; force_change = false;
mode = PROJECTION_PERSPECTIVE; mode = PROJECTION_PERSPECTIVE;
set_perspective(70.0, 0.05, 100.0); set_perspective(75.0, 0.05, 100.0);
keep_aspect = KEEP_HEIGHT; keep_aspect = KEEP_HEIGHT;
layers = 0xfffff; layers = 0xfffff;
v_offset = 0; v_offset = 0;

View file

@ -82,7 +82,7 @@ public:
Camera() { Camera() {
visible_layers = 0xFFFFFFFF; visible_layers = 0xFFFFFFFF;
fov = 70; fov = 75;
type = PERSPECTIVE; type = PERSPECTIVE;
znear = 0.05; znear = 0.05;
zfar = 100; zfar = 100;