बेबीलोनजस - दशमलव

Decals पसंद हैं स्टिकर anobject पर चिपकाया जाता है। स्टिकर ड्राइंग 2d छवि की मदद से किया जाता है जो मेष पर खींचा जाता है (उदाहरण के लिए, खेल में ऑब्जेक्ट)। खेलों में, विचार करें कि आपके पास एक सेना की गोलियां हैं, गोली की छाप वस्तु पर देखी जानी चाहिए। तो बेबीलोन में, यह decals का उपयोग करके किया जाता है जिसमें, जब आप किसी भी ऑब्जेक्ट पर क्लिक करते हैं तो आप उस जगह पर 2 डी छवि खींचेंगे जहां आपने इसे क्लिक किया था।

निर्मित जाल पर विवरण जोड़ने के लिए Decals का उपयोग किया जाता है - गोलियों, छेद, आदि जैसे विवरण नीचे दिए गए डेमो लिंक में, हम एक छवि का उपयोग कर रहे हैं और आयातित मेष में समान जोड़ रहे हैं।

Decal जोड़ने के लिए, आप निम्नलिखित कोड का उपयोग कर सकते हैं -

var newDecal = BABYLON.Mesh.CreateDecal("decal", mesh, decalPosition, normal, decalSize, angle);

निम्नलिखित कोड को मेष पर decals जोड़ने के लिए निष्पादित किया जाता है -

BABYLON.SceneLoader.ImportMesh("Shcroendiger'scat", "scenes/", "SSAOcat.babylon", scene, function (newMeshes) {
   var cat = newMeshes[0]; / /this is mesh shown on the screen.

   // Set the target of the camera to the first imported mesh
   camera.target = cat;

   var decalMaterial = new BABYLON.StandardMaterial("decalMat", scene);
   decalMaterial.diffuseTexture = new BABYLON.Texture("images/impact1.jpg", scene);
   decalMaterial.diffuseTexture.hasAlpha = true;
   decalMaterial.zOffset = -2;

   var onPointerDown = function (evt) {
      if (evt.button !== 0) {
         return;
      }

      // check if we are under a mesh
      var pickInfo = scene.pick(scene.pointerX, scene.pointerY, function (mesh) { return mesh === cat; 
      // this will give all the meshes , but it will pick the mesh whch is same as cat and return true if it is found });
      if (pickInfo.hit) { // if true
         var decalSize = new BABYLON.Vector3(5, 5, 5); //size of decal is defined

         var newDecal = BABYLON.Mesh.CreateDecal("decal", cat, pickInfo.pickedPoint, pickInfo.getNormal(true), decalSize); //decal is created 
         newDecal.material = decalMaterial; //decal material is added.
      }
   }
   var canvas = engine.getRenderingCanvas();
   canvas.addEventListener("pointerdown", onPointerDown, false);

   scene.onDispose = function () {
      canvas.removeEventListener("pointerdown", onPointerDown);
   }
});

डेमो

<!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);

            //Adding a light
            var light = new BABYLON.HemisphericLight("Hemi", new BABYLON.Vector3(0, 1, 0), scene);

            //Adding an Arc Rotate Camera
            var camera = new BABYLON.ArcRotateCamera("Camera", -1.85, 1.2, 200, BABYLON.Vector3.Zero(), scene);

            camera.attachControl(canvas, true);

            // The first parameter can be used to specify which mesh to import. Here we import all meshes
            BABYLON.SceneLoader.ImportMesh("Shcroendiger'scat", "scenes/", "SSAOcat.babylon", scene, function (newMeshes) {
               var cat = newMeshes[0];

               // Set the target of the camera to the first imported mesh
               camera.target = cat;

               var decalMaterial = new BABYLON.StandardMaterial("decalMat", scene);
               decalMaterial.diffuseTexture = new BABYLON.Texture("images/impact1.jpg", scene);
               decalMaterial.diffuseTexture.hasAlpha = true;
               decalMaterial.zOffset = -2;

               var onPointerDown = function (evt) {
                  if (evt.button !== 0) {
                     return;
                  }

                  // check if we are under a mesh
                  var pickInfo = scene.pick(scene.pointerX, scene.pointerY, function (mesh) { return mesh === cat; });
                  if (pickInfo.hit) {
                     var decalSize = new BABYLON.Vector3(5, 5, 5);

                     var newDecal = BABYLON.Mesh.CreateDecal("decal", cat, pickInfo.pickedPoint, pickInfo.getNormal(true), decalSize);
                     newDecal.material = decalMaterial;
                  }
               }
               var canvas = engine.getRenderingCanvas();
               canvas.addEventListener("pointerdown", onPointerDown, false);

               scene.onDispose = function () {
                  canvas.removeEventListener("pointerdown", onPointerDown);
               }
            });	
            return scene;
         };
         var scene = createScene();
         engine.runRenderLoop(function() {
            scene.render();
         });
      </script>
   </body>
</html>

उपरोक्त डेमो लिंक में, हमने SSAOcat.babylon जाल का उपयोग किया है। आप यहाँ से SSAOcat.babylon के लिए json फ़ाइल डाउनलोड कर सकते हैं -

SSAOcat.babylon

फ़ाइल को दृश्यों / फ़ोल्डर में सहेजें। यह आपको नीचे दिखाए गए अनुसार आउटपुट प्राप्त करने में मदद करेगा।

उत्पादन

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

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

images/impact1.jpg