(function() { var __moduleName = "js/main"; var __moduleAddress = "http://projects.delimited.io/webgl-globes/js/main.js";System.register(['./common/scene', './common/setEvents', './common/geoHelpers', './common/mapTexture', './common/utils', 'topojson', 'THREE', 'd3'], function (_export) { 'use strict'; var scene, camera, renderer, setEvents, convertToXYZ, getEventCenter, geodecoder, mapTexture, getTween, memoize, topojson, THREE, d3; function animate() { requestAnimationFrame(animate); renderer.render(scene, camera); } return { setters: [function (_commonScene) { scene = _commonScene.scene; camera = _commonScene.camera; renderer = _commonScene.renderer; }, function (_commonSetEvents) { setEvents = _commonSetEvents.setEvents; }, function (_commonGeoHelpers) { convertToXYZ = _commonGeoHelpers.convertToXYZ; getEventCenter = _commonGeoHelpers.getEventCenter; geodecoder = _commonGeoHelpers.geodecoder; }, function (_commonMapTexture) { mapTexture = _commonMapTexture.mapTexture; }, function (_commonUtils) { getTween = _commonUtils.getTween; memoize = _commonUtils.memoize; }, function (_topojson) { topojson = _topojson['default']; }, function (_THREE) { THREE = _THREE['default']; }, function (_d3) { d3 = _d3['default']; }], execute: function () { d3.json('data/world.json', function (err, data) { d3.select('#loading').transition().duration(500).style('opacity', 0).remove(); var currentCountry, overlay; var segments = 155; // number of vertices. Higher = better mouse accuracy // Setup cache for country textures var countries = topojson.feature(data, data.objects.countries); var geo = geodecoder(countries.features); var textureCache = memoize(function (cntryID, color) { var country = geo.find(cntryID); return mapTexture(country, color); }); // Base globe with blue "water" var blueMaterial = new THREE.MeshPhongMaterial({ color: '#2B3B59', transparent: true }); var sphere = new THREE.SphereGeometry(200, segments, segments); var baseGlobe = new THREE.Mesh(sphere, blueMaterial); baseGlobe.rotation.y = Math.PI; baseGlobe.addEventListener('click', onGlobeClick); baseGlobe.addEventListener('mousemove', onGlobeMousemove); // add base map layer with all countries var worldTexture = mapTexture(countries, '#647089'); var mapMaterial = new THREE.MeshPhongMaterial({ map: worldTexture, transparent: true }); var baseMap = new THREE.Mesh(new THREE.SphereGeometry(200, segments, segments), mapMaterial); baseMap.rotation.y = Math.PI; // create a container node and add the two meshes var root = new THREE.Object3D(); root.scale.set(2.5, 2.5, 2.5); root.add(baseGlobe); root.add(baseMap); scene.add(root); function onGlobeClick(event) { // Get pointc, convert to latitude/longitude var latlng = getEventCenter.call(this, event); // Get new camera position var temp = new THREE.Mesh(); temp.position.copy(convertToXYZ(latlng, 900)); temp.lookAt(root.position); temp.rotateY(Math.PI); for (var key in temp.rotation) { if (temp.rotation[key] - camera.rotation[key] > Math.PI) { temp.rotation[key] -= Math.PI * 2; } else if (camera.rotation[key] - temp.rotation[key] > Math.PI) { temp.rotation[key] += Math.PI * 2; } } var tweenPos = getTween.call(camera, 'position', temp.position); d3.timer(tweenPos); var tweenRot = getTween.call(camera, 'rotation', temp.rotation); d3.timer(tweenRot); } function onGlobeMousemove(event) { var map, material; // Get pointc, convert to latitude/longitude var latlng = getEventCenter.call(this, event); // Look for country at that latitude/longitude var country = geo.search(latlng[0], latlng[1]); if (country !== null && country.code !== currentCountry) { // Track the current country displayed currentCountry = country.code; // Update the html d3.select('#msg').html(country.code); // Overlay the selected country map = textureCache(country.code, '#CDC290'); material = new THREE.MeshPhongMaterial({ map: map, transparent: true }); if (!overlay) { overlay = new THREE.Mesh(new THREE.SphereGeometry(201, 40, 40), material); overlay.rotation.y = Math.PI; root.add(overlay); } else { overlay.material = material; } } } setEvents(camera, [baseGlobe], 'click'); setEvents(camera, [baseGlobe], 'mousemove', 10); });animate(); } }; }); //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["http://projects.delimited.io/webgl-globes/js/main.js"],"names":[],"mappings":"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","file":"http://projects.delimited.io/webgl-globes/js/main.js","sourcesContent":["import { scene, camera, renderer } from './common/scene';\nimport { setEvents } from './common/setEvents';\nimport { convertToXYZ, getEventCenter, geodecoder } from './common/geoHelpers';\nimport { mapTexture } from './common/mapTexture';\nimport { getTween, memoize } from './common/utils';\nimport topojson from 'topojson';\nimport THREE from 'THREE';\nimport d3 from 'd3';\n\nd3.json('data/world.json', function (err, data) {\n\n  d3.select(\"#loading\").transition().duration(500)\n    .style(\"opacity\", 0).remove();\n\n  var currentCountry, overlay;\n\n  var segments = 155; // number of vertices. Higher = better mouse accuracy\n\n  // Setup cache for country textures\n  var countries = topojson.feature(data, data.objects.countries);\n  var geo = geodecoder(countries.features);\n\n  var textureCache = memoize(function (cntryID, color) {\n    var country = geo.find(cntryID);\n    return mapTexture(country, color);\n  });\n\n  // Base globe with blue \"water\"\n  let blueMaterial = new THREE.MeshPhongMaterial({color: '#2B3B59', transparent: true});\n  let sphere = new THREE.SphereGeometry(200, segments, segments);\n  let baseGlobe = new THREE.Mesh(sphere, blueMaterial);\n  baseGlobe.rotation.y = Math.PI;\n  baseGlobe.addEventListener('click', onGlobeClick);\n  baseGlobe.addEventListener('mousemove', onGlobeMousemove);\n\n  // add base map layer with all countries\n  let worldTexture = mapTexture(countries, '#647089');\n  let mapMaterial  = new THREE.MeshPhongMaterial({map: worldTexture, transparent: true});\n  var baseMap = new THREE.Mesh(new THREE.SphereGeometry(200, segments, segments), mapMaterial);\n  baseMap.rotation.y = Math.PI;\n\n  // create a container node and add the two meshes\n  var root = new THREE.Object3D();\n  root.scale.set(2.5, 2.5, 2.5);\n  root.add(baseGlobe);\n  root.add(baseMap);\n  scene.add(root);\n\n  function onGlobeClick(event) {\n\n    // Get pointc, convert to latitude/longitude\n    var latlng = getEventCenter.call(this, event);\n\n    // Get new camera position\n    var temp = new THREE.Mesh();\n    temp.position.copy(convertToXYZ(latlng, 900));\n    temp.lookAt(root.position);\n    temp.rotateY(Math.PI);\n\n    for (let key in temp.rotation) {\n      if (temp.rotation[key] - camera.rotation[key] > Math.PI) {\n        temp.rotation[key] -= Math.PI * 2;\n      } else if (camera.rotation[key] - temp.rotation[key] > Math.PI) {\n        temp.rotation[key] += Math.PI * 2;\n      }\n    }\n\n    var tweenPos = getTween.call(camera, 'position', temp.position);\n    d3.timer(tweenPos);\n\n    var tweenRot = getTween.call(camera, 'rotation', temp.rotation);\n    d3.timer(tweenRot);\n  }\n\n  function onGlobeMousemove(event) {\n    var map, material;\n\n    // Get pointc, convert to latitude/longitude\n    var latlng = getEventCenter.call(this, event);\n\n    // Look for country at that latitude/longitude\n    var country = geo.search(latlng[0], latlng[1]);\n\n    if (country !== null && country.code !== currentCountry) {\n\n      // Track the current country displayed\n      currentCountry = country.code;\n\n      // Update the html\n      d3.select(\"#msg\").html(country.code);\n\n       // Overlay the selected country\n      map = textureCache(country.code, '#CDC290');\n      material = new THREE.MeshPhongMaterial({map: map, transparent: true});\n      if (!overlay) {\n        overlay = new THREE.Mesh(new THREE.SphereGeometry(201, 40, 40), material);\n        overlay.rotation.y = Math.PI;\n        root.add(overlay);\n      } else {\n        overlay.material = material;\n      }\n    }\n  }\n\n  setEvents(camera, [baseGlobe], 'click');\n  setEvents(camera, [baseGlobe], 'mousemove', 10);\n});\n\nfunction animate() {\n  requestAnimationFrame(animate);\n  renderer.render(scene, camera);\n}\nanimate();\n"]} }).call(__global);