DPlayer/README.md

162 lines
5.4 KiB
Markdown
Raw Normal View History

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)
2016-08-18 10:41:49 +00:00
[![gitter](https://img.shields.io/gitter/room/DIYgod/DPlayer.svg?style=flat-square)](https://gitter.im/diygod233/dplayer)
2016-05-03 14:11:47 +00:00
[![%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-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
## Usage
### HTML
```HTML
<div id="player1" class="dplayer"></div>
<!-- ... -->
2016-08-02 09:56:45 +00:00
<script src="dist/DPlayer.min.js"></script>
```
### JS
```JS
var dp = new DPlayer(option);
dp.init();
```
2016-05-20 02:38:36 +00:00
**Options**
```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
screenshot: true, // Optional, enable screenshot function, default: false, NOTICE: if set it to true, video and video poster must enable Cross-Origin
video: { // Required, video info
url: '若能绽放光芒.mp4', // Required, video url
pic: '若能绽放光芒.png' // Optional, music picture
},
2016-08-02 09:56:45 +00:00
danmaku: { // Optional, showing danmaku, ignore this option to hide danmaku
id: '9E2E3368B56CDBB4', // Required, danmaku id, NOTICE: it must be unique, can not use these in your new player: `https://dplayer.daoapp.io/list`
api: 'https://dplayer.daoapp.io/', // Required, danmaku api
token: 'tokendemo', // Optional, danmaku token for api
maximum: 1000 // Optional, maximum quantity of danmaku
}
}
```
2016-05-20 02:38:36 +00:00
**API**
2016-07-15 02:33:20 +00:00
+ `dp.init()` // Load player
+ `dp.play()` // Resume play
+ `dp.play(time)` // Set currentTime
+ `dp.pause()` // Pause
+ `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-20 02:38:36 +00:00
**Event binding**
`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.
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**
```js
var DPlayer = require('DPlayer');
var dp = new DPlayer(option);
dp.init();
```
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)