100 000 et un object WebGL / three.js
sli.do/1618
data:image/s3,"s3://crabby-images/8160f/8160f5d6475bba0a4193b97d19a580ab606dc60b" alt=""
data:image/s3,"s3://crabby-images/a963d/a963d720425c71ce3df0bf891238bd76be48d7c7" alt=""
data:image/s3,"s3://crabby-images/2fb53/2fb533e4b2e078d4d304840f865f207b33642e11" alt=""
Prince of Persia - 1989
data:image/s3,"s3://crabby-images/30550/30550f495138c64462cb7d573f9f5eb4ee186f62" alt=""
La cité idéale - 1465
data:image/s3,"s3://crabby-images/674f5/674f5c8b789d239920aa2b2336cffbe7639c1634" alt=""
Starfox - 1993
data:image/s3,"s3://crabby-images/af61a/af61abb59720a76bac1fb80319b46007206e5d6e" alt=""
Metal Gear Solid - 1998
Uncharted 4 - 2016
data:image/s3,"s3://crabby-images/19c3e/19c3e397a755ab314230f840b21a5cdc0695b2ed" alt=""
@AnasAmeziane
data:image/s3,"s3://crabby-images/350f2/350f2aa24878103203273e261574a117e1dd071e" alt=""
data:image/s3,"s3://crabby-images/1fd11/1fd1122642360ae5488d10891eeb3f2e35f574e3" alt=""
anas@ozzo.io
data:image/s3,"s3://crabby-images/67c6d/67c6d70992a62532fdfa796a749fccaaadbbb74c" alt=""
Fondateur de ozzo.io
Anas AMEZIANE
Trading automatique et évolutif sur les marchés de cryptomonnaie
data:image/s3,"s3://crabby-images/6022f/6022ff52107d2da38a06d2b9f9d5aa4d7e8c8173" alt=""
data:image/s3,"s3://crabby-images/7e6fc/7e6fcb69ec85f88b1c339f4feb2fa184c2b27e16" alt=""
data:image/s3,"s3://crabby-images/49335/493355f79e15639d2c6acca97480e9ce726f21d6" alt=""
data:image/s3,"s3://crabby-images/fd6d2/fd6d245977d1422559a1c5e16d229fa420259a3d" alt=""
Architecture
data:image/s3,"s3://crabby-images/51b82/51b825b725bd421fdd66cf2fc2dc080ea9dd8442" alt=""
WebGL
data:image/s3,"s3://crabby-images/e3018/e3018dfe3588350dd737be7a15bff53e5cbaa13e" alt=""
Browsers
WebGL est une API de pixellisation, pas une API 3D
The graphics pipeline
Vertex processing
Les "vertex" sont transformés à des positions sur l’écran
data:image/s3,"s3://crabby-images/c1fe4/c1fe4a3a16ed81c2011805cc328a6b8e1adea341" alt=""
Primitive processing
Puis organisés et assemblés en primitives
data:image/s3,"s3://crabby-images/fb1b7/fb1b704abe05f6ab9d3146ad15d0ff8b6e0e4ff5" alt=""
Primitive processing
data:image/s3,"s3://crabby-images/c9f18/c9f18279f8c3f891b14b56ead4911fad5cf6becb" alt=""
les primitives sont pixelisées en fragments
Fragment processing
les fragment sont transformés à des pixels colorés
data:image/s3,"s3://crabby-images/8b9f3/8b9f3d773ddc4aa6fcf33f8916eb3fba54023e58" alt=""
Fragment processing
Les fragments sont mélangés dans le buffer d'image à leur emplacements de pixels
data:image/s3,"s3://crabby-images/bf074/bf0742f3f21de3c4dc9e9d885077ec67ab6b1787" alt=""
pipeline
data:image/s3,"s3://crabby-images/34f30/34f30b50418017e5fbb6ccb7dacc24cf64d1c807" alt=""
data:image/s3,"s3://crabby-images/e4cc2/e4cc281b4bf48baa738bd0f14def73b015aa533c" alt=""
Shader
data:image/s3,"s3://crabby-images/7d2e7/7d2e77179cab7e1a1914733d984d4c7cd798ba28" alt=""
Les shaders sont un ensemble d'instructions exécutées en une seule fois pour chaque pixel de l'écran.
data:image/s3,"s3://crabby-images/136f7/136f7794a879b811dbdf4c6e5a8623ac93fde418" alt=""
data:image/s3,"s3://crabby-images/6c5ef/6c5eff669d8c7e2b994c134aa1e412761313bc3a" alt=""
CPU
data:image/s3,"s3://crabby-images/2dec0/2dec039f650106cda99db9e353930c6d3cff69c2" alt=""
GPU
<script id="vertex-shader" type="notjs">
attribute vec4 a_position;
void main() {
gl_Position = a_position;
}
</script>
<script id="fragment-shader" type="notjs">
precision mediump float;
void main() {
gl_FragColor = vec4(1, 0, 0.5, 1);
}
</script>
GLSL
( openGL Shading Language)
webglfundamentals.org
thebookofshaders.com
WebGL libraries
data:image/s3,"s3://crabby-images/fcfd5/fcfd5931f4b2c5c85f64a435a11b0685745a32bb" alt=""
data:image/s3,"s3://crabby-images/1c3c0/1c3c0d67aa6432cc04f22e0ab26bce0a6f205003" alt=""
Threejs
<!DOCTYPE html>
<html lang="en">
<head>
<title>Basic Three.js App</title>
<style>
html, body { margin: 0; padding: 0; overflow: hidden; }
</style>
</head>
<body>
<script src="js/three.min.js"></script>
<script>
// Javascript will go here.
</script>
</body>
</html>
var scene = new THREE.Scene();
var aspect = window.innerWidth / window.innerHeight;
var camera = new THREE.PerspectiveCamera( 75, aspect, 0.1, 1000 );
var renderer = new THREE.WebGLRenderer();
renderer.setSize( window.innerWidth, window.innerHeight );
document.body.appendChild( renderer.domElement );
var geometry = new THREE.BoxGeometry( 1, 1, 1 );
var material = new THREE.MeshNormalMaterial();
var cube = new THREE.Mesh( geometry, material );
scene.add( cube );
camera.position.z = 5;
var render = function () {
requestAnimationFrame( render );
cube.rotation.x += 0.1;
cube.rotation.y += 0.1;
renderer.render( scene, camera );
};
render();
data:image/s3,"s3://crabby-images/a5fe7/a5fe7a6a2652d931104d0c8f127a546ed88d57fe" alt=""
Scene
data:image/s3,"s3://crabby-images/ee4af/ee4af07610bb0d27fd06fbc3e570fe19bf2a7652" alt=""
Camera
data:image/s3,"s3://crabby-images/71e69/71e69066c45c9e09f912b3027c3a113c7b1ff320" alt=""
data:image/s3,"s3://crabby-images/4c59a/4c59aa8454813797936e9a09818c5d74d6db0d81" alt=""
data:image/s3,"s3://crabby-images/5b974/5b974e12121ddc9458621f0c342bdaf58cbf4e17" alt=""
data:image/s3,"s3://crabby-images/98d1e/98d1e258297fc6f69573297be32fb5645ed210a2" alt=""
var camera = new THREE.PerspectiveCamera(
40, //fov
canvasWidth / canvasHeight, //aspect
0.1, //near
1000 //far
);
Perspective Camera
var viewSize = 900;
var aspectRatio = canvasWidth/canvasHeight;
var camera = new THREE.OrthographicCamera(
-aspectRatio * viewSize / 2, //left
aspectRatio * viewSize / 2, //right
viewSize / 2, //top
-viewSize / 2, //bottom
-1000, //near
1000 //far
);
Orthographic Camera
data:image/s3,"s3://crabby-images/e8430/e843006b23e8da4252ded49ea7aebae01a53a052" alt=""
data:image/s3,"s3://crabby-images/d4d3a/d4d3ac2a718e1ea9bd539bbbd087eb2b697108cb" alt=""
Diablo, Civilization and SimCity
Orthographic Camera
<script src="path/to/OrbitControls.js"></script>
controls = new THREE.OrbitControls( camera );
function render() {
requestAnimationFrame( render );
controls.update();
renderer.render( scene, camera );
}
Camera controls
https://threejs.org/examples/js/controls/OrbitControls.js
Mesh
Geometry + Material
Geometry
data:image/s3,"s3://crabby-images/ec2f6/ec2f6c890c5b616d111a9c50a24f1fb14c0a10ba" alt=""
BoxBufferGeometry, BoxGeometry, ,CircleBufferGeometry, CircleGeometry, ConeBufferGeometry, ConeGeometry, CylinderBufferGeometry, CylinderGeometry, DodecahedronBufferGeometry, DodecahedronGeometry, EdgesGeometry, ExtrudeBufferGeometry, ExtrudeGeometry, IcosahedronBufferGeometry, IcosahedronGeometry, LatheBufferGeometry, LatheGeometry, OctahedronBufferGeometry, OctahedronGeometry, ParametricBufferGeometry, ParametricGeometry, PlaneBufferGeometry, PlaneGeometry, PolyhedronBufferGeometry, PolyhedronGeometry, RingBufferGeometry, RingGeometry, ShapeBufferGeometry, ShapeGeometry, SphereBufferGeometry, SphereGeometry, TetrahedronBufferGeometry, TetrahedronGeometry, TextBufferGeometry, TextGeometry, TorusBufferGeometry, TorusGeometry, TorusKnotBufferGeometry, TorusKnotGeometry, TubeBufferGeometry, TubeGeometry, WireframeGeometry
Cube
var geometry = new THREE.BoxGeometry(
1, //width
1, //height
1 //depth
);
var material = new THREE.MeshBasicMaterial( {color: 0x00ff00} );
var cube = new THREE.Mesh( geometry, material );
scene.add( cube );
Sphere
var geometry = new THREE.SphereGeometry(
5, //radius
32, //widthSegments
32 //heightSegments
);
var material = new THREE.MeshBasicMaterial( {color: 0xffff00} );
var sphere = new THREE.Mesh( geometry, material );
scene.add( sphere );
BufferGeometry
var geometry = new THREE.BufferGeometry();
var vertices = new Float32Array( [
-1.0, -1.0, 1.0,
1.0, -1.0, 1.0,
1.0, 1.0, 1.0,
-1.0, 1.0, 1.0
]);
geometry.addAttribute( 'position', new THREE.BufferAttribute( vertices, 3 ) );
var material = new THREE.PointsMaterial( { color: 0xff0000 } );
var mesh = new THREE.Points( geometry, material );
Material
data:image/s3,"s3://crabby-images/5a9a5/5a9a550c8aab4fdea7a1e04598df5ea02ff75323" alt=""
MeshNormalMaterial
MeshNormalMaterial( parameters : Object )
MeshStandardMaterial
MeshStandardMaterial( parameters : Object )
MeshPhongMaterial
MeshPhongMaterial( parameters : Object )
PointsMaterial
let ozzoBotPointsMaterial = new THREE.PointsMaterial({
size: 8,
vertexColors: THREE.VertexColors,
map: new THREE.TextureLoader().load(CircleSprite),
});
data:image/s3,"s3://crabby-images/b9f18/b9f18c9efcb14cd6670bff032ca85f2397950344" alt=""
Texture
data:image/s3,"s3://crabby-images/6791c/6791cd6a93a852db22c7595d4603e67f243111c4" alt=""
data:image/s3,"s3://crabby-images/430bf/430bf5f6e87437d92a9bab3ed63789637999b12f" alt=""
+
=
http://planetpixelemporium.com/mars.html
Texture map
var PLANET_RADIUS = 1;
let planetMesh = new THREE.Mesh(
new THREE.SphereBufferGeometry(PLANET_RADIUS, 32, 32),
new THREE.MeshPhongMaterial({
map: new THREE.TextureLoader().load('images/mars_4k_color.jpg')
})
);
Texture bump
var PLANET_RADIUS = 1;
var planetMesh = new THREE.Mesh(
new THREE.SphereBufferGeometry(PLANET_RADIUS, 32, 32),
new THREE.MeshPhongMaterial({
map: new THREE.TextureLoader().load('images/mars_4k_color.jpg'),
bumpMap: new THREE.TextureLoader().load('images/mars_4k_bump.jpg'),
bumpScale: 0.05
})
);
data:image/s3,"s3://crabby-images/61942/61942b0346d6d64a50b92743a4911c7c866306a5" alt=""
Light & shadows
var light = new THREE.DirectionalLight( 0xdddddd, 0.8 );
light.position.set(5, 0, 5);
scene.add(light);
DirectionalLight
scene.add(new THREE.AmbientLight( 0x444444, 0.8));
AmbientLight
renderer.shadowMap.enabled = true;
renderer.shadowMap.type = THREE.PCFSoftShadowMap;
light.castShadow = true;
planetMesh.receiveShadow = true;
planetMesh.castShadow = true;
moonMesh.castShadow = true;
moonMesh.receiveShadow = true;
Shadow
var D_THETA = 0.005;
var theta = 0;
function animate() {
requestAnimationFrame( animate );
//rotate animation
planetMesh.rotation.y += (0.5*(Math.PI / 180)) % 360;
moonMesh.rotation.y += (0.5*(Math.PI / 180)) % 360;
//orbit animation
theta += D_THETA;
moonMesh.position.x = (PLANET_RADIUS + MOON_RADIUS + MOON_DISTANCE) * Math.cos(theta);
moonMesh.position.z = (PLANET_RADIUS + MOON_RADIUS + MOON_DISTANCE) * Math.sin(theta);
controls.update();
renderer.render( scene, camera );
}
Animation
threejs
By anas ameziane
threejs
- 2,071