<h1 align="center">
<img src="fig/pear.png" height="110"></img>
<br>
<a href="https://demo.webrtc.win/player">PearPlayer.js</a>
<br>
<br>
</h1>
<h4 align="center">一个支持多协议、多源、混合P2P-CDN的流媒体播放器</h4>
<p align="center">
<a href="https://www.npmjs.com/package/pearplayer"><img src="https://img.shields.io/npm/v/pearplayer.svg?style=flat" alt="npm"></a>
<a href="https://www.jsdelivr.com/package/npm/pearplayer"><img src="https://data.jsdelivr.com/v1/package/npm/pearplayer/badge" alt="jsdelivr"></a>
<a href="https://www.jsdelivr.com/package/npm/pearplayer"><img src="https://img.shields.io/badge/license-MIT-blue.svg" alt="License"></a>
</p>
<br>
**[English](https://github.com/PearInc/PearPlayer.js/blob/master/README_EN.md)**
PearPlayer(梨享播放器)**[[Demo](https://demo.webrtc.win/)]** 是完全用JavaScript写的开源HTML5流媒体播放框架,实现了融合HTTP(包含HTTPS、HTTP2)、WebRTC的多协议、多源、低延迟、高带宽利用率的无插件Web端流媒体加速能力。基于H5的MSE技术(Media Source Extension)将来自多个源节点的Buffer分块喂给播放器,再加上精心设计的算法来达到最优的调度策略及对各种异常情况的处理,Pear Player能在保证用户流畅视频体验的前提下最大化P2P率。

<br>
<br>

只需将`pear-player.min.js`通过`<script>`标签导入到HTML就可以使用。 参考以下[代码示例](#快速开始),也可以查看[`/examples/player-test.html`](/examples/player-test.html)来了解使用方法。
参考[get-started](docs/get-started.md)来了解基本使用方法。<br/>
## 特性
- P2P能力基于**WebRTC**,无须安装任何插件
- 多协议(HTTP、HTTPS、WebRTC)、多源
- 自研的调度算法,在保证用户流畅视频体验的前提下最大化P2P率
- 默认无需填参数(内部根据视频码率等作自适应),高级使用模式可自行调整算法和参数
- 默认不会无限制缓冲,尽可能为CP用户节省带宽/流量
- 支持Chrome、Firefox、Opera、IE、Edge等主流浏览器,即将支持Safari、腾讯微信、X5/TBS(可以多源传输,播放问题待不久后MSE支持完善)
- 可选接入低成本、高可用的Pear [Fog CDN](https://github.com/PearInc/FogVDN)
- 协议默认通过TLS/DTLS全加密,无DPI特征;并可通过Pear Fog组件的动态端口映射进一步消除统计学特征
- 像使用HTML5 `<video>`标签一样简单,并容易与[video.js](https://github.com/videojs/video.js)等流行播放框架集成
- 具备Browser P2P能力(基于WebTorrent)

## 快速开始
将以下代码拷贝到HTML5代码中,打开网页,见证奇迹的时刻到了!
```html
<script src="https://cdn.jsdelivr.net/npm/pearplayer@latest"></script>
<video id="video" controls></video>
<script>
var player = new PearPlayer('#video', { src: 'https://qq.webrtc.win/tv/Pear-Demo-Yosemite_National_Park.mp4' });
</script>
```
## 使用方法
### 导入js文件并绑定video标签
首先通过script标签导入pear-player.min.js:
```html
<script src="./dist/pear-player.min.js"></script>
```
或者使用CDN:
```html
<script src="https://cdn.jsdelivr.net/npm/pearplayer@latest"></script>
```
假设用video标签播放如下视频,HTML如下所示:
```html
<video id="pearvideo" src="https://qq.webrtc.win/tv/Pear-Demo-Yosemite_National_Park.mp4" controls>
```
只需要如下几行代码,即可将PearPlayer绑定到video标签:
```html
<script>
/**
* 第一个参数为video标签的id或class
* opts是可选的参数配置
*/
if (PearPlayer.isMSESupported()) {
var player = new PearPlayer('#pearvideo', opts);
}
</script>
```
恭喜您,您的播放器已经具备P2P能力了,而且无须任何插件!
### 如何为自己的视频加速?
示例中的视频是已经分发过的,那么如何为任意视频加速呢?很简单,只需在[视频分发系统](https://oss.webrtc.win/)中添加您的视频URL,即可利用Pear的海量节点为您的视频加速!具体教程请点击[这里](https://manual.webrtc.win/oss/)(目前仅支持分发`MP4`格式,视频的名字需要加上`Pear-Demo`前缀,如`Pear-Demo-movie.mp4`)
## 谁在用我们的产品?
+ [Pear Limited](https://pear.hk)
+ [Lenovo China](https://www.lenovo.com.cn/)
+ [Newifi xCloud](http://www.newifi.com/)
+ [FastWeb](http://fastweb.com.cn/)
+ [UCloud](https://www.ucloud.cn)
+ [Tencent Cloud](https://qcloud.com)
+ [Tencent X5/TBS](https://x5.tencent.com/tbs/)
+ [Tencent APD](http://www.chinaz.com/news/2016/0707/548873.shtml)
## Pear Player 文档
- **[阅读get-started文档](docs/get-started.md)**
- **[阅读API文档](docs/api.md)**
## 致谢
特别感谢以下项目,为本项目提供了部分灵感来源以及API设计参考:
- [WebTorrent](https://github.com/webtorrent/webtorrent)
- [Peer5](https://www.peer5.com/#)
## 演讲与媒体报道
- 2017.11.24 (金色财经) - [谛听科技正式进军区块链领域,战略投资梨享计算](http://www.jinse.com/blockchain/99767.html)
- 2017.09.01 (未来网络开放社区联盟) - [继云计算之后,雾计算再起 —— 谈谈 P2P CDN](https://mp.weixin.qq.com/s/39dfSA6cTj2eoo-KqsC3AQ)
- 2017.08.18 (IT大咖说) - [WebRTC会成主流吗?众包CDN时代到了!](http://mp.weixin.qq.com/s/cx_ljl2sexE0XkgliZfnmQ)
- 2017.07.11 (OSChina开源中国) - [PearPlayer.js —— 混合P2P-CDN的流媒体播放器](https://www.oschina.net/p/PearPlayerjs)
- 2017.06.24 (腾讯Web前端大会) - [基于WebRTC的P2P-CDN流媒体加速](http://www.itdks.com/dakalive/detail/2577)
- 2017.05.17 (南方科技大学) - Edge Computing and Shared Fog Streaming
- 2017.05.08 (台湾逢甲大学) - A Cooler Fruit Venture: Scaling up a Network from Cloud to Fog with Crowdsourcing
- 2016.08.17 (香港科技大学) - From Cloud to Fog: Scaling up a Network with Crowdsourcing
## License
MIT. Copyright (c) [Pear Limited](https://pear.hk) and [snowinszu](https://github.com/snowinszu).
## 帮助与支持
E-mail: <service@pear.hk>;用户QQ群:`373594967`;[CP/CDN接入、OEM与其他商务合作](https://github.com/PearInc/FogVDN)

weixin_42651887
- 粉丝: 108
- 资源: 1万+
最新资源
- 三段式电流保护Matlab Simulink仿真模型与实验:原理、相间距离保护及整定分析(多版本含操作指南),三段式电流保护Matlab Simulink仿真模型与实验:涵盖模型仿真文件、操作说明、保
- 批量下载源码:编译的Python whl包生成及其自动化源码获取方法,编译的Python二进制whl包批量下载源码解析与实现,编译的二进制Python的whl包批量下载源码 ,编译的二进制; Pyth
- 基于CFD的轴流风叶流体力学分析:高效能设计的策略与探讨,利用CFD计算流体力学分析轴流风叶的性能及优化设计,cfd 计算流体力学 分析轴流风叶 ,关键词:CFD;计算流体力学;轴流风叶;流场分析;气
- Matlab Simulink三闭环直流电机调速系统仿真:深度解析位置环、速度环与电流环的PI控制及PWM调制技术,附H桥正反转控制及详尽说明文档(R2022a版本),Matlab Simulink三
- 基于形状的跨平台模板匹配技术:Windows、Linux、ARM平台通用的C++实现与OpenCV、HALCON的替代方案,自研跨平台C++模板匹配技术:Windows、Linux、ARM通用,基于形
- 基于OpenCV的跨平台形状模板匹配:C++与C#在Windows与Linux下的应用与实现,适用于ARM等不同架构 ,基于OpenCV的跨平台模板匹配算法:C++与C#实现,支持Windows、Li
- 基于灰狼优化的高斯过程回归算法的锂电池SOH估算学习案例:利用NASA锂离子电池老化数据集的实验分析与MATLAB代码实现,基于Matlab的灰狼优化GPR算法锂电池SOH估算学习案例,电池SOH估
- 污水流量远程监测系统的设计
- 杏鲍菇栽培环境因子远程监测系统及模糊PID控制器的设计
- 医院室内空气质量实时监测系统
- 油浸式变压器三维温度场建模及在线温度监测系统研究
- 血液透析治疗仪的控制系统研究
- LCC-MMC三端混合直流系统:基于PSCAD的仿真研究与分析,LCC-MMC三端混合直流系统仿真分析与优化研究:基于PSCAD软件的模拟研究,LCC-MMC三端混合直流系统pscad仿真 ,LCC
- 诱芯诱捕器自动计数系统的研发
- 基于HTML+JavaScript等技术的心理咨询平台设计源码
- 光伏储能并网三端口仿真研究:DC升压与充放电管理、双PI控制及直流母线电压恒定策略探讨,“光伏储能并网三端口仿真:DC升降压、充放电管理、双向转换与稳压控制”,光伏 储能 并网 三端口 仿真 光伏 :
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈


