-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #22 from TDT4290-group-4/9-coastline-overlay
#9 Coastline overlay
- Loading branch information
Showing
8 changed files
with
319 additions
and
50 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
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
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,101 @@ | ||
| /** | ||
| * Syncs Potree's point cloud with Cesium's globe. | ||
| * | ||
| * @param potreeViewer - used for point cloud | ||
| * @param cesiumViewer - used for globe | ||
| */ | ||
| export function syncCameras(potreeViewer, cesiumViewer) { | ||
| const camera = potreeViewer.scene.getActiveCamera() | ||
|
|
||
| // Compute camera position, up vector, and target (pivot) in world coordinates | ||
| const pPos = new THREE.Vector3(0, 0, 0).applyMatrix4(camera.matrixWorld) | ||
| const pUp = new THREE.Vector3(0, 600, 0).applyMatrix4(camera.matrixWorld) | ||
| const pTarget = potreeViewer.scene.view.getPivot() | ||
|
|
||
| const toCes = (v) => new Cesium.Cartesian3(v.x, v.y, v.z) | ||
|
|
||
| const cPos = toCes(pPos) | ||
| const cUpTarget = toCes(pUp) | ||
| const cTarget = toCes(pTarget) | ||
|
|
||
| // Compute Cesium camera direction and up vectors | ||
| const cDir = Cesium.Cartesian3.normalize( | ||
| Cesium.Cartesian3.subtract(cTarget, cPos, new Cesium.Cartesian3()), | ||
| new Cesium.Cartesian3() | ||
| ) | ||
| const cUp = Cesium.Cartesian3.normalize( | ||
| Cesium.Cartesian3.subtract(cUpTarget, cPos, new Cesium.Cartesian3()), | ||
| new Cesium.Cartesian3() | ||
| ) | ||
|
|
||
| // Hide globe when the camera is below the surface, blocked by the curvature of the Earth or directly above the pivot | ||
| const showGlobe = shouldShowGlobe(cPos, cTarget, cDir) | ||
| cesiumViewer.scene.globe.show = showGlobe | ||
| cesiumViewer.scene.skyAtmosphere.show = showGlobe | ||
|
|
||
| // Sync Cesium camera position and orientation with Potree | ||
| cesiumViewer.camera.setView({ | ||
| destination: cPos, | ||
| orientation: { | ||
| direction: cDir, | ||
| up: cUp | ||
| } | ||
| }) | ||
|
|
||
| // Match FOV | ||
| const aspect = camera.aspect | ||
| const fovy = Math.PI * (camera.fov / 180) | ||
| if (aspect < 1) { | ||
| cesiumViewer.camera.frustum.fov = fovy | ||
| } else { | ||
| const fovx = Math.atan(Math.tan(0.5 * fovy) * aspect) * 2 | ||
| cesiumViewer.camera.frustum.fov = fovx | ||
| } | ||
| } | ||
|
|
||
| /** | ||
| * Determines whether the globe should be visible based on the camera position. | ||
| * | ||
| * Returns false if the camera is below the globe surface, if the pivot | ||
| * point would be blocked by the curvature of the Earth or if the camera | ||
| * is looking almost straight down at the pivot. | ||
| * | ||
| * @param cameraPos - The camera position in Cesium.Cartesian3 coordinates | ||
| * @param pivot - The pivot point in Cesium.Cartesian3 coordinates | ||
| * @param direction - The camera direction as a Cesium.Cartesian3 unit vector | ||
| * @returns true if the globe should be visible, false if it should be hidden | ||
| */ | ||
| function shouldShowGlobe(cameraPos, pivot, direction) { | ||
| const ellipsoid = Cesium.Ellipsoid.WGS84 | ||
| const earthCenter = Cesium.Cartesian3.ZERO | ||
|
|
||
| // Get point on globe surface directly above the pivot | ||
| const carto = Cesium.Cartographic.fromCartesian(pivot) | ||
| const pivotSurface = Cesium.Cartesian3.fromRadians( | ||
| carto.longitude, | ||
| carto.latitude, | ||
| 0, | ||
| ellipsoid | ||
| ) | ||
|
|
||
| // Axis vector from Earth center through pivot | ||
| const axis = Cesium.Cartesian3.subtract( | ||
| pivotSurface, | ||
| earthCenter, | ||
| new Cesium.Cartesian3() | ||
| ) | ||
| Cesium.Cartesian3.normalize(axis, axis) | ||
|
|
||
| // Project camera and pivot onto this axis | ||
| const camProj = Cesium.Cartesian3.dot(cameraPos, axis) | ||
| const pivotProj = Cesium.Cartesian3.dot(pivotSurface, axis) | ||
|
|
||
| // Compute the dot product between camera direction and local vertical | ||
| // Used to detect if the camera is looking almost straight down | ||
| const targetNormal = Cesium.Ellipsoid.WGS84.geodeticSurfaceNormal(pivot) | ||
| const dotProduct = Math.abs(Cesium.Cartesian3.dot(direction, targetNormal)) | ||
|
|
||
| // If camera is "above" pivot on the axis, and not looking nearly straight down, the globe should be visible | ||
| // Otherwise, the globe should not be visible | ||
| return camProj >= pivotProj && dotProduct < 0.99 | ||
| } |
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,26 @@ | ||
| /** | ||
| * Initializes the Cesium viewer used to visualize the globe. | ||
| * | ||
| * @param containerId - id of the container | ||
| * @returns Cesium viewer | ||
| */ | ||
| export function createCesiumViewer(containerId) { | ||
| const viewer = new Cesium.Viewer(containerId, { | ||
| useDefaultRenderLoop: false, | ||
| animation: false, | ||
| baseLayerPicker: false, | ||
| fullscreenButton: false, | ||
| geocoder: false, | ||
| homeButton: false, | ||
| infoBox: false, | ||
| sceneModePicker: false, | ||
| selectionIndicator: false, | ||
| timeline: false, | ||
| navigationHelpButton: false, | ||
| imageryProvider: Cesium.createOpenStreetMapImageryProvider({ | ||
| url: 'https://a.tile.openstreetmap.org/' | ||
| }), | ||
| terrainShadows: Cesium.ShadowMode.DISABLED | ||
| }) | ||
| return viewer | ||
| } |
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,7 @@ | ||
| export const POTREE_POINTCLOUD_URL = '/pointclouds/data_converted/metadata.json' | ||
|
|
||
| export const POTREE_SETTINGS = { | ||
| edl: true, | ||
| fov: 60, | ||
| pointBudget: 1_000_000 | ||
| } |
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,26 @@ | ||
| import { POTREE_POINTCLOUD_URL, POTREE_SETTINGS } from './config.js' | ||
| import { createCesiumViewer } from './cesiumViewer.js' | ||
| import { createPotreeViewer } from './potreeViewer.js' | ||
| import { syncCameras } from './cameraSync.js' | ||
|
|
||
| async function init() { | ||
| window.cesiumViewer = createCesiumViewer('cesiumContainer') | ||
|
|
||
| window.potreeViewer = await createPotreeViewer( | ||
| 'potree_render_area', | ||
| POTREE_POINTCLOUD_URL, | ||
| POTREE_SETTINGS | ||
| ) | ||
|
|
||
| function loop(timestamp) { | ||
| requestAnimationFrame(loop) | ||
| potreeViewer.update(potreeViewer.clock.getDelta(), timestamp) | ||
| potreeViewer.render() | ||
| syncCameras(potreeViewer, cesiumViewer) | ||
| cesiumViewer.render() | ||
| } | ||
|
|
||
| requestAnimationFrame(loop) | ||
| } | ||
|
|
||
| init() |
Oops, something went wrong.