BabylonJS - Memutar Suara dan Musik

Tanpa suara dan musik, permainan tidak akan lengkap. Mesin suara BabylonJS hadir dengan API yang membantu menambahkan efek suara ke game. Ketika ada pertarungan yang terlihat di dalam game, Anda harus menembakkan tembakan, hal yang sama dapat dicapai di sini dengan mesin suara babylonjs. Anda bisa mendapatkan efek suara berdasarkan efek kontrol keyboard / mouse ke game. Mesin suara menawarkan suara ambien, suara khusus, dan suara arah. Mesin mendukung format suara .mp3 dan .wav.

Sintaksis

var music = new BABYLON.Sound(
   "Music", "sound.wav", scene, null, { 
      loop: true, 
      autoplay: true 
   }
);

Parameter

Pertimbangkan parameter berikut yang terkait dengan mesin suara -

  • Name - Nama suaranya.

  • URL - url dari suara yang akan dimainkan.

  • Scene - Adegan dimana suara harus dimainkan.

  • Callbackfunction- Fungsi panggilan balik yang dipanggil saat suara siap dimainkan, saat ini tidak ada. Kami akan membahas beberapa contoh dan mempelajari cara menggunakannya.

  • Json object - Objek ini memiliki detail dasar tentang apa yang perlu dilakukan.

  • sound.autoplay - Dengan ini, suara diputar secara otomatis setelah file diunduh.

  • loop:true - Ini berarti suara akan terus diputar dalam satu lingkaran.

Buat folder suara di direktori proyek Anda dan unduh file audio sampel apa pun untuk menguji hasilnya.

Sekarang mari kita tambahkan suara ke adegan yang telah kita buat.

Demo

<!doctype html>
<html>
   <head>
      <meta charset = "utf-8">
      <title>BabylonJs - Basic Scene- Playing sounds and music</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(0, 1, 0);
            
            var camera = new BABYLON.ArcRotateCamera("Camera", 1, 0.8, 10, new BABYLON.Vector3(0, 0, 0), scene);
            camera.attachControl(canvas, true);
            
            var music = new BABYLON.Sound("sound", "sounds/scooby.wav", scene, null, { 
               loop: true, 
               autoplay: true 
            });	
            return scene;
         };
         var scene = createScene();
         engine.runRenderLoop(function() {
            scene.render();
         });
      </script>
   </body>
</html>

Keluaran

Baris kode di atas menghasilkan output berikut -

Sekarang mari kita periksa bagaimana callbackfungsi bekerja. Jika Anda tidak ingin suara diputar secara otomatis atau Anda ingin memutar suara hanya saat diinginkan, Anda dapat melakukannya dengan fungsi panggilan balik.

Sebagai contoh,

Var music = new BABYLON.Sound ("Music", "music.wav", scene, function callback() {music.play();});

Demo

<!doctype html>
<html>
   <head>
      <meta charset = "utf-8">
      <title>BabylonJs - Basic Scene- Playing sounds and music</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(0, 1, 0);
            
            var camera = new BABYLON.ArcRotateCamera("Camera", 1, 0.8, 10, new BABYLON.Vector3(0, 0, 0), scene);
            camera.attachControl(canvas, true)
            
            var music = new BABYLON.Sound(
               "sound", "sounds/scooby.wav", scene, function callback() { setTimeout(function() {music.play();}, 5000)});	
            return scene;
         };
         var scene = createScene();
         engine.runRenderLoop(function() {
            scene.render();
         });
      </script>
   </body>
</html>

Dalam callback, kami akan menggunakan setTimeout. Artinya, kami ingin suara hanya dimainkan setelah waktu tertentu. Kami telah menambahkan 5 detik sebagai pengatur waktu, sehingga suara akan diputar saat file Scooby.wav diunduh dan 5 detik selesai.

Mainkan suara dengan klik dan tombol pada keyboard

Setelah mengklik di mana saja di tempat kejadian, Anda akan mendengar efek suara ledakan dan jika Anda menekan salah satu tombol panah -kiri, kanan, atas atau bawah, itu akan memainkan efek suara ledakan.

Untuk klik, kami melampirkan acara tersebut onmousedownke jendela dan untuk kunci, kami akan menggunakan acara keydown. Berdasarkan kode kunci, suara dimainkan.

Demo

<!doctype html>
<html>
   <head>
      <meta charset = "utf-8">
      <title>BabylonJs - Basic Scene- Playing sounds and music</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(0, 1, 0);
            
            var camera = new BABYLON.ArcRotateCamera("Camera", 1, 0.8, 10, new BABYLON.Vector3(0, 0, 0), scene);
            camera.attachControl(canvas, true)
            
            var sound = new BABYLON.Sound("gunshot", "sounds/explosion.wav", scene);

            window.addEventListener("mousedown", function (evt) {	
               if (evt.button === 0) { // onclick
                  sound.play();
               }
            });

            window.addEventListener("keydown", function (evt) { // arrow key left right up down
               if (evt.keyCode === 37 || evt.keyCode === 38 || evt.keyCode === 39 || evt.keyCode === 40) {
                  sound.play();
               }
            });		
            return scene;
         };
         var scene = createScene();
         engine.runRenderLoop(function() {
            scene.render();
         });
      </script>
   </body>
