Ionic - Cordova Native Audio

Ce plugin est utilisé pour ajouter des sons audio natifs à l'application Ionic.

Utilisation de l'audio natif

Pour pouvoir utiliser ce plugin, nous devons d'abord l'installer. Ouvrez la fenêtre d'invite de commande et ajoutez le plugin Cordova.

C:\Users\Username\Desktop\MyApp>cordova plugin add cordova-plugin-nativeaudio

Avant de commencer à utiliser ce plugin, nous aurons besoin d'un fichier audio. Pour plus de simplicité, nous sauverons notreclick.mp3 fichier dans le js dossier, mais vous pouvez le placer où vous le souhaitez.

L'étape suivante consiste à précharger le fichier audio. Deux options sont disponibles, à savoir -

  • preloadSimple - Il est utilisé pour des sons simples qui seront joués une fois.

  • preloadComplex - C'est pour les sons qui seront joués en tant que sons en boucle ou audio de fond.

Ajoutez le code suivant à votre contrôleur pour précharger un fichier audio. Nous devons nous assurer que la plate-forme Ionic est chargée avant de pouvoir précharger le fichier audio.

Code du contrôleur

$ionicPlatform.ready(function() {
   $cordovaNativeAudio
   .preloadSimple('click', 'js/click.mp3')
	
   .then(function (msg) {
      console.log(msg);
   }, function (error) {
      console.log(error);
   });

   $cordovaNativeAudio.preloadComplex('click', 'js/click.mp3', 1, 1)
	.then(function (msg) {
      console.log(msg);
   }, function (error) {
      console.error(error);
   });
});

Dans le même contrôleur, nous ajouterons du code pour la lecture audio. Notre$timeout La fonction s'arrête et décharge l'audio en boucle après cinq secondes.

$scope.playAudio = function () {
   $cordovaNativeAudio.play('click');
};

$scope.loopAudio = function () {
   $cordovaNativeAudio.loop('click');

   $timeout(function () {
      $cordovaNativeAudio.stop('click');
      $cordovaNativeAudio.unload('click');
   }, 5000);
}

La dernière chose dont nous avons besoin est de créer des boutons pour lire et boucler l'audio.

Code HTML

<button class = "button" ng-click = "playAudio()">PLAY</button>

<button class = "button" ng-click = "loopAudio()">LOOP</button>

Lorsque nous tapons sur le bouton de lecture, nous entendons le son une fois et lorsque nous appuierons sur le bouton de boucle, le son passera en boucle pendant cinq secondes, puis s'arrêtera. Ce plugin ne fonctionne que sur un émulateur ou un appareil mobile.