JimmyVV / httplive

http-chunked for live, easily implement and combine
Apache License 2.0
112 stars 8 forks source link
httpflv httplive mse playback


Introduction

When the MSE technology is accepted by most of browser, front-end developers can do much more multimedia things. And now, more than 80% browser has supported it. In China, X5, the largest market share of the kernel, will support it in early 2018. httplive achieves live stream playback of httpflv protocol depending on MSE. Based on the loaders idea, it decouples and encapsulates modules in httpflv, like HttpChunked, MuxController, MSEController. If you want to customize you owner player, you just need to simply follow the relevant standards. And this is the main idea:

httplive is not a library, but a standards of front-end live stream playback

DEMO

HTTPLive demo

Languages

中文版请参考:readme_cn.md

Features

Install

npm install httplive --save

Get Started

import HTTPLive from 'httplive';

let video = document.getElementById('videoTag');

let flv = new HTTPLive({
  video
});

video.addEventListener('canplaythrough',()=>{
  video.play();
},false);

flv.send('https://xxx.flv');

If you want to use custom modules to replace existing modules, you can simply do like this:

import {CustomPlayer} from 'httplive';
import WebSocketChunked from 'custom';

// Replace HTTPChunked module by WebSocketChunked. 

const HTTPLive = CustomPlayer({
    HTTPChunked: WebSocketChunked
});

let flv = new HTTPLive({
  video
});
...

Later, I will show you about the standard protocols of these modules in wiki.

API

api.md

Contact

If you are interested in MSE and live stream playback, you can scan the QR_code and join us in QQ.

QR_code

After you scan it, you will receive a question and its answer is MSE

For these people who don't have a QQ account,you can send me a email and keep contact.

When you meet some problem about httplive, you can show us issue. Httplive is an open-source repo,so we welcome people to check and optimze it and contribute your PR

LICENSE

httplive is under the Apache License. See the LICENSE file for details.