बेबीलोनजस - सामग्री
सामग्री वस्तुओं के लिए कपड़े की तरह हैं। आप रंग, बनावट जोड़ सकते हैं और इसके साथ अपने मेश को लपेट सकते हैं। आप कई जालों को कवर करने के लिए एक ही सामग्री का उपयोग कर सकते हैं। मेज़ वह दृश्य हो सकता है जिसे हमने अध्याय के लिए पूर्व में उदाहरण में देखा था - आकाश के माध्यम से गुजरने वाला विमान।
इस अध्याय में, हम सीखेंगे कि इस अध्याय में मेषों के लिए रंग, बनावट, प्रतिबिंब कैसे जोड़े।
हम पहले से निर्मित दृश्य में सामग्री जोड़ देंगे। हम अपने द्वारा बनाई गई सभी आकृतियों में सामग्री जोड़कर प्रगति करेंगे।
आइए हम कुछ उदाहरणों पर विचार करें कि यह देखने के लिए कि सामग्री का जोड़ कैसे काम करता है।
वाक्य - विन्यास
var materialforshapes = new BABYLON.StandardMaterial("texture1", scene);
उपरोक्त सामग्री कुछ भी नहीं बदलेगी क्योंकि यह डिफ़ॉल्ट है। वस्तुओं को अधिक आकर्षक दिखने के लिए हम उपलब्ध गुणों का उपयोग करेंगे।
उपलब्ध गुण इस प्रकार हैं -
Transparency
Diffuse
Emissive
Ambient
Specular
बैक-फेस कलिंग
WireFrame
एक नज़र डालें कि सामग्री पर लगाए गए इन गुणों को जाल के रूप और अनुभव में कैसे बदलाव आता है।
मूल सामग्री संपत्ति - FresnelParameters
फ्रेस्नेल बाबुलजेएस द्वारा जोड़ी गई नई चीज है standardmaterial। यह आकृतियों पर लागू रंग को बदलने की अनुमति देता है। आप साधारण फ्रेस्नेल का उपयोग करके प्रतिबिंब की तरह ग्लास प्राप्त कर सकते हैं। Fresnel आपको किनारों पर अधिक प्रतिबिंब देगा और सभी केंद्र पर नहीं।
Fresnel के लिए निम्नलिखित गुण उपलब्ध हैं
StandardMaterial.diffuseFresnelParameters
StandardMaterial.opacityFresnelParameters
StandardMaterial.reflectionFresnelParameters
StandardMaterial.emissiveFresnelParameters
StandardMaterial.refractionFresnelParameters
डेमो
<!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>
उत्पादन
कोड की उपरोक्त लाइन निम्नलिखित आउटपुट उत्पन्न करती है -
व्याख्या
निम्नलिखित कोड Fresnel प्रभाव लागू करता है। बाएं और दाएं रंगों को मेश के किनारों पर लागू किया जाता है।
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();
पूर्वाग्रह और बिजली संपत्ति सतह पर Fresnel प्रभाव को नियंत्रित करती है।
इस डेमो में, हमने एक इमेज का उपयोग किया है जिसे इंद्रधनुष कहा जाता है। छवियों को स्थानीय रूप से छवियों / फ़ोल्डर में संग्रहीत किया जाता है। आप अपनी पसंद की किसी भी छवि को डाउनलोड कर सकते हैं और डेमो लिंक में उपयोग कर सकते हैं।