Three.js particles

Size
7,333 Kb
Views
6,072

How do I make an three.js particles?

A quick play with particles in three.js - I've discovered that they don't respond to the lighting in a scene.. What is a three.js particles? How do you make a three.js particles? This script and codes were developed by Sarah Cartwright on 05 December 2022, Monday.

Three.js particles Previews

Three.js particles - Script Codes HTML Codes

<!DOCTYPE html>
<html >
<head> <meta charset="UTF-8"> <title>Three.js particles</title> <link rel="stylesheet" href="css/style.css">
</head>
<body> <script src='https://cdnjs.cloudflare.com/ajax/libs/three.js/r79/three.min.js'></script> <script src="js/index.js"></script>
</body>
</html>

Three.js particles - Script Codes CSS Codes

body {	margin: 0px; padding 0px;	overflow: hidden;
}

Three.js particles - Script Codes JS Codes

var smokeImage = new Image();
smokeImage.src = "";
var smokeTexture = new THREE.Texture();
smokeTexture.image = smokeImage;
smokeTexture.needsUpdate = true;
var scene = new THREE.Scene();
var camera = new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 0.1, 1000 );
camera.position.z = 5;
camera.position.set( 0, 0, 250 );
var renderer = new THREE.WebGLRenderer();
renderer.setSize( window.innerWidth + 2, window.innerHeight + 2);
document.body.appendChild( renderer.domElement );
window.addEventListener( 'resize', onWindowResize, false );
function onWindowResize() { camera.aspect = window.innerWidth / window.innerHeight; camera.updateProjectionMatrix(); renderer.setSize( window.innerWidth + 2 , window.innerHeight + 2);
}
var pMaterial = new THREE.MeshLambertMaterial({ color: 0xffffff, //size: 20, map: smokeTexture, blending: THREE.AdditiveBlending, depthTest: true, transparent: false });
//THREE.MeshLambertMaterial( { color: 0xffffff, shading: THREE.SmoothShading } );
var pMaterial2 = new THREE.PointsMaterial({ color: 0x909090, size: 20, map: smokeTexture, blending: THREE.AdditiveBlending, depthTest: false, transparent: true });
var particleCount = 5000, particles = new THREE.Geometry();
for(var i = 0; i<particleCount; i++) { var pX = Math.random()*1000 - 500, pY = Math.random()*1500 - 500, pZ = Math.random()*1000 - 500, particle = new THREE.Vector3(pX, pY, pZ); particle.velocity = {}; particle.velocity.y = (Math.random() * -5)-4; particles.vertices.push(particle);
}
var particleSystem = new THREE.Points(particles, pMaterial2);
var light = new THREE.PointLight(0x202030, 10, 800, 1);
light.position.set(200, 200, 0);
var cube = new THREE.CubeGeometry( 2000, 1, 2000);
cube.translate( 0, -100, -10 );
var purpleMat = new THREE.MeshPhongMaterial( { color: 0x505050, specular: 0x555555, shininess: 2 } );
var floor = new THREE.Mesh(cube, purpleMat );
scene.add(floor);
scene.add(particleSystem);
//scene.add(new THREE.HemisphereLight(0xffffff, 0x333333));
scene.add(light);
function updateAnimation(){ var pCount = particleCount; while (pCount--) { var particle = particles.vertices[pCount]; if (particle.y < -500) { particle.y = 1000; particle.velocity.y = (Math.random() * -5)-2; } particle.y += particle.velocity.y; } particles.verticesNeedUpdate = true;
}
function render() { requestAnimationFrame( render ); particleSystem.rotation.y += 0.02; updateAnimation(); renderer.render(scene, camera);
}
render();
Three.js particles - Script Codes
Three.js particles - Script Codes
Home Page Home
Developer Sarah Cartwright
Username SarahC
Uploaded December 05, 2022
Rating 3
Size 7,333 Kb
Views 6,072
Do you need developer help for Three.js particles?

Find the perfect freelance services for your business! Fiverr's mission is to change how the world works together. Fiverr connects businesses with freelancers offering digital services in 500+ categories. Find Developer!

Sarah Cartwright (SarahC) Script Codes
Create amazing web content with AI!

Jasper is the AI Content Generator that helps you and your team break through creative blocks to create amazing, original content 10X faster. Discover all the ways the Jasper AI Content Platform can help streamline your creative workflows. Start For Free!