forked from MapComplete/MapComplete
		
	Feature(360): attempt to fix CSP
This commit is contained in:
		
							parent
							
								
									a30f25f42a
								
							
						
					
					
						commit
						558b19f8d7
					
				
					 5 changed files with 132 additions and 55 deletions
				
			
		|  | @ -6,7 +6,7 @@ | |||
|   import type { ProvidedImage } from "../../Logic/ImageProviders/ImageProvider" | ||||
|   import { UIEventSource } from "../../Logic/UIEventSource" | ||||
|   import Zoomcontrol from "../Zoomcontrol" | ||||
|   import { getContext, onDestroy } from "svelte" | ||||
|   import { onDestroy } from "svelte" | ||||
|   import type { PanoramaView } from "./photoSphereViewerWrapper" | ||||
|   import { PhotoSphereViewerWrapper } from "./photoSphereViewerWrapper" | ||||
| 
 | ||||
|  |  | |||
|  | @ -25,6 +25,7 @@ | |||
|   import { BBox } from "../../Logic/BBox" | ||||
|   import PanoramaxLink from "../BigComponents/PanoramaxLink.svelte" | ||||
|   import { GeoOperations } from "../../Logic/GeoOperations" | ||||
|   import type { PanoramaView } from "../../Logic/ImageProviders/ImageProvider" | ||||
| 
 | ||||
