index.html 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <title>three.js gui</title>
  5. <style>
  6. body {
  7. font-family: Arial, sans-serif;
  8. font-size: 14px;
  9. margin: 0;
  10. overflow: hidden;
  11. }
  12. hr {
  13. border: 0px;
  14. border-top: 1px solid #ccc;
  15. }
  16. </style>
  17. </head>
  18. <body>
  19. <script type="text/javascript" src="../build/Three.js"></script>
  20. <script type="text/javascript" src="js/libs/signals.min.js"></script>
  21. <script type="text/javascript" src="js/UI.js"></script>
  22. <script type="text/javascript" src="js/ui/Viewport.js"></script>
  23. <script type="text/javascript" src="js/ui/Panel.js"></script>
  24. <script>
  25. var SIGNALS = signals;
  26. var signals = {
  27. objectAdded: new SIGNALS.Signal(),
  28. objectSelected: new SIGNALS.Signal(),
  29. windowResize: new SIGNALS.Signal()
  30. };
  31. //
  32. var viewport = new Viewport( signals );
  33. viewport.setWidth( '-webkit-calc(100% - 300px)' );
  34. viewport.setWidth( '-moz-calc(100% - 300px)' );
  35. viewport.setWidth( 'calc(100% - 300px)' );
  36. viewport.setHeight( '100%' );
  37. document.body.appendChild( viewport.dom );
  38. var panel = new Panel( signals );
  39. panel.setX( '-webkit-calc(100% - 300px)' );
  40. panel.setX( '-moz-calc(100% - 300px)' );
  41. panel.setX( 'calc(100% - 300px)' );
  42. document.body.appendChild( panel.dom );
  43. //
  44. var geometry = new THREE.SphereGeometry( 75, 25, 15 );
  45. var material = new THREE.MeshBasicMaterial( { color: Math.random() * 0xffffff } );
  46. var mesh = new THREE.Mesh( geometry, material );
  47. signals.objectAdded.dispatch( mesh );
  48. //
  49. var onWindowResize = function ( event ) {
  50. signals.windowResize.dispatch();
  51. };
  52. onWindowResize();
  53. window.addEventListener( 'resize', onWindowResize, false );
  54. </script>
  55. </body>
  56. </html>