BabylonJS - Cartographie de parallaxe
Le mappage de parallaxe est également appelé mappage de décalage. Il utilise une carte de hauteur qui est appliquée comme un décalage sur les textures du matériau afin d'accentuer l'effet de relief dans la surface de la géométrie. Dans le 3Dworld, les murs de pierre avec une profondeur appliquée auront une apparence plus apparente et sembleront réalistes pour l'utilisateur final. Aux angles de vue plus raides, les coordonnées de texture sont davantage déplacées, donnant l'illusion de profondeur due aux effets de parallaxe lorsque la vue change.
La cartographie Parallex est utilisée avec du matériel standard. Nous l'avons appris dans le chapitre sur le matériel standard.
Il y a 3 propriétés qui sont présentes avec le mappage parallex.
material.useParallax = true;- Ceci active le mappage parallex. Pour utiliser cette propriété, vous devez d'abord affecter une texture de relief au matériau.
material.useParallaxOcclusion = true;- Pour utiliser cette propriété, vous devez définir useParallax sur true. Il permet l'occlusion de parallaxe.
material.parallaxScaleBias = 0.1;- Applique un facteur de mise à l'échelle pour que la profondeur soit identique au maillage. Une valeur comprise entre 0,05 et 0,1 convient parfaitement à Parallax. Pour l'occlusion, vous pouvez atteindre 0,2.
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() {
// This creates a basic Babylon Scene object (non-mesh)
var scene = new BABYLON.Scene(engine);
// This creates and positions a free camera (non-mesh)
var camera = new BABYLON.ArcRotateCamera("camera1", 0, Math.PI / 2, 100, new BABYLON.Vector3(0, 0, 0), scene);
camera.attachControl(canvas, false);
// This targets the camera to scene origin
camera.setTarget(BABYLON.Vector3.Zero());
// This creates a light, aiming 0,1,0 - to the sky (non-mesh)
var light = new BABYLON.HemisphericLight("light1", new BABYLON.Vector3(0, 1, 0), scene);
// Default intensity is 1. Let's dim the light a small amount
light.intensity = 0.7;
var mesh = BABYLON.Mesh.CreateBox("box01", 25, scene);
mesh.position = new BABYLON.Vector3(0, 0, 0);
var brickWallDiffURL = "images/a1.png";
var brickWallNHURL = "images/a2.png";
var stoneDiffURL = "images/pebble.jpg";
var stoneNHURL = "images/a3.png";
var stoneDiffuseTexture = new BABYLON.Texture(stoneDiffURL, scene);
var stoneNormalsHeightTexture = new BABYLON.Texture(stoneNHURL, scene);
var wallDiffuseTexture = new BABYLON.Texture(brickWallDiffURL, scene);
var wallNormalsHeightTexture = new BABYLON.Texture(brickWallNHURL, scene);
var normalsHeightTexture = stoneNormalsHeightTexture;
var material = new BABYLON.StandardMaterial("mtl01", scene);
material.diffuseTexture = stoneDiffuseTexture;
material.bumpTexture = stoneNormalsHeightTexture;
material.useParallax = true;
material.useParallaxOcclusion = true;
material.parallaxScaleBias = 0.1;
material.specularPower = 1000.0;
material.specularColor = new BABYLON.Color3(0.5, 0.5, 0.5);
mesh.material = material;
return scene;
};
var scene = createScene();
engine.runRenderLoop(function() {
scene.render();
});
</script>
</body>
</html>
Production
La ligne de code ci-dessus générera la sortie suivante -
Dans cette démo, nous avons utilisé des images a1.png, a2.png, pebble.jpg et a3.png. Les images sont stockées localement dans les images / dossier et sont également collées ci-dessous pour référence. Vous pouvez télécharger n'importe quelle image de votre choix et l'utiliser dans le lien de démonstration.