main.js!eval 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. (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) {
  2. 'use strict';
  3. var scene, camera, renderer, setEvents, convertToXYZ, getEventCenter, geodecoder, mapTexture, getTween, memoize, topojson, THREE, d3;
  4. function animate() {
  5. requestAnimationFrame(animate);
  6. renderer.render(scene, camera);
  7. }
  8. return {
  9. setters: [function (_commonScene) {
  10. scene = _commonScene.scene;
  11. camera = _commonScene.camera;
  12. renderer = _commonScene.renderer;
  13. }, function (_commonSetEvents) {
  14. setEvents = _commonSetEvents.setEvents;
  15. }, function (_commonGeoHelpers) {
  16. convertToXYZ = _commonGeoHelpers.convertToXYZ;
  17. getEventCenter = _commonGeoHelpers.getEventCenter;
  18. geodecoder = _commonGeoHelpers.geodecoder;
  19. }, function (_commonMapTexture) {
  20. mapTexture = _commonMapTexture.mapTexture;
  21. }, function (_commonUtils) {
  22. getTween = _commonUtils.getTween;
  23. memoize = _commonUtils.memoize;
  24. }, function (_topojson) {
  25. topojson = _topojson['default'];
  26. }, function (_THREE) {
  27. THREE = _THREE['default'];
  28. }, function (_d3) {
  29. d3 = _d3['default'];
  30. }],
  31. execute: function () {
  32. d3.json('data/world.json', function (err, data) {
  33. d3.select('#loading').transition().duration(500).style('opacity', 0).remove();
  34. var currentCountry, overlay;
  35. var segments = 155; // number of vertices. Higher = better mouse accuracy
  36. // Setup cache for country textures
  37. var countries = topojson.feature(data, data.objects.countries);
  38. var geo = geodecoder(countries.features);
  39. var textureCache = memoize(function (cntryID, color) {
  40. var country = geo.find(cntryID);
  41. return mapTexture(country, color);
  42. });
  43. // Base globe with blue "water"
  44. var blueMaterial = new THREE.MeshPhongMaterial({ color: '#2B3B59', transparent: true });
  45. var sphere = new THREE.SphereGeometry(200, segments, segments);
  46. var baseGlobe = new THREE.Mesh(sphere, blueMaterial);
  47. baseGlobe.rotation.y = Math.PI;
  48. baseGlobe.addEventListener('click', onGlobeClick);
  49. baseGlobe.addEventListener('mousemove', onGlobeMousemove);
  50. // add base map layer with all countries
  51. var worldTexture = mapTexture(countries, '#647089');
  52. var mapMaterial = new THREE.MeshPhongMaterial({ map: worldTexture, transparent: true });
  53. var baseMap = new THREE.Mesh(new THREE.SphereGeometry(200, segments, segments), mapMaterial);
  54. baseMap.rotation.y = Math.PI;
  55. // create a container node and add the two meshes
  56. var root = new THREE.Object3D();
  57. root.scale.set(2.5, 2.5, 2.5);
  58. root.add(baseGlobe);
  59. root.add(baseMap);
  60. scene.add(root);
  61. function onGlobeClick(event) {
  62. // Get pointc, convert to latitude/longitude
  63. var latlng = getEventCenter.call(this, event);
  64. // Get new camera position
  65. var temp = new THREE.Mesh();
  66. temp.position.copy(convertToXYZ(latlng, 900));
  67. temp.lookAt(root.position);
  68. temp.rotateY(Math.PI);
  69. for (var key in temp.rotation) {
  70. if (temp.rotation[key] - camera.rotation[key] > Math.PI) {
  71. temp.rotation[key] -= Math.PI * 2;
  72. } else if (camera.rotation[key] - temp.rotation[key] > Math.PI) {
  73. temp.rotation[key] += Math.PI * 2;
  74. }
  75. }
  76. var tweenPos = getTween.call(camera, 'position', temp.position);
  77. d3.timer(tweenPos);
  78. var tweenRot = getTween.call(camera, 'rotation', temp.rotation);
  79. d3.timer(tweenRot);
  80. }
  81. function onGlobeMousemove(event) {
  82. var map, material;
  83. // Get pointc, convert to latitude/longitude
  84. var latlng = getEventCenter.call(this, event);
  85. // Look for country at that latitude/longitude
  86. var country = geo.search(latlng[0], latlng[1]);
  87. if (country !== null && country.code !== currentCountry) {
  88. // Track the current country displayed
  89. currentCountry = country.code;
  90. // Update the html
  91. d3.select('#msg').html(country.code);
  92. // Overlay the selected country
  93. map = textureCache(country.code, '#CDC290');
  94. material = new THREE.MeshPhongMaterial({ map: map, transparent: true });
  95. if (!overlay) {
  96. overlay = new THREE.Mesh(new THREE.SphereGeometry(201, 40, 40), material);
  97. overlay.rotation.y = Math.PI;
  98. root.add(overlay);
  99. } else {
  100. overlay.material = material;
  101. }
  102. }
  103. }
  104. setEvents(camera, [baseGlobe], 'click');
  105. setEvents(camera, [baseGlobe], 'mousemove', 10);
  106. });animate();
  107. }
  108. };
  109. });
  110. //# 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"]}
  111. }).call(__global);