बेबीलोनजेएस - स्टैंडर्ड रेंडरिंग पाइपलाइन

StandardRenderingPipeline पोस्टप्रोसेस प्रभाव के एक सेट के साथ आता है जो वास्तविक दुनिया से संबंधित है। प्रकाश प्रभाव और रोशनी प्रभाव जैसे विभिन्न पोस्ट प्रक्रिया प्रभाव हैं।

नीचे दिए गए उदाहरण में, आप विभिन्न प्रभाव देखेंगे जैसे लेंस प्रभाव, रोशनी की पोस्ट प्रक्रिया प्रभाव आदि।

इसमें एचडीआर क्यूब टेक्सचर का इस्तेमाल किया गया है और टेक्सचर का होना जरूरी है। यह बनावट एक panromic प्रभाव देती है जिसे कैमरे को घुमाते समय देखा जा सकता है।

var hdrTexture = new BABYLON.HDRCubeTexture("images/GravelPlaza_REF.hdr", scene, 512);

कोड की निम्नलिखित पंक्ति के साथ प्रभाव प्राप्त करने के लिए मानक रेंडरिंग पाइपलाइन क्लास को कहा जाता है -

// Create rendering pipeline
var pipeline = new BABYLON.StandardRenderingPipeline("standard", scene, 1.0 / devicePixelRatio, null, [camera]);
pipeline.lensTexture = new BABYLON.Texture("images/lensdirt.jpg", scene)

नीचे दिखाए गए डेमो में, हम क्यूबटेक्स्चर वातावरण बनाएंगे। हम उसी के लिए ग्राउंड मेश का उपयोग करेंगे और पूरे दृश्य के लिए मानक रेंडरिंग पाइप लाइन लगाएंगे।

लैंसटैक्सचर का उपयोग करके इसे बनावट दी गई है जो एक छवि है और आप दृश्य को स्थानांतरित करते हुए उसी बनावट को देख सकते हैं।

डेमो

<!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("Camera", -Math.PI / 4, Math.PI / 2.5, 200, BABYLON.Vector3.Zero(), scene);
            camera.attachControl(canvas, true);
            camera.minZ = 0.1;

            // Light
            new BABYLON.PointLight("point", new BABYLON.Vector3(0, 40, 0), scene);

            // Environment Texture
            var hdrTexture = new BABYLON.HDRCubeTexture("images/GravelPlaza_REF.hdr", scene, 512);

            // Skybox
            var hdrSkybox = BABYLON.Mesh.CreateBox("hdrSkyBox", 1000.0, scene);
            var hdrSkyboxMaterial = new BABYLON.PBRMaterial("skyBox", scene);
            hdrSkyboxMaterial.backFaceCulling = false;
            hdrSkyboxMaterial.reflectionTexture = hdrTexture.clone();
            hdrSkyboxMaterial.reflectionTexture.coordinatesMode = BABYLON.Texture.SKYBOX_MODE;
            hdrSkyboxMaterial.microSurface = 1.0;
            hdrSkyboxMaterial.cameraExposure = 0.6;
            hdrSkyboxMaterial.cameraContrast = 1.6;
            hdrSkyboxMaterial.disableLighting = true;
            hdrSkybox.material = hdrSkyboxMaterial;
            hdrSkybox.infiniteDistance = true;

            // Create mesh
            var woodbox = BABYLON.MeshBuilder.CreateBox("plane", { 
               width: 40, 
               height: 50, 
               depth: 65 
            }, scene);

            var wood = new BABYLON.PBRMaterial("wood", scene);
            wood.reflectionTexture = hdrTexture;
            wood.directIntensity = 1.5;
            wood.environmentIntensity = 0.5;
            wood.specularIntensity = 0.3;
            wood.cameraExposure = 0.9;
            wood.cameraContrast = 1.6;

            wood.reflectivityTexture = new BABYLON.Texture("images/reflectivity.png", scene);
            wood.useMicroSurfaceFromReflectivityMapAlpha = true;

            wood.albedoColor = BABYLON.Color3.White();
            wood.albedoTexture = new BABYLON.Texture("images/albedo.png", scene);
            woodbox.material = wood;

            // Create rendering pipeline
            var pipeline = new BABYLON.StandardRenderingPipeline("standard", scene, 1.0 / devicePixelRatio, null, [camera]);
            pipeline.lensTexture = new BABYLON.Texture("images/lensdirt.jpg", scene);

            // Return scene
            return scene;
         };
         var scene = createScene();
         engine.runRenderLoop(function() {
            scene.render();
         });
      </script>
   </body>
</html>

इमेज फोल्डर बनाएं और उसमें .hdr फाइल को स्टोर करें। हम से छवियों / GravelPlaza_REF.hdr का इस्तेमाल किया है www.hdrlabs.com ।

आप अपनी पसंद की .hdr प्रकार की फाइलों को डाउन लोड कर सकते हैं और डेमो लिंक में उपयोग कर सकते हैं।

उत्पादन

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

इस डेमो में, हमने छवियों का उपयोग किया है images/GravelPlaza_REF.hdr, images/reflectivity.png, images/albedo.png, images/lensdirt.jpg। छवियों को स्थानीय रूप से छवियों / फ़ोल्डर में संग्रहीत किया जाता है और संदर्भ के लिए नीचे भी चिपकाया जाता है। आप अपनी पसंद की किसी भी छवि को डाउनलोड कर सकते हैं और डेमो लिंक में उपयोग कर सकते हैं। कृपया ध्यान दें कि .hdr फ़ाइलों को यहाँ पेस्ट करना मुश्किल है क्योंकि इसका आकार बहुत बड़ा है।

छवियाँ / reflectivity.png

छवियाँ / albedo.png

छवियाँ / lensdirt.png