बेबीलोनजेएस - स्टैंडर्ड रेंडरिंग पाइपलाइन
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 फ़ाइलों को यहाँ पेस्ट करना मुश्किल है क्योंकि इसका आकार बहुत बड़ा है।