|
@@ -24,8 +24,6 @@
|
|
|
|
|
|
<script>
|
|
<script>
|
|
|
|
|
|
- var SCREEN_WIDTH = window.innerWidth / 2;
|
|
|
|
- var SCREEN_HEIGHT = window.innerHeight / 2;
|
|
|
|
var AMOUNT = 100;
|
|
var AMOUNT = 100;
|
|
|
|
|
|
var stats;
|
|
var stats;
|
|
@@ -35,17 +33,15 @@
|
|
|
|
|
|
var mesh, group;
|
|
var mesh, group;
|
|
|
|
|
|
- var mouseX = 0, mouseY = 0;
|
|
|
|
-
|
|
|
|
- var windowHalfX = window.innerWidth / 2;
|
|
|
|
- var windowHalfY = window.innerHeight / 2;
|
|
|
|
-
|
|
|
|
init();
|
|
init();
|
|
animate();
|
|
animate();
|
|
|
|
|
|
function init() {
|
|
function init() {
|
|
|
|
|
|
- camera = new THREE.PerspectiveCamera( 75, SCREEN_WIDTH / SCREEN_HEIGHT, 1, 100000 );
|
|
|
|
|
|
+ var width = window.innerWidth / 2;
|
|
|
|
+ var height = window.innerHeight / 2;
|
|
|
|
+
|
|
|
|
+ camera = new THREE.PerspectiveCamera( 75, width / height, 1, 10000 );
|
|
camera.position.z = 500;
|
|
camera.position.z = 500;
|
|
|
|
|
|
scene = new THREE.Scene();
|
|
scene = new THREE.Scene();
|
|
@@ -184,23 +180,23 @@
|
|
|
|
|
|
canvasRenderer = new THREE.CanvasRenderer();
|
|
canvasRenderer = new THREE.CanvasRenderer();
|
|
canvasRenderer.setClearColor( 0xf0f0f0 );
|
|
canvasRenderer.setClearColor( 0xf0f0f0 );
|
|
- canvasRenderer.setSize( SCREEN_WIDTH, SCREEN_HEIGHT );
|
|
|
|
|
|
+ canvasRenderer.setSize( width, height );
|
|
document.body.appendChild( canvasRenderer.domElement );
|
|
document.body.appendChild( canvasRenderer.domElement );
|
|
|
|
|
|
svgRenderer = new THREE.SVGRenderer();
|
|
svgRenderer = new THREE.SVGRenderer();
|
|
svgRenderer.setClearColor( 0xf0f0f0 );
|
|
svgRenderer.setClearColor( 0xf0f0f0 );
|
|
- svgRenderer.setSize( SCREEN_WIDTH, SCREEN_HEIGHT );
|
|
|
|
|
|
+ svgRenderer.setSize( width, height );
|
|
svgRenderer.setQuality( 'low' );
|
|
svgRenderer.setQuality( 'low' );
|
|
document.body.appendChild( svgRenderer.domElement );
|
|
document.body.appendChild( svgRenderer.domElement );
|
|
|
|
|
|
softwareRenderer = new THREE.SoftwareRenderer();
|
|
softwareRenderer = new THREE.SoftwareRenderer();
|
|
softwareRenderer.setClearColor( 0xf0f0f0 );
|
|
softwareRenderer.setClearColor( 0xf0f0f0 );
|
|
- softwareRenderer.setSize( SCREEN_WIDTH, SCREEN_HEIGHT );
|
|
|
|
|
|
+ softwareRenderer.setSize( width, height );
|
|
document.body.appendChild( softwareRenderer.domElement );
|
|
document.body.appendChild( softwareRenderer.domElement );
|
|
|
|
|
|
webglRenderer = new THREE.WebGLRenderer( { antialias: true } );
|
|
webglRenderer = new THREE.WebGLRenderer( { antialias: true } );
|
|
webglRenderer.setClearColor( 0xf0f0f0 );
|
|
webglRenderer.setClearColor( 0xf0f0f0 );
|
|
- webglRenderer.setSize( SCREEN_WIDTH, SCREEN_HEIGHT );
|
|
|
|
|
|
+ webglRenderer.setSize( width, height );
|
|
document.body.appendChild( webglRenderer.domElement );
|
|
document.body.appendChild( webglRenderer.domElement );
|
|
|
|
|
|
stats = new Stats();
|
|
stats = new Stats();
|
|
@@ -208,8 +204,6 @@
|
|
stats.domElement.style.top = '0px';
|
|
stats.domElement.style.top = '0px';
|
|
document.body.appendChild( stats.domElement );
|
|
document.body.appendChild( stats.domElement );
|
|
|
|
|
|
- document.addEventListener( 'mousemove', onDocumentMouseMove, false );
|
|
|
|
-
|
|
|
|
//
|
|
//
|
|
|
|
|
|
window.addEventListener( 'resize', onWindowResize, false );
|
|
window.addEventListener( 'resize', onWindowResize, false );
|
|
@@ -218,26 +212,16 @@
|
|
|
|
|
|
function onWindowResize() {
|
|
function onWindowResize() {
|
|
|
|
|
|
- windowHalfX = window.innerWidth / 2;
|
|
|
|
- windowHalfY = window.innerHeight / 2;
|
|
|
|
-
|
|
|
|
- SCREEN_WIDTH = window.innerWidth / 2;
|
|
|
|
- SCREEN_HEIGHT = window.innerHeight / 2;
|
|
|
|
|
|
+ var width = window.innerWidth / 2;
|
|
|
|
+ var height = window.innerHeight / 2;
|
|
|
|
|
|
- camera.aspect = SCREEN_WIDTH / window.SCREEN_HEIGHT;
|
|
|
|
|
|
+ camera.aspect = width / height;
|
|
camera.updateProjectionMatrix();
|
|
camera.updateProjectionMatrix();
|
|
|
|
|
|
- canvasRenderer.setSize( SCREEN_WIDTH, SCREEN_HEIGHT );
|
|
|
|
- svgRenderer.setSize( SCREEN_WIDTH, SCREEN_HEIGHT );
|
|
|
|
- softwareRenderer.setSize( SCREEN_WIDTH, SCREEN_HEIGHT );
|
|
|
|
- webglRenderer.setSize( SCREEN_WIDTH, SCREEN_HEIGHT );
|
|
|
|
-
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- function onDocumentMouseMove( event ) {
|
|
|
|
-
|
|
|
|
- mouseX = ( event.clientX - windowHalfX );
|
|
|
|
- mouseY = ( event.clientY - windowHalfY );
|
|
|
|
|
|
+ canvasRenderer.setSize( width, height );
|
|
|
|
+ svgRenderer.setSize( width, height );
|
|
|
|
+ softwareRenderer.setSize( width, height );
|
|
|
|
+ webglRenderer.setSize( width, height );
|
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
@@ -254,11 +238,13 @@
|
|
|
|
|
|
function render() {
|
|
function render() {
|
|
|
|
|
|
- camera.position.x += ( mouseX - camera.position.x ) * .05;
|
|
|
|
- camera.position.y += ( - mouseY - camera.position.y ) * .05;
|
|
|
|
|
|
+ var time = Date.now() * 0.0002;
|
|
|
|
+
|
|
|
|
+ camera.position.x = Math.sin( time ) * 500;
|
|
|
|
+ camera.position.z = Math.cos( time ) * 500;
|
|
camera.lookAt( scene.position );
|
|
camera.lookAt( scene.position );
|
|
|
|
|
|
- group.rotation.y += 0.01;
|
|
|
|
|
|
+ group.rotation.x += 0.01;
|
|
|
|
|
|
scene.updateMatrixWorld();
|
|
scene.updateMatrixWorld();
|
|
|
|
|