बेबीलोनजस - सामग्री

सामग्री वस्तुओं के लिए कपड़े की तरह हैं। आप रंग, बनावट जोड़ सकते हैं और इसके साथ अपने मेश को लपेट सकते हैं। आप कई जालों को कवर करने के लिए एक ही सामग्री का उपयोग कर सकते हैं। मेज़ वह दृश्य हो सकता है जिसे हमने अध्याय के लिए पूर्व में उदाहरण में देखा था - आकाश के माध्यम से गुजरने वाला विमान।

इस अध्याय में, हम सीखेंगे कि इस अध्याय में मेषों के लिए रंग, बनावट, प्रतिबिंब कैसे जोड़े।

हम पहले से निर्मित दृश्य में सामग्री जोड़ देंगे। हम अपने द्वारा बनाई गई सभी आकृतियों में सामग्री जोड़कर प्रगति करेंगे।

आइए हम कुछ उदाहरणों पर विचार करें कि यह देखने के लिए कि सामग्री का जोड़ कैसे काम करता है।

वाक्य - विन्यास

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 प्रभाव को नियंत्रित करती है।

इस डेमो में, हमने एक इमेज का उपयोग किया है जिसे इंद्रधनुष कहा जाता है। छवियों को स्थानीय रूप से छवियों / फ़ोल्डर में संग्रहीत किया जाता है। आप अपनी पसंद की किसी भी छवि को डाउनलोड कर सकते हैं और डेमो लिंक में उपयोग कर सकते हैं।