BabylonJS - Fizik Motoru

Babylon.js, sahneye etkileşimler eklemeye yardımcı olan Fizik motoru için eklenti sistemine sahiptir. 2 nesne arasındaki çarpışmayı ve sıçramayı gösterir ve daha çok gerçek hayat etkileşimi gibi yapar Demo, topları birbirleriyle çarpışan ve hareket eden Bilardo gibi oyunlarda, oyuncunun sopayla topa vurduğu ve topların diğer toplarla çarpıştığı oyunlarda aynı davranışı görüyoruz.Burada Fizik Motoru topların gerçekçi bir görüntüsünü vermeye çalışıyor. zemin yüzeyine çarptığında çarpışıyor ve sıçrıyor. Motor, gerekli olduğunda ve ayrıca ağlar diğer ağlarla çarpışırsa belirli eylemleri gerçekleştirmemiz gerektiğinde çağrılacak itme, kuvvet, hız değiştirme, geri arama işlevlerinin uygulanmasına yardımcı olan sınıflara ve API'ye sahiptir.

Kullanılabilecek 3 Fizik eklentisi vardır -

  • Cannon.js
  • Oimo.js
  • Energy.js

Demo

<!doctype html>
<html>
   <head>
      <meta charset = "utf-8">
      <title>BabylonJs - Ball/Ground Demo</title>
      <script type = "text/javascript" src="https://cdn.babylonjs.com/Oimo.js"></script>
      <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 v3 = BABYLON.Vector3;
         
         var createScene = function () {	
            // This creates a basic Babylon Scene object (non-mesh)
            var scene = new BABYLON.Scene(engine);

            var camera = new BABYLON.ArcRotateCamera("Camera", 0.86, 1.37, 250, BABYLON.Vector3.Zero(), scene);
            
            camera.attachControl(canvas);
            camera.maxZ = 5000;
            camera.lowerRadiusLimit = 120;
            camera.upperRadiusLimit = 430;
            camera.lowerBetaLimit =0.75;
            camera.upperBetaLimit =1.58 ;

            new BABYLON.HemisphericLight("hemi", new BABYLON.Vector3(0, 1, 0), scene);

            var randomNumber = function (min, max) {
               if (min == max) {
                  return (min);
               }
               var random = Math.random();
               return ((random * (max - min)) + min);
            };

            var mat = new BABYLON.StandardMaterial("ground", scene);
            var t = new BABYLON.Texture("images/gr1.jpg", scene);
            t.uScale = t.vScale = 10;
            mat.diffuseTexture = t;
            mat.specularColor = BABYLON.Color3.Black();
            
            var g = BABYLON.Mesh.CreateBox("ground", 200, scene);
            
            g.position.y = -20;
            g.position.x = 0
            g.scaling.y = 0.01;
            g.material = mat;	
            
            scene.enablePhysics(new BABYLON.Vector3(0, -10, 0), new BABYLON.OimoJSPlugin());
            
            g.physicsImpostor = new BABYLON.PhysicsImpostor(g, BABYLON.PhysicsImpostor.BoxImpostor, { 
               mass: 0, 
               restitution: 0.9 
            }, scene);
            
            var getPosition = function(y) {
               return new v3(randomNumber(-100, 100), y, randomNumber(-100, 100));
            };
            
            var allspheres = [];
            var y = 50;
            var max = 50;
            
            for (var index = 0; index < max; index++) {
               var redSphere = BABYLON.Mesh.CreateSphere("s" + index, 32, 8, scene);
               redSphere.position = getPosition(y);
               redSphere.physicsImpostor = new BABYLON.PhysicsImpostor(redSphere, BABYLON.PhysicsImpostor.SphereImpostor,{
                  mass: 1, restitution:0.9
               }, scene);
               
               redSphere.physicsImpostor.applyImpulse(new BABYLON.Vector3(1, 2, -1), new BABYLON.Vector3(1, 2, 0));
               
               var redMat = new BABYLON.StandardMaterial("ground", scene);
               redMat.diffuseColor = new BABYLON.Color3(0.4, 0.4, 0.4);
               redMat.specularColor = new BABYLON.Color3(0.4, 0.4, 0.4);
               redMat.emissiveColor = BABYLON.Color3.Red();
               redSphere.material = redMat;
               
               // push all spheres in the allspheres variable
               allspheres.push(redSphere);			
               y += 10; // increment height
            }
            scene.registerBeforeRender(function() {
               allspheres.forEach(function(obj) { 
                  // if the sphers falls down its updated again over here
                  // If object falls
                  if (obj.position.y < -100) {
                     obj.position = getPosition(200);				
                  }
               });
            })
            return scene;
         };
         var scene = createScene();
         engine.runRenderLoop(function() {
            scene.render();
         });
      </script>
   </body>
