BabylonJS - Matériaux

Les matériaux sont comme des vêtements pour les objets. Vous pouvez ajouter de la couleur, de la texture et envelopper vos maillages avec. Vous pouvez utiliser le même matériau pour couvrir de nombreux maillages. Les maillages peuvent être la scène que nous venons de voir dans l'exemple du chapitre précédent - l'avion traversant le ciel.

Dans ce chapitre, nous allons apprendre à ajouter de la couleur, de la texture, de la réflexion pour les maillages de ce chapitre.

Nous ajouterons du matériel à la scène déjà créée. Nous progresserons en ajoutant de la matière à toutes les formes que nous avons créées.

Prenons quelques exemples pour voir comment fonctionne l'ajout de matière.

Syntaxe

var materialforshapes = new BABYLON.StandardMaterial("texture1", scene);

Le matériel ci-dessus ne changera rien puisqu'il s'agit de celui par défaut. Nous utiliserons les propriétés disponibles pour rendre les objets plus attrayants.

Les propriétés disponibles sont les suivantes -

  • Transparency

  • Diffuse

  • Emissive

  • Ambient

  • Specular

  • Élimination de la face arrière

  • WireFrame

Regardez comment ces propriétés appliquées au matériau modifient l'aspect et la sensation du maillage.

Propriété de base du matériau - FresnelParameters

Fresnel est la nouveauté ajoutée par BabylonJS sur standardmaterial. Il permet de changer la couleur appliquée sur les formes. Vous pouvez obtenir du verre comme une réflexion en utilisant le simple Fresnel. Le Fresnel vous permettra d'avoir plus de réflexion sur les bords et pas tout au centre.

Les propriétés suivantes sont disponibles pour Fresnel

StandardMaterial.diffuseFresnelParameters
StandardMaterial.opacityFresnelParameters
StandardMaterial.reflectionFresnelParameters
StandardMaterial.emissiveFresnelParameters
StandardMaterial.refractionFresnelParameters

Démo

<!doctype html>
<html>
   <head>
      <meta charset = "utf-8">
      <title>BabylonJs - Basic Element-Creating Scene</title>
      <script src = "babylon.js"></script>
      <style>
         canvas {width: 100%; height: 100%;}
      </style>
   </head>

   <body>
      <canvas id = "renderCanvas"></canvas>
      <script type = "text/javascript">
         var canvas = document.getElementById("renderCanvas");
         var engine = new BABYLON.Engine(canvas, true);
         var createScene  = function() {
            var scene = new BABYLON.Scene(engine);

            var camera = new BABYLON.ArcRotateCamera("camera1", 0, 0, 10, BABYLON.Vector3.Zero(), scene);

            camera.setPosition(new BABYLON.Vector3(0, 5, -10));

            camera.attachControl(canvas);
            camera.upperBetaLimit = Math.PI / 2;
            camera.lowerRadiusLimit = 4;

            var light = new BABYLON.HemisphericLight("light1", new BABYLON.Vector3(0, 1, 0), scene);
            light.intensity = 0.7;

            var knot = BABYLON.Mesh.CreateTorusKnot("knot", 1, 0.4, 128, 64, 2, 3, scene);	
            var yellowSphere = BABYLON.Mesh.CreateSphere("yellowSphere", 16, 1.5, scene);
            yellowSphere.setPivotMatrix(BABYLON.Matrix.Translation(3, 0, 0));
            var yellowMaterial = new BABYLON.StandardMaterial("yellowMaterial", scene);
            yellowMaterial.diffuseColor = BABYLON.Color3.Yellow();
            yellowSphere.material = yellowMaterial;    

            // Ground
            var ground = BABYLON.Mesh.CreateBox("Mirror", 1.0, scene);
            ground.scaling = new BABYLON.Vector3(100.0, 0.01, 100.0);
            ground.material = new BABYLON.StandardMaterial("ground", scene);
            ground.material.diffuseTexture = new BABYLON.Texture("images/rainbow.png", scene);
            ground.material.diffuseTexture.uScale = 10;
            ground.material.diffuseTexture.vScale = 10;
            ground.position = new BABYLON.Vector3(0, -2, 0);

            // Main material	
            var mainMaterial = new BABYLON.StandardMaterial("main", scene);
            knot.material = mainMaterial;

            var probe = new BABYLON.ReflectionProbe("main", 512, scene);
            probe.renderList.push(yellowSphere);
            probe.renderList.push(ground);
            mainMaterial.diffuseColor = new BABYLON.Color3(1, 0.5, 0.5);
            mainMaterial.refractionTexture = probe.cubeTexture;
            mainMaterial.refractionFresnel<h3>Parameters</h3> = new BABYLON.Fresnel<h3>Parameters</h3>();
            mainMaterial.refractionFresnel<h3>Parameters</h3>.bias = 0.5;
            mainMaterial.refractionFresnel<h3>Parameters</h3>.power = 16;
            mainMaterial.refractionFresnel<h3>Parameters</h3>.leftColor = BABYLON.Color3.Black();
            mainMaterial.refractionFresnel<h3>Parameters</h3>.rightColor = BABYLON.Color3.White();
            mainMaterial.indexOfRefraction = 1.05;

            // Fog
            scene.fogMode = BABYLON.Scene.FOGMODE_LINEAR;
            scene.fogColor = scene.clearColor;
            scene.fogStart = 20.0;
            scene.fogEnd = 50.0;

            // Animations
            scene.registerBeforeRender(function () {
               yellowSphere.rotation.y += 0.01;
               //  greenSphere.rotation.y += 0.01;
            });
            return scene;
         };
         var scene = createScene();
         engine.runRenderLoop(function() {
            scene.render();
         });
      </script>
   </body>
</html>

Production

La ligne de code ci-dessus génère la sortie suivante -

Explication

Le code suivant applique l'effet Fresnel. Les couleurs gauche et droite sont appliquées aux bords des maillages.

mainMaterial.refractionFresnelParameters = new BABYLON.FresnelParameters();
mainMaterial.refractionFresnelParameters.bias = 0.5;
mainMaterial.refractionFresnelParameters.power = 16;
mainMaterial.refractionFresnelParameters.leftColor = BABYLON.Color3.Black();
mainMaterial.refractionFresnelParameters.rightColor = BABYLON.Color3.White();

Le biais et la propriété de puissance contrôlent l'effet Fresnel sur la surface.

Dans cette démo, nous avons utilisé une image appelée rainbow.png. Les images sont stockées localement dans un dossier / images. Vous pouvez télécharger n'importe quelle image de votre choix et l'utiliser dans le lien de démonstration.