</html>

Keluaran

Baris kode di atas akan menghasilkan output berikut -

Anda dapat mengontrol volume suara di objek json, yang kami temui di awal.

Sebagai contoh,

Var music = new BABYLON.Sound("sound", "sounds/scooby.wav", scene, null, { 
   loop: true, 
   autoplay: true, 
   volume:0.5 
});

Untuk mengetahui kapan file suara selesai, ada event yang bisa digunakan sebagai berikut -

music.onended = function () {	
   console.log("sound ended");
   
   //you can do the required stuff here like play it again or play some other sound etc.
};

Properti SetVolume juga tersedia jika Anda ingin mengontrol suara selain konstruktor.

Sebagai contoh,

music.setVolume(volume);

Jika Anda memainkan lebih dari satu suara dalam adegan Anda, Anda dapat menyetel suara global untuk semua suara yang dibuat.

Sebagai contoh,

BABYLON.Engine.audioEngine.setGlobalVolume(0.5);

Membuat Suara Spasial 3D

Jika Anda ingin mengubah suara menjadi suara spasial (suara yang mirip dengan suara ruang), Anda perlu menambahkan opsi ke konstruktor suara Anda.

Sebagai contoh,

var music = new BABYLON.Sound("music", "sounds/explosion.wav", scene, null, { 
   loop: false, 
   autoplay: true, 
   spatialSound: true 
});

Berikut adalah opsi berbeda untuk suara spasial -

  • DistanceModel- Ini menggunakan persamaan "linier" secara default. Pilihan lainnya adalah “invers” atau “exponential”.

  • MaxDistance - Ini disetel ke 100. Ini berarti bahwa setelah pendengar berjarak lebih dari 100 unit dari suara, volumenya akan menjadi 0. Anda tidak dapat mendengar suara itu lagi

  • PanningModel- Ini diatur ke "HRTF". Spesifikasi mengatakan itu adalah algoritma spasialisasi kualitas lebih tinggi menggunakan konvolusi dengan respon impuls terukur dari subjek manusia. Ini mengacu pada keluaran stereo.

  • MaxDistance - Ini digunakan hanya jika distanceModel linier. Ini tidak digunakan dengan invers atau eksponensial.

Demo dengan suara spasial

<!doctype html>
<html>
   <head>
      <meta charset = "utf-8">
      <title>BabylonJs - Basic Scene- Playing sounds and music</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(0, 1, 0);
            
            var camera = new BABYLON.ArcRotateCamera("Camera", 1, 0.8, 10, new BABYLON.Vector3(0, 0, 0), scene);
            camera.attachControl(canvas, true);	
            
            var music = new BABYLON.Sound(
               "music", "sounds/explosion.wav", scene, null, {
                  loop: false, autoplay: true, spatialSound: true, distanceModel: "exponential"
               }
            );
            return scene;
         };
         var scene = createScene();
         engine.runRenderLoop(function() {
            scene.render();
         });
      </script>
   </body>
</html>

Memasang suara ke mesh

Menggunakan BABYLON.Sound, Anda dapat memasang suara ke mesh Anda. Jika jala bergerak, suara akan ikut bergerak.AttachtoMesh (mesh) adalah metode yang akan digunakan.

Demo

<!doctype html>
<html>
   <head>
      <meta charset = "utf-8">
      <title>BabylonJs - Basic Scene- Playing sounds and music</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(0, 1, 0);

            var camera = new BABYLON.ArcRotateCamera("Camera", 1, 0.8, 10, new BABYLON.Vector3(0, 0, 0), scene);
            camera.attachControl(canvas, true);

            var materialforbox = new BABYLON.StandardMaterial("texture1", scene);
            var box = BABYLON.Mesh.CreateBox("box", '2', scene);	
            box.material  = materialforbox;
            materialforbox.ambientColor = new BABYLON.Color3(1, 0, 0.2);

            var music = new BABYLON.Sound("music", "sounds/explosion.wav", scene, null, { 
               loop: false, 
               autoplay: true, 
               spatialSound: true, 
               distanceModel: "exponential"
            });	
            music.attachToMesh(box);
            return scene;
         };
         var scene = createScene();
         engine.runRenderLoop(function() {
            scene.render();
         });
      </script>
   </body>
</html>

Keluaran

Baris kode di atas menghasilkan output berikut -