diff --git a/.eslintrc b/.eslintrc index b80fdb0f8..f5d4ebe7a 100644 --- a/.eslintrc +++ b/.eslintrc @@ -56,6 +56,7 @@ "module": false, "Hls": false, "flvjs": false, - "dashjs": false + "dashjs": false, + "WebTorrent": false } } \ No newline at end of file diff --git a/README.md b/README.md index 42a3ddc45..eab479258 100644 --- a/README.md +++ b/README.md @@ -25,6 +25,7 @@ DPlayer is a lovely HTML5 danmaku video player to help people build video and da - [HLS](https://github.com/video-dev/hls.js) - [FLV](https://github.com/Bilibili/flv.js) - [MPEG DASH](https://github.com/Dash-Industry-Forum/dash.js) + - [WebTorrent](https://github.com/webtorrent/webtorrent) - Media formats - MP4 H.264 - WebM diff --git a/demo/demo.js b/demo/demo.js index cb86c4d91..fc585020a 100644 --- a/demo/demo.js +++ b/demo/demo.js @@ -149,6 +149,14 @@ function initPlayers () { // } // }); + // window.dp9 = new DPlayer({ + // container: document.getElementById('dplayer9'), + // video: { + // url: 'magnet:?xt=urn:btih:08ada5a7a6183aae1e09d831df6748d566095a10&dn=Sintel&tr=udp%3A%2F%2Fexplodie.org%3A6969&tr=udp%3A%2F%2Ftracker.coppersurfer.tk%3A6969&tr=udp%3A%2F%2Ftracker.empire-js.us%3A1337&tr=udp%3A%2F%2Ftracker.leechers-paradise.org%3A6969&tr=udp%3A%2F%2Ftracker.opentrackr.org%3A1337&tr=wss%3A%2F%2Ftracker.btorrent.xyz&tr=wss%3A%2F%2Ftracker.fastcast.nz&tr=wss%3A%2F%2Ftracker.openwebtorrent.com&ws=https%3A%2F%2Fwebtorrent.io%2Ftorrents%2F&xs=https%3A%2F%2Fwebtorrent.io%2Ftorrents%2Fsintel.torrent', + // type: 'webtorrent' + // } + // }); + // window.dp6 = new DPlayer({ // container: document.getElementById('dplayer6'), // preload: 'none', diff --git a/demo/index.html b/demo/index.html index 84b7d6760..fb4a96346 100644 --- a/demo/index.html +++ b/demo/index.html @@ -10,6 +10,7 @@ + @@ -54,6 +55,11 @@

FLV support

+

WebTorrent

+
+
+
+

Live

diff --git a/src/js/player.js b/src/js/player.js index 9bd924116..c6ff50e58 100644 --- a/src/js/player.js +++ b/src/js/player.js @@ -323,26 +323,73 @@ class DPlayer { } } - // HTTP Live Streaming - if (this.type === 'hls' && Hls && Hls.isSupported()) { - const hls = new Hls(); - hls.loadSource(video.src); - hls.attachMedia(video); - } - - // FLV - if (this.type === 'flv' && flvjs && flvjs.isSupported()) { - const flvPlayer = flvjs.createPlayer({ - type: 'flv', - url: video.src - }); - flvPlayer.attachMediaElement(video); - flvPlayer.load(); - } + switch (this.type) { + // https://github.com/video-dev/hls.js + case 'hls': + if (Hls) { + if (Hls.isSupported()) { + const hls = new Hls(); + hls.loadSource(video.src); + hls.attachMedia(video); + } + else { + this.notice('Error: Hls is not supported.'); + } + } + else { + this.notice('Error: Can\'t find Hls.'); + } + break; + + // https://github.com/Bilibili/flv.js + case 'flv': + if (flvjs && flvjs.isSupported()) { + if (flvjs.isSupported()) { + const flvPlayer = flvjs.createPlayer({ + type: 'flv', + url: video.src + }); + flvPlayer.attachMediaElement(video); + flvPlayer.load(); + } + else { + this.notice('Error: flvjs is not supported.'); + } + } + else { + this.notice('Error: Can\'t find flvjs.'); + } + break; - // MPEG DASH - if (this.type === 'dash' && dashjs) { - dashjs.MediaPlayer().create().initialize(video, video.src, false); + // https://github.com/Dash-Industry-Forum/dash.js + case 'dash': + if (dashjs) { + dashjs.MediaPlayer().create().initialize(video, video.src, false); + } + else { + this.notice('Error: Can\'t find dashjs.'); + } + break; + + // https://github.com/webtorrent/webtorrent + case 'webtorrent': + if (WebTorrent) { + this.container.classList.add('dplayer-loading'); + const client = new WebTorrent(); + const torrentId = video.src; + client.add(torrentId, (torrent) => { + const file = torrent.files.find((file) => file.name.endsWith('.mp4')); + file.renderTo(this.video, { + autoplay: this.options.autoplay + }, () => { + this.container.classList.remove('dplayer-loading'); + }); + }); + } + else { + this.notice('Error: Can\'t find Webtorrent.'); + } + break; } } @@ -367,7 +414,7 @@ class DPlayer { // video download error: an error occurs this.on('error', () => { - this.tran && this.notice && this.notice(this.tran('This video fails to load'), -1); + this.tran && this.notice && this.type !== 'webtorrent' & this.notice(this.tran('This video fails to load'), -1); }); // video end