PearPlayer (梨享播放器) [Demo] is a streaming media player framework written completely with HTML5 and JavaScript. Combining HTTP (including HTTPS, HTTP2) and WebRTC, PearPlayer accelerates media streaming on the Web. It supports multiple protocols, multiple sources, and achieves low latency and high bandwidth utilization. With the help of H5 MSE (Media Source Extension) technology, it receives buffers from multiple source nodes and delivers to the player. Finely designed algorithms are adopted to achieve the best scheduling effect and to handle abnormal situations. Thus, PearPlayer can provide end-users with wonderful video watching experience while maximizing the P2P ratio at the same time.
Simply import pear-player.min.js
to HTML via the <script>
tag. Refer to code examples below, or consult /examples/player-test.html
or get-started for usages.
- Plugin-free thanks to the P2P ability based on WebRTC
- Multi-protocol (HTTP, HTTPS, WebRTC) and multi-source
- Customized algorithms that provide users with wonderful video watching experience while maximizing the P2P ratio at the same time.
- Parameter-free by default (dynamic adaptive internally according to bitrate, etc.). Clients can fill in their preferred parameters in advanced mode.
- Buffers are limited to save bandwidth/traffic for CP users.
- Support Chrome, Firefox, Opera, IE, Edge and other mainstream browsers; will support Safari, Tencent WeChat and X5/TBS (multi-source transmission is enabled; media playback issues will be well resolved when MSE is supported)
- Optional access to low cost, high availability Pear Fog CDN
- Fully encrypted via TLS/DTLS by default, no DPI features; statistical characteristics can be further eliminated using dynamic port mapping of Pear Fog Suite.
- As easy as using HTML5
<video>
tag; easy to integrate with popular player frameworks like video.js - With Browser-to-Browser P2P ability (based on WebTorrent)
Please copy the following codes into Web HTML5 code, and then open the webpage. Now, it's time to witness the miracle.
<video id="video" controls></video>
<script>
var player = new PearPlayer('#video', { src: 'https://qq.webrtc.win/tv/Pear-Demo-Yosemite_National_Park.mp4' });
</script>
First import the <script> tag to pear-player.min.js:
<script src="./dist/pear-player.min.js"></script>
or use CDN:
<script src="https://cdn.jsdelivr.net/npm/pearplayer@latest"></script>
If use video tag to play the following video, HTML is like below:
<video id="pearvideo" src="https://qq.webrtc.win/tv/Pear-Demo-Yosemite_National_Park.mp4" controls>
PearPlayer can be bound to the video tag using only the codes below:
<script>
/**
* The first parameter is ID or CLASS of the video tag
* Opts means the optional parameter configurations
*/
if (PearPlayer.isMSESupported()) {
var player = new PearPlayer('#pearvideo', opts);
}
</script>
Congratulations! NOW your player has P2P ability and no plug-ins!
The video above has already been dispatched. So how to speed up other videos? Just add your video URL into Pear Fog Content Delivery Operating System. And then you can feel free to use Pear's massive fog nodes to accelerate your videos! Please click here for detailed guide. (Currently, newly-registered users can distribute three MP4
/TS files, each under 100MB, free of charge. Prefix Pear-Demo-
prefix needs to be added in front of the video file name, such as Pear-Demo-movie.mp4
)
Special thanks goes to the following projects that provide some inspirations and API design references:
- Feb 7th, 2018 (36Kr) - 「Pear Share」practises fog computing, behind millions of fringe nodes are efficiency promotion and cost control
- Sep 1st, 2017 (Future Network and Open Community Alliance) - Fog Computing rises after Cloud Computing - Have a discuss on P2P-CDN
- Aug 18th, 2017 (IT Biggie Talks) - Will WebRTC be the mainstream? Here comes the era of CDN crowdsourcing!
- Jul 11st, 2017 (OSChina) - PearPlayer.js - A streaming media player supports Mixed P2P-CDN
- Jun 24th, 2017 (Tencent Frontend Conference) - P2P-CDN streaming media acceleration based on WebRTC
- May 17th, 2017 (Southern University of Science and Technology) - Edge Computing and Shared Fog Streaming
- May 8th, 2017 (Feng Chia University) - A Cooler Fruit Venture: Scaling up a Network from Cloud to Fog with Crowdsourcing
- Aug 17th, 2016 (Hong Kong University of Science and Technology) - From Cloud to Fog: Scaling up a Network with Crowdsourcing
MIT. Copyright (c) Pear Limited and snowinszu.
E-mail: service@pear.hk; User QQ group:373594967
; CP/CDN, OEM and other business cooperations