बेबीलोनजस - शेमरमेट

Shader सामग्री आपको आउटपुट के रूप में एक सामग्री देती है। आप इस सामग्री को किसी भी जाल पर लागू कर सकते हैं। यह मूल रूप से आपके दृश्य से डेटा को वर्टेक्स और फ्रेग्मेंट शेड्स में पास करता है।

Shader सामग्री प्राप्त करने के लिए, निम्न वर्ग को कहा जाता है -

var myShaderMaterial = new BABYLON.ShaderMaterial(name, scene, route, options);

मापदंडों

Shader सामग्री से संबंधित निम्नलिखित मापदंडों पर विचार करें -

  • Name - स्ट्रिंग, नामकरण एक स्ट्रिंग।

  • Scene - वह दृश्य जिसमें शैडर का उपयोग किया जाना है।

  • Route - तीन तरीकों में से एक में shader कोड का मार्ग -

object - {
   vertex: "custom", 
   fragment: "custom" 
}, used with 
BABYLON.Effect.ShadersStore["customVertexShader"] and
BABYLON.Effect.ShadersStore["customFragmentShader"]
object - { 
   vertexElement: "vertexShaderCode", 
   fragmentElement: "fragmentShaderCode" 
}, 
used with shader code in <script> tags
string - "./COMMON_NAME",

अंत में उल्लिखित वाक्यविन्यास का उपयोग बाहरी फ़ाइलों COMMON_NAME.vertex.fx और COMMON_NAME.fragment.fx के साथ index.html फ़ोल्डर में किया जाता है।

  • Options - एट्रिब्यूट्स वाली एट्रिब्यूट्स और यूनिफॉर्म सरणियाँ जिनके नाम तार के रूप में हैं

मूल्यों के साथ shader सिंटैक्स नीचे दिखाया गया है -

var shaderMaterial = new BABYLON.ShaderMaterial("shader", scene, {
   vertex: "custom",
   fragment: "custom",
},
{
   attributes: ["position", "normal", "uv"],
   uniforms: ["world", "worldView", "worldViewProjection", "view", "projection"]
});

विशेषताएँ सरणी रूप में होनी चाहिए। इनमें स्थिति, सामान्य और यूवी होते हैं जो वेक्टर 3 डी फ्लोटिंग पॉइंट वैक्टर हैं।

  • vec2 - फ्लोटिंग-पॉइंट संख्याओं का द्वि-आयामी वेक्टर।

  • vec3 - फ्लोटिंग-पॉइंट संख्याओं का त्रि-आयामी वेक्टर।

  • mat4 - 4 कॉलम और 4 पंक्तियों वाली एक मैट्रिक्स फ़्लोटिंग पॉइंट संख्या।

  • gl_Position - यह स्क्रीन निर्देशांक के लिए स्थितीय डेटा प्रदान करता है।

  • gl_FragColor - यह स्क्रीन पर एक पहलू के प्रतिनिधित्व के लिए रंग डेटा प्रदान करता है।

ऊपर GLSL भाषा में चर में बनाया गया है।

चूंकि शीर्ष पदों को यथासंभव सटीक होना चाहिए, सभी फ्लोटिंग-पॉइंट संख्याओं को उच्च परिशुद्धता वाले सेट किया जाना चाहिए। यह प्रयोग करने वाले प्रत्येक shader के लिए कोड की शुरुआत में किया जाता है -precision highp float। सटीक हाईप फ्लोट यह निर्धारित करता है कि फ्लोट के लिए कितनी सटीकता का उपयोग किया जाता है।

निम्नलिखित डेमो पहली वस्तु विधि पर आधारित है।

डेमो

<!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">
         //downloaded HDR files from :http://www.hdrlabs.com/sibl/archive.html
         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 / 4, 4, BABYLON.Vector3.Zero(), scene);

            camera.attachControl(canvas, true);

            var light = new BABYLON.HemisphericLight("light1", new BABYLON.Vector3(0, 1, 0), scene);

            BABYLON.Effect.ShadersStore["customVertexShader"] = "\r\n" + 
               "precision highp float;\r\n" + 
               "// Attributes\r\n" + 
               "attribute vec3 position;\r\n" + 
               "attribute vec2 uv;\r\n" + 
               "// Uniforms\r\n" + 
               "uniform mat4 worldViewProjection;\r\n" + 

               "// Varying\r\n" + 
               "varying vec2 vUV;\r\n" + 
               "void main(void) {
                  \r\n" + 
                  "gl_Position = worldViewProjection * vec4(position, 1.0);\r\n" + 
                  "vUV = uv;\r\n"+"
               }
               \r\n";
               BABYLON.Effect.ShadersStore["customFragmentShader"] = "\r\n"+
                  "precision highp float;\r\n" + 
                  "varying vec2 vUV;\r\n" + 
                  "uniform sampler2D textureSampler;\r\n" + 
               "void main(void) {
                  \r\n"+
                  "gl_FragColor = texture2D(textureSampler, vUV);\r\n"+"
               }
               \r\n";

            var shaderMaterial = new BABYLON.ShaderMaterial("shader", scene, {
               vertex: "custom",
               fragment: "custom",
            },
            
            {
               attributes: ["position", "normal", "uv"],
               uniforms: ["world", "worldView", "worldViewProjection", "view", "projection"]
            });

            var mainTexture = new BABYLON.Texture("images/mat.jpg", scene);

            shaderMaterial.setTexture("textureSampler", mainTexture);

            shaderMaterial.backFaceCulling = false;

            var box = BABYLON.MeshBuilder.CreateBox("box", {}, scene);
            box.material = shaderMaterial;
            return scene;
         };
         var scene = createScene();
         engine.runRenderLoop(function() {
            scene.render();
         });
      </script>
   </body>
</html>

उत्पादन

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

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

छवियाँ / mat.jpg