-
-
Notifications
You must be signed in to change notification settings - Fork 754
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
93 changed files
with
1,816 additions
and
503 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
# How Camera position is calculated | ||
|
||
This guide describes how camera position is calculated from the center point, zoom, and camera rotation. | ||
The `Transform` variables `center`, `elevation`, `zoom`, `pitch`, `bearing`, and `fov` control the location of the camera indirectly. | ||
|
||
`elevation` sets the height of the "center point" above sea level. In the typical use case (`centerClampedToGround = true`), the library modifies `elevation` in an attempt to keep the center point always on the terrain (or 0 MSL if no terrain is enabled). When `centerClampedToGround = false`, the user provides the elevation of the center point. | ||
|
||
`zoom` sets the distance from the center point to the camera (in conjunction with `fovInRadians`, which is currently hardcoded). | ||
|
||
Together, `zoom`, `elevation`, and `pitch` set the altitude of the camera: | ||
|
||
See `MercatorTransform::getCameraAltitude()`: | ||
```typescript | ||
getCameraAltitude(): number { | ||
const altitude = Math.cos(this.pitchInRadians) * this._cameraToCenterDistance / this._helper._pixelPerMeter; | ||
return altitude + this.elevation; | ||
} | ||
``` | ||
|
||
![image](assets/center-point_nominal.png) | ||
|
||
To allow pitch > 90, the "center point" must be placed off of the ground. This will allow the camera to stay above the ground when it pitches above 90. This requires setting `centerClampedToGround = false`. | ||
|
||
![image](assets/center-point_high-pitch.png) | ||
|
||
The same math applies whether the center point is on terrain or not, and whether the camera is above or below the ground: | ||
|
||
![image](assets/center-point_straight-up.png) | ||
![image](assets/center-point_underground.png) | ||
|
||
|
||
To help users position the camera, `Camera` exports the function `calculateCameraOptionsFromCameraLngLatAltRotation()`. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.