@oplayer/hls
Version:
Hls plugin for oplayer
108 lines (89 loc) • 2.55 kB
Markdown
# oplayer-plugin-hls
[](https://www.npmjs.com/package/@oplayer/hls)

[](https://www.npmjs.com/package/@oplayer/hls)
[](https://www.jsdelivr.com/package/npm/@oplayer/hls)
[HLS](https://github.com/video-dev/hls.js) plugin for oplayer
## Install
```bash
npm i @oplayer/hls hls.js
```
```html
<script src="https://cdn.jsdelivr.net/npm/@oplayer/core@latest/dist/index.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/@oplayer/hls@latest/dist/index.min.js"></script>
<div id="oplayer" />
<script>
OPlayer.make('#oplayer', {
source: {
src: 'https://test-streams.mux.dev/x36xhzz/x36xhzz.m3u8',
poster: 'https://cdn.jsdelivr.net/gh/shiyiya/QI-ABSL@master/o/poster.png'
}
})
.use([OHls({ library: 'https://cdn.jsdelivr.net/npm/hls.js@0.14.17/dist/hls.min.js' })])
.create()
</script>
```
## Handle default Quality/Audio/Subtitle
```js
OHls({
forceHLS: true, // use hls.js not native
defaultQuality(levels) {
let id = -1 // -1 => 'auto'
for (let i = 0; i < levels.length; i++) {
if (levels[i].height <= 1080) id = i
}
return id
},
defaultAudio(tracks) {
for (const { lang, id } of object) {
if (lang == 'en' || lang.startsWith('en')) {
return id
}
}
return -1 // -1 => brower lang
},
defaultSubtitle(tracks) {
for (const { lang, id } of object) {
if (lang == 'en' || lang.startsWith('en')) {
return id
}
}
return -1 // -1 => brower lang
}
})
```
## Handle Hls.js Error
```ts
OHls({
errorHandler(player, data) {
// skip bufferAppendError
if (data.details == 'bufferAppendError') return
player.emit('error', {
...data,
message: data.type + ': ' + data.details
})
}
})
```
## DRM
```ts
OHls({
forceHLS: true, // use hls.js not native
config: {
emeEnabled: true,
drmSystems: {
'com.widevine.alpha': {
licenseUrl: 'https://widevine-proxy.appspot.com/proxy'
}
},
licenseXhrSetup(xhr) {
xhr.setRequestHeader('content-type', 'application/octet-stream')
xhr.setRequestHeader('Authorization', 'Bearer token') // or other headers
}
}
})
// update
player.context.hls.options.config = {
//...
}
```