2016-05-03 14:11:47 +00:00
|
|
|
# DPlayer
|
|
|
|
|
|
|
|
[![npm](https://img.shields.io/npm/v/dplayer.svg?style=flat-square)](https://www.npmjs.com/package/dplayer)
|
2016-07-14 03:14:15 +00:00
|
|
|
[![npm](https://img.shields.io/npm/l/dplayer.svg?style=flat-square)](https://github.com/DIYgod/DPlayer/blob/master/LICENSE)
|
2016-05-03 14:11:47 +00:00
|
|
|
[![devDependency Status](https://img.shields.io/david/dev/DIYgod/dplayer.svg?style=flat-square)](https://david-dm.org/DIYgod/DPlayer#info=devDependencies)
|
|
|
|
[![npm](https://img.shields.io/npm/dt/dplayer.svg?style=flat-square)](https://www.npmjs.com/package/dplayer)
|
|
|
|
[![Travis](https://img.shields.io/travis/DIYgod/DPlayer.svg?style=flat-square)](https://travis-ci.org/DIYgod/DPlayer)
|
|
|
|
[![%e2%9d%a4](https://img.shields.io/badge/made%20with-%e2%9d%a4-ff69b4.svg?style=flat-square)](https://www.anotherhome.net/)
|
|
|
|
|
2016-05-17 18:23:44 +00:00
|
|
|
> Wow, such a lovely HTML5 danmaku video player
|
2016-05-03 14:11:47 +00:00
|
|
|
|
|
|
|
## Introduction
|
|
|
|
|
2016-07-14 03:14:15 +00:00
|
|
|
[Demo](http://dplayer.js.org/)
|
2016-05-19 14:49:13 +00:00
|
|
|
|
2016-05-20 00:48:30 +00:00
|
|
|
Screenshot
|
2016-05-20 13:31:17 +00:00
|
|
|
![image](http://i.imgur.com/207ch36.jpg)
|
2016-05-20 00:48:30 +00:00
|
|
|
|
2016-05-03 14:11:47 +00:00
|
|
|
## Install
|
|
|
|
|
|
|
|
```
|
|
|
|
$ npm install dplayer --save
|
2016-05-03 14:14:11 +00:00
|
|
|
```
|
2016-05-03 14:11:47 +00:00
|
|
|
|
2016-05-19 14:49:13 +00:00
|
|
|
## Usage
|
|
|
|
|
|
|
|
### HTML
|
|
|
|
|
|
|
|
```HTML
|
|
|
|
<div id="player1" class="dplayer"></div>
|
|
|
|
<!-- ... -->
|
2016-08-02 09:56:45 +00:00
|
|
|
<script src="dist/DPlayer.min.js"></script>
|
2016-05-19 14:49:13 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
### JS
|
|
|
|
|
|
|
|
```JS
|
|
|
|
var dp = new DPlayer(option);
|
|
|
|
dp.init();
|
|
|
|
```
|
|
|
|
|
2016-05-20 02:38:36 +00:00
|
|
|
**Options**
|
2016-05-19 14:49:13 +00:00
|
|
|
|
|
|
|
```JS
|
|
|
|
var option = {
|
|
|
|
element: document.getElementById('player1'), // Optional, player element
|
|
|
|
autoplay: false, // Optional, autoplay video, not supported by mobile browsers
|
|
|
|
theme: '#FADFA3', // Optional, theme color, default: #b7daff
|
|
|
|
loop: true, // Optional, loop play music, default: true
|
2016-07-20 06:45:26 +00:00
|
|
|
lang: 'zh', // Optional, language, `zh` for Chinese, `en` for English, default: Navigator language
|
2016-07-29 10:04:17 +00:00
|
|
|
screenshot: true, // Optional, enable screenshot function, default: false, NOTICE: if set it to true, video and video poster must enable Cross-Origin
|
2016-05-19 14:49:13 +00:00
|
|
|
video: { // Required, video info
|
2016-07-29 10:04:17 +00:00
|
|
|
url: '若能绽放光芒.mp4', // Required, video url
|
|
|
|
pic: '若能绽放光芒.png' // Optional, music picture
|
2016-05-19 14:49:13 +00:00
|
|
|
},
|
2016-08-02 09:56:45 +00:00
|
|
|
danmaku: { // Optional, showing danmaku, ignore this option to hide danmaku
|
2016-07-29 10:04:17 +00:00
|
|
|
id: '9E2E3368B56CDBB4', // Required, danmaku id, NOTICE: it must be unique, can not use these in your new player: `https://dplayer.daoapp.io/list`
|
2016-05-19 14:49:13 +00:00
|
|
|
api: 'https://dplayer.daoapp.io/', // Required, danmaku api
|
2016-05-26 13:18:24 +00:00
|
|
|
token: 'tokendemo', // Optional, danmaku token for api
|
|
|
|
maximum: 1000 // Optional, maximum quantity of danmaku
|
2016-05-19 14:49:13 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-05-20 02:38:36 +00:00
|
|
|
**API**
|
2016-05-19 14:49:13 +00:00
|
|
|
|
2016-07-15 02:33:20 +00:00
|
|
|
+ `dp.init()` // Load player
|
|
|
|
+ `dp.play()` // Resume play
|
|
|
|
+ `dp.play(time)` // Set currentTime
|
|
|
|
+ `dp.pause()` // Pause
|
2016-08-12 07:36:55 +00:00
|
|
|
+ `dp.toggle()` // Toggle between play and pause
|
|
|
|
+ `dp.on(event, handler)` // Event binding
|
|
|
|
+ `dp.dan` // Return danmaku info
|
|
|
|
+ `dp.danIndex` // Return danmaku index
|
|
|
|
+ `dp.video` // Return native video, most [native api](http://www.w3schools.com/tags/ref_av_dom.asp) are supported
|
|
|
|
+ `dp.video.currentTime` // Returns the current playback position
|
|
|
|
+ `dp.video.loop` // Returns whether the video should start over again when finished
|
|
|
|
+ Most [native api](http://www.w3schools.com/tags/ref_av_dom.asp)
|
2016-05-19 14:49:13 +00:00
|
|
|
|
2016-05-20 02:38:36 +00:00
|
|
|
**Event binding**
|
2016-05-19 14:49:13 +00:00
|
|
|
|
|
|
|
`dp.on(event, handler)`
|
|
|
|
|
|
|
|
`event`:
|
|
|
|
+ `play`: Triggered when DPlayer start play
|
|
|
|
+ `pause`: Triggered when DPlayer paused
|
|
|
|
+ `canplay`: Triggered when enough data is available that DPlayer can be played
|
|
|
|
+ `playing`: Triggered periodically when DPlayer is playing
|
|
|
|
+ `ended`: Triggered when DPlayer ended
|
|
|
|
+ `error`: Triggered when an error occurs
|
|
|
|
|
2016-08-02 09:56:45 +00:00
|
|
|
**Live Video (HTTP Live Streaming, M3U8 format)**
|
|
|
|
|
|
|
|
It requires the library [hls.js](https://github.com/dailymotion/hls.js) and it should be loaded before DPlayer.min.js.
|
|
|
|
|
2016-08-12 07:36:55 +00:00
|
|
|
Live danamku is not supported yet.
|
2016-08-02 09:56:45 +00:00
|
|
|
|
|
|
|
```HTML
|
|
|
|
<div id="player1" class="dplayer"></div>
|
|
|
|
<!-- ... -->
|
|
|
|
<script src="plugin/hls.min.js"></script>
|
|
|
|
<script src="dist/DPlayer.min.js"></script>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
var dp = new DPlayer({
|
|
|
|
// ...
|
|
|
|
video: {
|
|
|
|
url: 'xxx.m3u8'
|
|
|
|
// ...
|
|
|
|
}
|
|
|
|
});
|
|
|
|
dp.init();
|
|
|
|
</script>
|
|
|
|
```
|
|
|
|
|
2016-05-20 02:38:36 +00:00
|
|
|
**Work with module bundler**
|
2016-05-19 14:49:13 +00:00
|
|
|
|
|
|
|
```js
|
|
|
|
var DPlayer = require('DPlayer');
|
2016-05-26 13:18:24 +00:00
|
|
|
var dp = new DPlayer(option);
|
|
|
|
dp.init();
|
2016-05-19 14:49:13 +00:00
|
|
|
```
|
|
|
|
|
2016-05-20 02:33:55 +00:00
|
|
|
### Danmaku back-end
|
|
|
|
|
|
|
|
**Ready-made API:**
|
|
|
|
|
|
|
|
`https://dplayer.daoapp.io/`
|
|
|
|
|
|
|
|
**Build yourself:**
|
|
|
|
|
|
|
|
Required environment
|
|
|
|
|
|
|
|
- Node.js
|
|
|
|
- Mongodb
|
|
|
|
|
2016-05-03 14:11:47 +00:00
|
|
|
## Run in development
|
|
|
|
|
|
|
|
```
|
|
|
|
$ npm install
|
|
|
|
$ npm run dev
|
|
|
|
```
|
|
|
|
|
|
|
|
## Make a release
|
|
|
|
|
|
|
|
```
|
|
|
|
$ npm install
|
|
|
|
$ npm run build
|
|
|
|
```
|
|
|
|
|
2016-05-13 00:43:39 +00:00
|
|
|
## Related Projects
|
|
|
|
|
|
|
|
- [DPlayer-for-typecho](https://github.com/volio/DPlayer-for-typecho)
|
2016-07-14 03:14:15 +00:00
|
|
|
|
2016-05-23 16:20:43 +00:00
|
|
|
- [Hexo-tag-dplayer](https://github.com/NextMoe/hexo-tag-dplayer)
|
2016-07-14 03:14:15 +00:00
|
|
|
|
2016-06-01 15:05:13 +00:00
|
|
|
- [DPlayer_for_Z-BlogPHP](https://github.com/fghrsh/DPlayer_for_Z-BlogPHP)
|
2016-05-13 00:43:39 +00:00
|
|
|
|
2016-05-03 14:11:47 +00:00
|
|
|
## LICENSE
|
|
|
|
|
2016-07-08 04:23:56 +00:00
|
|
|
[The Star And Thank Author License (SATA)](https://github.com/DIYgod/DPlayer/blob/master/LICENSE)
|