Einzelnen Beitrag anzeigen

CHackbart

Registriert seit: 22. Okt 2012
260 Beiträge
 
#6

AW: Welcher Mediaplayer

  Alt 15. Nov 2022, 20:04
Aus Erfahrung weiß ich, wenn es nur um Audio geht, ist Bass die beste Wahl. Die Bibliothek läuft auf allen Plattformen, ist extrem klein und sehr performant. Für Media allgemein würde ich Directshow empfehlen, oder FFmpeg. Ich hatte mal eine Erweiterung für Alcinoe geschrieben: https://github.com/MagicFoundation/Alcinoe/issues/164.
Du kannst auch das hier mal probieren: https://github.com/FactoryXCode/MfPack
Ich hatte damals kein Glück mit PlayReady - deswegen bin ich dann auf die von Bernhard vorgeschlagene Variante umgestiegen. Einen Webbrowser mit einem Javascript bei dem ich den Shakaplayer lade und meinen Stream im Browserfenster abspiele.

Code:
<html xmlns="http://www.w3.org/1999/xhtml">
  <body style="margin:0;padding:0;background-color:0">
    <script src="https://cdnjs.cloudflare.com/ajax/libs/shaka-player/4.3.0/shaka-player.compiled.js"></script>
    <div id="videodiv" style="position:absolute;width:100%;height:100%;z-index=0">
      <video width=100% height=100% id="video" autoplay></video>
    </div>
    <script>
      async function loadMedia(FileName, Widevine) {
        try {
          window.player.configure({
            drm: {
              servers: {
                "com.widevine.alpha": Widevine,
              },
              advanced: {
                "com.widevine.alpha": {
                  "videoRobustness": "SW_SECURE_CRYPTO",
                  "audioRobustness": "SW_SECURE_CRYPTO",
                }
              },
            },
          });
          window.player.configure("manifest.dash.ignoreMinBufferTime", true);
          window.player.configure("streaming.rebufferingGoal", 1);
          window.player.configure({
            manifest: {
              dash: {
                ignoreMinBufferTime: true
              }
            },
            streaming: {
              rebufferingGoal: 1,
            }
          });
          await window.player.load(FileName);
        } catch (e) {
          onError(e);
        }
      }

      function initApp() {
        shaka.polyfill.installAll();
        if (shaka.Player.isBrowserSupported()) {
          initPlayer();
        } else {
          console.error("Browser not supported!");
        }
      }
      async function initPlayer() {
        const video = document.getElementById("video");
        const player = new shaka.Player(video);
        video.onloadeddata = function() {
          setTimeout(function() {
            video.muted = false;
            video.play()
          }, 250);
        };
        window.player = player;
        player.addEventListener("error", onErrorEvent);
      }

      function onErrorEvent(event) {
        onError(event.detail);
      }

      function onError(error) {
        console.error("Error code", error.code, "object", error);
      }
      document.addEventListener("DOMContentLoaded", initApp);
    </script>
  </body>
</html>
Da die Browserkomponente Javascript Befehle ausführen kann, kann man loadMedia einfach laden mit der gewünschten URL und schon spielt das ganze in dem Browserfenster ab.

Christian
  Mit Zitat antworten Zitat