|   export let tags: UIEventSource<OsmTags> | ||||
|   export let state: SpecialVisualizationState | ||||
|  | @ -55,14 +56,16 @@ | |||
|   let asFeatures = result.map((p4cs) => | ||||
|     p4cs.map( | ||||
|       (p4c) => | ||||
|         <Feature<Point>>{ | ||||
|         <Feature<Point, PanoramaView>>{ | ||||
|           type: "Feature", | ||||
|           geometry: { | ||||
|             type: "Point", | ||||
|             coordinates: [p4c.coordinates.lng, p4c.coordinates.lat] | ||||
|           }, | ||||
|           properties: { | ||||
|           properties: <PanoramaView>{ | ||||
|             id: p4c.pictureUrl, | ||||
|             url: p4c.pictureUrl, | ||||
|             northOffset: p4c.direction, | ||||
|             rotation: p4c.direction, | ||||
|             spherical: p4c.details.isSpherical ? "yes" : "no" | ||||
|           } | ||||
|  | @ -145,15 +148,24 @@ | |||
|       highlighted.set(feature.properties.id) | ||||
|     } | ||||
|   }) | ||||
|   let nearbyFeatures: Feature[] = [{ | ||||
|     type: "Feature", | ||||
|     geometry: { type: "Point", coordinates: GeoOperations.centerpointCoordinates(feature) }, | ||||
|     properties: { | ||||
|       name: layer.title?.GetRenderValue(feature.properties).Subs(feature.properties).txt, | ||||
|       focus: true | ||||
|     } | ||||
|   } | ||||
|   ] | ||||
|   let nearbyFeatures: Store<Feature[]> = asFeatures.map(nearbyPoints => { | ||||
|     return [{ | ||||
|       type: "Feature", | ||||
|       geometry: { type: "Point", coordinates: GeoOperations.centerpointCoordinates(feature) }, | ||||
|       properties: { | ||||
|         name: layer.title?.GetRenderValue(feature.properties).Subs(feature.properties).txt, | ||||
|         focus: true | ||||
|       } | ||||
|     }, ...nearbyPoints.filter(p => p.properties.spherical === "yes").map(f => ({ | ||||
|       ...f, properties: { | ||||
|         name: "Nearby panorama", | ||||
|         pitch: "auto", | ||||
|         type: "scene", | ||||
|         gotoPanorama: f | ||||
|       } | ||||
|     })) | ||||
|     ] | ||||
|   }) | ||||
| 
 | ||||
|   onDestroy( | ||||
|     tags.addCallbackAndRunD((tags) => { | ||||
|  |  | |||
|  | @ -1,65 +1,106 @@ | |||
| import "pannellum" | ||||
| 
 | ||||
| import { Feature, Point } from "geojson" | ||||
| import { Feature, Geometry, Point } from "geojson" | ||||
| import { GeoOperations } from "../../Logic/GeoOperations" | ||||
| import { PanoramaView } from "../../Logic/ImageProviders/ImageProvider" | ||||
| import { HotspotProperties, PanoramaView } from "../../Logic/ImageProviders/ImageProvider" | ||||
| 
 | ||||
| 
 | ||||
| export class PhotoSphereViewerWrapper { | ||||
| 
 | ||||
|     private readonly imageInfo: Feature<Point, PanoramaView> | ||||
|     private imageInfo: Feature<Point, PanoramaView> | ||||
|     private readonly viewer: Pannellum.Viewer | ||||
|     private nearbyFeatures: Feature<Geometry, HotspotProperties>[] = [] | ||||
| 
 | ||||
| 
 | ||||
|     constructor(container: HTMLElement, imageInfo: Feature<Point, PanoramaView>, nearbyFeatures?: Feature[]) { | ||||
|     constructor(container: HTMLElement, imageInfo: Feature<Point, PanoramaView>, nearbyFeatures?: Feature<Geometry, HotspotProperties>[]) { | ||||
|         this.imageInfo = imageInfo | ||||
|         this.viewer = pannellum.viewer(container, { | ||||
|             type: "equirectangular", | ||||
|             hfov: 110, | ||||
|             panorama: imageInfo.properties.url, | ||||
|             autoLoad: true, | ||||
|             hotSpots: [], | ||||
|             compass: true, | ||||
|             showControls: false, | ||||
|             northOffset: imageInfo.properties.northOffset, | ||||
|             horizonPitch: imageInfo.properties.pitchOffset | ||||
|         }) | ||||
| 
 | ||||
|         /* for (let i = 0; i < 360; i += 45) { | ||||
| 
 | ||||
|              viewer.addHotSpot({ | ||||
|                  type: "info", | ||||
|                  yaw: i, | ||||
|                  text: "YAW " + i | ||||
|              }) | ||||
|          } | ||||
| 
 | ||||
|          console.log("North offset:", imageInfo.properties.northOffset) | ||||
|          viewer.addHotSpot({ | ||||
|              type: "info", | ||||
|              yaw: -northOffs, | ||||
|              text: "Supposedely north " | ||||
|          })*/ | ||||
|         this.viewer = pannellum.viewer(container, | ||||
|             <any>{ | ||||
|                 default: { | ||||
|                     firstScene: imageInfo.properties.url, | ||||
|                     sceneFadeDuration: 250 | ||||
|                 }, | ||||
|                 scenes: { | ||||
|                     [imageInfo.properties.url]: | ||||
|                         { | ||||
|                             type: "equirectangular", | ||||
|                             hfov: 110, | ||||
|                             panorama: imageInfo.properties.url, | ||||
|                             autoLoad: true, | ||||
|                             hotSpots: [], | ||||
|                             sceneFadeDuration: 250, | ||||
|                             compass: true, | ||||
|                             showControls: false, | ||||
|                             northOffset: imageInfo.properties.northOffset, | ||||
|                             horizonPitch: imageInfo.properties.pitchOffset | ||||
|                         } | ||||
|                 } | ||||
|             } | ||||
|         ) | ||||
| 
 | ||||
|         this.setNearbyFeatures(nearbyFeatures) | ||||
|     } | ||||
| 
 | ||||
|     public setNearbyFeatures(nearbyFeatures: Feature[]) { | ||||
|     public calculatePitch(feature: Feature): number { | ||||
|         const coors = this.imageInfo.geometry.coordinates | ||||
|         const distance = GeoOperations.distanceBetween( | ||||
|             <[number, number]>coors, GeoOperations.centerpointCoordinates(feature) | ||||
|         ) | ||||
| 
 | ||||
|         // In: -pi/2 up to pi/2
 | ||||
|         const alpha = Math.atan(distance / 4) // in radians
 | ||||
|         const degrees = alpha * 360 / (2 * Math.PI) | ||||
|         return -degrees | ||||
|     } | ||||
| 
 | ||||
|     private setPanorama(imageInfo: Feature<Point, PanoramaView>) { | ||||
|         if (this.viewer?.getScene() === imageInfo?.properties?.url) { | ||||
|             // Already the current scene
 | ||||
|             return | ||||
|         } | ||||
|         this.clearHotspots() | ||||
|         this.imageInfo = imageInfo | ||||
|         this.viewer.addScene(imageInfo.properties.url, <any>{ | ||||
|             panorama: imageInfo.properties.url, | ||||
|             northOffset: imageInfo.properties.northOffset, | ||||
|             type: "equirectangular" | ||||
|         }) | ||||
| 
 | ||||
|         this.viewer.loadScene(imageInfo.properties.url, 0, imageInfo.properties.northOffset) | ||||
|         this.setNearbyFeatures(this.nearbyFeatures) | ||||
|     } | ||||
| 
 | ||||
|     private clearHotspots() { | ||||
|         const hotspots = this.viewer.getConfig()["scenes"][this.imageInfo.properties.url].hotSpots ?? [] | ||||
|         for (const hotspot of hotspots) { | ||||
|             this.viewer.removeHotSpot(hotspot?.id, this.imageInfo.properties.url) | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     public setNearbyFeatures(nearbyFeatures: Feature<Geometry, HotspotProperties>[]) { | ||||
|         const imageInfo = this.imageInfo | ||||
|         const northOffs = imageInfo.properties.northOffset | ||||
| 
 | ||||
|         const hotspots = this.viewer.getConfig().hotSpots ?? [] | ||||
|         for (const hotspot of hotspots) { | ||||
|             this.viewer.removeHotSpot(hotspot.id) | ||||
|         } | ||||
|         // this.viewer.removeHotSpot()
 | ||||
|         this.nearbyFeatures = nearbyFeatures | ||||
|         this.clearHotspots() | ||||
|         for (const f of nearbyFeatures ?? []) { | ||||
|             if (f.properties.gotoPanorama?.properties?.url === this.imageInfo.properties.url) { | ||||
|                 continue // This is the current panorama, no need to show it
 | ||||
|             } | ||||
|             const yaw = GeoOperations.bearing(imageInfo, GeoOperations.centerpoint(f)) | ||||
|             let pitch = 0 | ||||
|             if (f.properties.pitch === "auto") { | ||||
|                 pitch = this.calculatePitch(f) | ||||
|             } else if (!isNaN(f.properties.pitch)) { | ||||
|                 pitch = f.properties.pitch | ||||
|             } | ||||
|             this.viewer.addHotSpot({ | ||||
|                 type: "info", | ||||
|                 type: f.properties.gotoPanorama !== undefined ? "scene" : "info", | ||||
|                 yaw: (yaw - northOffs) % 360, | ||||
|                 text: f.properties.name | ||||
|             }) | ||||
|                 pitch, | ||||
|                 text: f.properties.name, | ||||
|                 clickHandlerFunc: () => { | ||||
|                     this.setPanorama(f.properties.gotoPanorama) | ||||
|                 } | ||||
|             }, this.imageInfo.properties.url) | ||||
|             if (f.properties.focus) { | ||||
|                 this.viewer.setYaw(yaw - northOffs) | ||||
|             } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue