index.html 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. <head>
  2. <style> body { margin: 0; } </style>
  3. <script src="//unpkg.com/three"></script>
  4. <script src="//unpkg.com/3d-force-graph"></script>
  5. <!--<script src="../../dist/3d-force-graph.js"></script>-->
  6. </head>
  7. <body>
  8. <div id="3d-graph"></div>
  9. <script>
  10. const imgs = ['cat.jpg', 'dog.jpg', 'eagle.jpg', 'elephant.jpg', 'grasshopper.jpg', 'octopus.jpg', 'owl.jpg', 'panda.jpg', 'squirrel.jpg', 'tiger.jpg', 'whale.jpg'];
  11. // Random connected graph
  12. const gData = {
  13. nodes: imgs.map((img, id) => ({ id, img })),
  14. links: [...Array(imgs.length).keys()]
  15. .filter(id => id)
  16. .map(id => ({
  17. source: id,
  18. target: Math.round(Math.random() * (id-1))
  19. }))
  20. };
  21. const Graph = ForceGraph3D()
  22. (document.getElementById('3d-graph'))
  23. .nodeThreeObject(({ img }) => {
  24. const imgTexture = new THREE.TextureLoader().load(`./imgs/${img}`);
  25. const material = new THREE.SpriteMaterial({ map: imgTexture });
  26. const sprite = new THREE.Sprite(material);
  27. sprite.scale.set(12, 12);
  28. return sprite;
  29. })
  30. .graphData(gData);
  31. </script>
  32. </body>