बेबीलोनजस - रोशनी
इस अध्याय में, हम बाबुलजेएस के लिए उपयोग की जाने वाली रोशनी के बारे में जानेंगे। हम बेबीलोन के साथ उपलब्ध विभिन्न प्रकार की रोशनी पर एक नज़र डालकर शुरू करेंगे।
रोशनी प्रत्येक पिक्सेल द्वारा प्राप्त डिफ्यूज़ और स्पेक्युलर रंग का उत्पादन करने के लिए होती है। बाद में, इसका उपयोग प्रत्येक पिक्सेल के अंतिम रंग को प्राप्त करने के लिए सामग्री पर किया जाता है।
बेबीलोन के साथ 4 प्रकार की लाइटें उपलब्ध हैं।
- बिंदु प्रकाश
- दिशात्मक प्रकाश
- स्पॉट लाइट
- हेमिस्फेरिक लाइट
बेबीलोनजेएस - प्वाइंट लाइट
बिंदु प्रकाश का एक उत्कृष्ट उदाहरण सूर्य है, जिसकी किरणें सभी दिशाओं में फैली हुई हैं। बिंदु प्रकाश का अंतरिक्ष में एक अनूठा बिंदु है जहां से यह हर दिशा में प्रकाश फैलाता है। प्रकाश के रंग को स्पेक्युलर और फैलाना संपत्ति का उपयोग करके नियंत्रित किया जा सकता है।
वाक्य - विन्यास
प्वाइंट लाइट के लिए वाक्य रचना निम्नलिखित है -
var light0 = new BABYLON.PointLight("Omni0", new BABYLON.Vector3(1, 10, 1), scene);
बिंदु प्रकाश के लिए तीन अलग-अलग पारम हैं -
1 परम प्रकाश का नाम है।
दूसरा परम स्थान वह स्थिति है जहाँ बिंदु प्रकाश को रखा जाता है।
तीसरा पे्रम वह दृश्य है, जिसमें प्रकाश को संलग्न करने की आवश्यकता होती है।
ऊपर बनाई गई वस्तु पर रंग जोड़ने के लिए निम्नलिखित गुणों का उपयोग किया जाता है -
light0.diffuse = new BABYLON.Color3(1, 0, 0);
light0.specular = new BABYLON.Color3(1, 1, 1);
डेमो
<!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 = new BABYLON.Color3( .5, .5, .5);
var camera = new BABYLON.ArcRotateCamera("camera1", 0, 0, 0, new BABYLON.Vector3(0, 0, -0), scene);
camera.setPosition(new BABYLON.Vector3(0, 0, -100));
camera.attachControl(canvas, true);
var pl = new BABYLON.PointLight("pl", new BABYLON.Vector3(1, 20, 1), scene);
pl.diffuse = new BABYLON.Color3(0, 1, 0);
pl.specular = new BABYLON.Color3(1, 0, 0);
var ground = BABYLON.Mesh.CreateGround("ground", 150, 6, 2, scene);
return scene;
};
var scene = createScene();
engine.runRenderLoop(function() {
scene.render();
});
</script>
</body>
</html>
उत्पादन
बेबीलोनजेएस - दिशात्मक प्रकाश
दिशात्मक प्रकाश में, प्रकाश को दिशा द्वारा परिभाषित किया जाता है और हर दिशा में उत्सर्जित किया जाता है जहां आप इसे रखते हैं।
var light0 = new BABYLON.DirectionalLight("Dir0", new BABYLON.Vector3(0, -1, 0), scene);
बिंदु प्रकाश के लिए तीन अलग-अलग पारम हैं -
1 सेंट परम प्रकाश का नाम है।
2 एन डी परम की स्थिति है। अभी, यह वाई अक्ष में नकारात्मक -1 के साथ विस्थापित है।
3 rd परम संलग्न करने के लिए दृश्य है।
यहां, आप स्पेक्युलर के साथ रंग जोड़ सकते हैं और संपत्ति को फैला सकते हैं।
light0.diffuse = new BABYLON.Color3(0, 1, 0);
light0.specular = new BABYLON.Color3(1,0, 0);
डेमो
<!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 = new BABYLON.Color3( .5, .5, .5);
var camera = new BABYLON.ArcRotateCamera("camera1", 0, 0, 0, new BABYLON.Vector3(0, 0, -0), scene);
camera.setPosition(new BABYLON.Vector3(0, 0, -100));
camera.attachControl(canvas, true);
var pl = new BABYLON.DirectionalLight("Dir0", new BABYLON.Vector3(0, -10, 0), scene);
pl.diffuse = new BABYLON.Color3(0, 1, 0);
pl.specular = new BABYLON.Color3(1, 0, 0);
var ground = BABYLON.Mesh.CreateGround("ground", 150, 6, 2, scene);
return scene;
};
var scene = createScene();
engine.runRenderLoop(function() {
scene.render();
});
</script>
</body>
</html>
उत्पादन
कोड की उपरोक्त लाइन निम्नलिखित आउटपुट उत्पन्न करती है -
बेबीलोनजेएस - द स्पॉट लाइट
स्पॉट लाइट ठीक वैसे ही है जैसे शंकु आकार में गिरने वाली रोशनी।
वाक्य - विन्यास
स्पॉट लाइट के लिए वाक्य रचना निम्नलिखित है -
var light0 = new BABYLON.SpotLight("Spot0", new BABYLON.Vector3(0, 30, -10), new BABYLON.Vector3(0, -1, 0), 0.8, 2, scene);
बिंदु प्रकाश के लिए पांच अलग-अलग परिम हैं -
- 1 सेंट परम प्रकाश का नाम है।
- 2 एन डी परम की स्थिति है।
- 3 आरडी परम दिशा है।
- 4 वें परम कोण है।
- 5 वें परम का प्रतिपादक है।
ये मान स्थिति से शुरू होने वाले प्रकाश के शंकु को परिभाषित करते हैं, जो दिशा की ओर निकलते हैं। प्रकाश के रंग को नियंत्रित करने के लिए स्पेक्युलर और डिफ्यूज़ का उपयोग किया जाता है।
light0.diffuse = new BABYLON.Color3(1, 0, 0);
light0.specular = new BABYLON.Color3(1, 1, 1);
डेमो
<!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 = new BABYLON.Color3( .5, .5, .5);
var camera = new BABYLON.ArcRotateCamera("camera1", 0, 0, 0, new BABYLON.Vector3(0, 0, -0), scene);
camera.setPosition(new BABYLON.Vector3(0, 0, -100));
camera.attachControl(canvas, true);
var light0 = new BABYLON.SpotLight("Spot0", new BABYLON.Vector3(0, 30, -10), new BABYLON.Vector3(0, -1, 0), 0.8, 2, scene);
light0.diffuse = new BABYLON.Color3(0, 1, 0);
light0.specular = new BABYLON.Color3(1, 0, 0);
var ground = BABYLON.Mesh.CreateGround("ground", 80,80, 2, scene);
return scene;
};
var scene = createScene();
engine.runRenderLoop(function() {
scene.render();
});
</script>
</body>
</html>
उत्पादन
कोड की उपरोक्त लाइन निम्नलिखित आउटपुट उत्पन्न करती है -
बेबीलोनजस - द हेमीस्फियरिक लाइट
एक गोलार्ध प्रकाश पर्यावरण प्रकाश प्राप्त करने का अधिक है। प्रकाश की दिशा आकाश की ओर है। 3 रंग प्रकाश को दिए जाते हैं; एक आकाश के लिए, एक जमीन के लिए और अंतिम एक सट्टेबाज के लिए।
वाक्य - विन्यास
निम्नलिखित गोलार्ध प्रकाश के लिए सिंटैक्स है -
var light0 = new BABYLON.HemisphericLight("Hemi0", new BABYLON.Vector3(0, 1, 0), scene);
रंगों के लिए
light0.diffuse = new BABYLON.Color3(1, 0, 0);
light0.specular = new BABYLON.Color3(0, 1, 0);
light0.groundColor = new BABYLON.Color3(0, 0, 0);
डेमो
<!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 = new BABYLON.Color3( .5, .5, .5);
var camera = new BABYLON.ArcRotateCamera("camera1", 0, 0, 0, new BABYLON.Vector3(0, 0, -0), scene);
camera.setPosition(new BABYLON.Vector3(0, 0, -100));
camera.attachControl(canvas, true);
var light0 = new BABYLON.HemisphericLight("Hemi0", new BABYLON.Vector3(0, 1, 0), scene);
light0.diffuse = new BABYLON.Color3(1, 0, 0);
light0.specular = new BABYLON.Color3(0, 1, 0);
light0.groundColor = new BABYLON.Color3(0, 0, 0);
var ground = BABYLON.Mesh.CreateGround("ground", 100,100, 2, scene);
return scene;
};
var scene = createScene();
engine.runRenderLoop(function() {
scene.render();
});
</script>
</body>
</html>
उत्पादन
कोड की उपरोक्त लाइन निम्नलिखित आउटपुट उत्पन्न करती है -