var ParticleSphere = { init: function () { ParticleSphere.buildWorld(); ParticleSphere.buildObjects(); ParticleSphere.render(); }, buildWorld: function () { ParticleSphere.camera = new THREE.PerspectiveCamera(45, window.innerWidth / window.innerHeight, 0.1, 1000); ParticleSphere.camera.position = new THREE.Vector3(0, 0, 100); ParticleSphere.renderer = new THREE.WebGLRenderer(); ParticleSphere.renderer.setSize(window.innerWidth, window.innerHeight); ParticleSphere.scene = new THREE.Scene(); ParticleSphere.scene.add(ParticleSphere.camera); document.body.appendChild(ParticleSphere.renderer.domElement); }, buildObjects: function () { var nParticles = 1500; var particles = new THREE.Geometry(); var material = new THREE.PointCloudMaterial({ size: 20, color: 0xffffff, map: new THREE.ImageUtils.loadTexture(''), transparent: true, alphaTest: 0.5 }); ParticleSphere.particleObj = new THREE.Object3D(); var vertex, point; for(var i = 0; i < nParticles; i++) { point = randomPoint(0, 0, 0, 150); vertex = new THREE.Vector3(point[0], point[1], point[2]); particles.vertices.push(vertex); } function randomPoint(x0, y0, z0, r) { var u = Math.random(); var v = Math.random(); var t = 2 * Math.PI * u; var p = Math.acos(2 * v - 1); var x = x0 + (r * Math.sin(p) * Math.cos(t)); var y = y0 + (r * Math.sin(p) * Math.sin(t)); var z = z0 + (r * Math.cos(p)); return [x, y, z]; }; var particleSystem = new THREE.PointCloud(particles, material); particleSystem.sortParticles = true; ParticleSphere.particleObj.add(particleSystem); ParticleSphere.particleObj.position.z = -550; new TWEEN.Tween(particleSystem.scale) .to({ x: 0.25, y: 0.25, z: 0.25}) .repeat(Infinity) .yoyo(true) .easing(TWEEN.Easing.Sinusoidal.InOut) .start(); ParticleSphere.scene.add(ParticleSphere.particleObj); }, render: function() { function render() { requestAnimationFrame(render); TWEEN.update(); if(ParticleSphere.particleObj) { ParticleSphere.particleObj.rotation.x += 0.01; ParticleSphere.particleObj.rotation.y += 0.01; } ParticleSphere.renderer.render(ParticleSphere.scene, ParticleSphere.camera) } render(); } } ParticleSphere.init();