</html>

Çıktı

Yukarıdaki kod satırı aşağıdaki çıktıyı üretir -

Bu demoda görüntü kullandık images/gr1.jpg. Görüntüler yerel olarak görüntülerde / klasörlerde saklanır ve ayrıca referans için aşağıya yapıştırılır. İstediğiniz herhangi bir görseli indirebilir ve demo bağlantısında kullanabilirsiniz.

images / gr1.jpg

Açıklama

scene.enablePhysics(new BABYLON.Vector3(0,-10,0), new BABYLON.OimoJSPlugin());

Yukarıdaki satır Fizik eklentisini etkinleştirir. Seçtiğiniz eklentiyi kullanabilirsiniz. OimoJsplugin () kullandık.

g.physicsImpostor = newBABYLON.PhysicsImpostor(g, BABYLON.PhysicsImpostor.BoxImpostor, { 
   mass: 0, 
   restitution: 0.9 
}, scene);

Etkileşim için Fizik motoru sahtekar kullanır. Sahtekarlığa uygulandığında, nesnenin şekli değiştirilemez. Değiştirilirse, yeni bir sahtekârın yaratılması gerekecektir.

Küre için, sahtekarlığı ayarlayacağız ve gösterildiği gibi bir sıçrama efekti için ona dürtü ekleyeceğiz -

redSphere.physicsImpostor = new BABYLON.PhysicsImpostor(
   redSphere, BABYLON.PhysicsImpostor.SphereImpostor, { 
      mass: 1, 
      restitution:0.9
   }, scene
);

redSphere.physicsImpostor.applyImpulse(
   new BABYLON.Vector3(1, 2, -1), 
   new BABYLON.Vector3(1, 2, 0)
);

Fizik için parametreler

Fizik efektleri için aşağıdaki parametreleri göz önünde bulundurun -

Nesne

Burada, etkileşimi uygulamak istediğiniz nesne. Örneğin küre, kutu vb.

Tür

Tür aşağıdakilerden biri olabilir -

  • BABYLON.PhysicsImpostor.SphereImpostor;
  • BABYLON.PhysicsImpostor.BoxImpostor;
  • BABYLON.PhysicsImpostor.PlaneImpostor;
  • BABYLON.PhysicsImpostor.MeshImpostor;
  • BABYLON.PhysicsImpostor.CylinderImpostor;
  • BABYLON.PhysicsImpostor.ParticleImpostor;
  • BABYLON.PhysicsImpostor.HeightmapImpostor;

kitle

Zorunlu olan tek parametre, nesnenin kg cinsinden kütlesi olan kütledir. Değer olarak 0, statik bir sahtekar yaratacaktır - zeminler için iyidir.

İade

Bu, çarpışırken vücudun "geri vereceği" kuvvet miktarıdır. Düşük bir değer hemen çıkma yaratmaz ve 1 değeri çok hızlı bir etkileşim olur.

scene.registerBeforeRender(function() {
   allspheres.forEach(function(obj) { 
      // if the sphers falls down its updated again over here
      // If object falls
      if (obj.position.y < -100) {
         obj.position = getPosition(200);
      }					
   });
})

Yukarıdaki kod yere düşen küreleri geri getiriyor. Düşmüş herhangi bir küre için zemini güncellemeye devam ediyor. Fizik etkisini görmek için tarayıcıda yukarıdaki demoyu deneyin.