बेबीलोनजेएस - लेंस फ्लेयर्स

जब प्रकाश बिखरा होता है और छवि पर गिरता है, तो आपको एक अलग छवि देखने के रूप में देखने को मिलती है और रंग भी बदल जाता है। जब आप प्रकाश प्रभाव की यथार्थवादी घटना दिखाने के लिए एक गेम विकसित करते हैं, तो लेंस फ्लेयर का उपयोग किया जाता है। दर्पण पर पड़ने वाली सूर्य की किरणों पर विचार करें और इसके प्रभाव को ज्यादातर लेंस फ्लेयर कहा जाता है।

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

लेंस फ्लेयर बनाने के लिए सिंटैक्स निम्नलिखित है -

var lensFlareSystem = new BABYLON.LensFlareSystem("lensFlareSystem", light0, scene);

पैरामीटर

लेंस भड़काने के लिए निम्नलिखित मापदंडों पर विचार करें -

  • Name - लेंसफ्लेरेसिस्टम को दिया गया नाम।

  • Light - यह प्रकाश स्रोत या कैमरा हो सकता है।

  • Scene - दृश्य जिससे लेंस भड़क जाएगा।

दृश्य में फ्लेयर्स जोड़ने के लिए, निम्न कमांड निष्पादित करें -

var flare1 = new BABYLON.LensFlare(0.5, 0.15, new BABYLON.Color3(1, 1, 1), "images/sun1.png", lensFlareSystem);
  • Size - 0 और 1 के बीच फ्लोटिंग मूल्य।

  • Position - लेंस का स्रोत (उत्सर्जक) भड़कता है (यह एक कैमरा, एक प्रकाश या एक जाल हो सकता है)।

  • Lensflaresystem - लेंसफ्लरेसिस्टम क्लास का उपयोग करके बनाई गई वस्तु।

डेमो

<!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);
            scene.clearColor = BABYLON.Color3.Gray();
            var camera = new BABYLON.ArcRotateCamera(
               "Camera", -Math.PI / 2, 1.5, 15, BABYLON.Vector3.Zero(), scene);
            camera.attachControl(canvas, false);

            var light1 = new BABYLON.HemisphericLight("light1", new BABYLON.Vector3(0, -1, 0), scene);
            light1.groundColor = new BABYLON.Color3(0.2, 0.2, 0.2);
            light1.intensity = 0.5;
            
            var bigdiamond = BABYLON.Mesh.CreateSphere("sphere", 32,6, scene);
            bigdiamond.visibility = 0.6;
            var dmat = new BABYLON.StandardMaterial("dmat", scene);
            dmat.diffuseColor = BABYLON.Color3.Blue();
            
            var texture = new BABYLON.Texture("images/earth.jpg", scene);
            dmat.diffuseTexture = texture;		
            dmat.specularColor = BABYLON.Color3.White();
            bigdiamond.material = dmat;

            var lensflare1 = new BABYLON.LensFlareSystem("lensFlareSystem", camera, scene);
            var flare1 = new BABYLON.LensFlare(
               Math.random(), 0.15, new BABYLON.Color3(1, 1, 1), "images/sun1.png", lensflare1);

            var lensflare2 = new BABYLON.LensFlareSystem("lensFlareSystem", camera, scene);
            var flare2 = new BABYLON.LensFlare(
               Math.random()/2, 0.1, new BABYLON.Color3(1, 0, 0), "images/sun1.png", lensflare2);

            var lensflare3 = new BABYLON.LensFlareSystem("lensFlareSystem", camera, scene);
            var flare3 = new BABYLON.LensFlare(
               Math.random()/8, 0.1, new BABYLON.Color3(1, 0, 1), "images/sun1.png", lensflare3);

            var lensflare4 = new BABYLON.LensFlareSystem("lensFlareSystem", camera, scene);
            var flare4 = new BABYLON.LensFlare(
               Math.random()/12, 0.1, new BABYLON.Color3(0, 1, 0), "images/sun1.png", lensflare4);

            scene.registerBeforeRender(function() {
               scene.getCameraByID("Camera").alpha += 0.01;
            });		
            return scene;
         };
         var scene = createScene();
         engine.runRenderLoop(function() {
            scene.render();
         });
      </script>
   </body>
</html>

उत्पादन

कोड की उपरोक्त लाइन निम्नलिखित आउटपुट उत्पन्न करती है -

earth.jpg

छवियों / sun1.png