Skip to content

Instantly share code, notes, and snippets.

@wallabyway
Created June 10, 2021 19:35
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save wallabyway/4503609e84a2b612b27138abba8aa3b7 to your computer and use it in GitHub Desktop.
Save wallabyway/4503609e84a2b612b27138abba8aa3b7 to your computer and use it in GitHub Desktop.
// Load the extension on startup, like this:
// viewer = new Autodesk.Viewing.GuiViewer3D(viewerDiv, {extensions: ['GoogleMapsExtension']});
// Result: https://youtu.be/9kVHlTV8wHw
class GoogleMapsExtension extends Autodesk.Viewing.Extension {
constructor(viewer, options) {
super(viewer, options);
}
quad(x,y) {
const mesh = new THREE.Mesh(
new THREE.PlaneBufferGeometry( 256, 256 ),
new THREE.MeshLambertMaterial({ color:0xa0a0a0, depthWrite:false,
map: (THREE.ImageUtils.loadTexture(`https://api.mapbox.com/v4/mapbox.satellite/16/${59157+x}/${40217-y}.webp?sku=101gdtmdKGvJF&access_token=pk.eyJ1IjoibWFwYm94IiwiYSI6ImNpejY4M29iazA2Z2gycXA4N2pmbDZmangifQ.-g_vE53SD2WrJ6tFX7QHmA`)) })
);
mesh.position.set (x*256,y*256, 1);
return mesh;
}
/*
// https://api.mapbox.com/styles/v1/mapbox/satellite-streets-v11.html?title=true&access_token=pk.eyJ1IjoibWFwYm94IiwiYSI6ImNpejY4M29iazA2Z2gycXA4N2pmbDZmangifQ.-g_vE53SD2WrJ6tFX7QHmA#14.88/-37.82655/144.97045
//const tex = THREE.ImageUtils.loadTexture('http://localhost:9081/assets/images/map.jpg');
const tex = THREE.ImageUtils.loadTexture('https://api.mapbox.com/v4/mapbox.satellite/16/59159/40216.webp?sku=101gdtmdKGvJF&access_token=pk.eyJ1IjoibWFwYm94IiwiYSI6ImNpejY4M29iazA2Z2gycXA4N2pmbDZmangifQ.-g_vE53SD2WrJ6tFX7QHmA');
*/
load() {
this.viewer.addEventListener(Autodesk.Viewing.OBJECT_TREE_CREATED_EVENT, ()=>{
if (!this.viewer.overlays.hasScene('map')) {
this.viewer.overlays.addScene('map');
}
const tiles = new THREE.Object3D();
tiles.position.set(-1140,-800, -10);
tiles.scale.set(2,2,1);
const tilex = [-1,0,1,2,3];
const tiley = [0,1,2];
tilex.map( x => {
tiley.map( y => {
tiles.add(this.quad(x,y));
})});
window.tiles=tiles;
this.viewer.overlays.addMesh(tiles, 'map');
});
return true;
}
unload() {
return true;
}
}
Autodesk.Viewing.theExtensionManager.registerExtension('GoogleMapsExtension', GoogleMapsExtension);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment