推荐一款开源的纯H5直播流播放器(推荐一款开源的纯H5直播流播放器)

今天给大家推荐一款开源的纯H5直播流播放器,他就是Jessibuca

Jessibuca是一款开源的纯H5直播流播放器,通过Emscripten将音视频解码库编译成Js(ams.js/wasm)运行于浏览器之中。兼容几乎所有浏览器,可以运行在PC、手机、微信中,无需额外安装插件。

功能
  • 支持解码H.264视频(Baseline, Main, High Profile全支持,支持解码B帧视频)
  • 支持解码H.265视频(flv id == 12)
  • 支持解码AAC音频(LC,HE,HEv2 Profile全支持)
  • 支持解码PCMA音频以及PCMU音频格式
  • 可设置播放缓冲区时长,可设置0缓冲极限低延迟(网络抖动会造成卡顿现象)
  • 支持智能不花屏丢帧,长时间播放绝不累积延迟。
  • 可创建多个播放实例
  • 程序精简,经CDN加速,GZIP压缩(实际下载500k),加载速度更快
  • 同时支持http-flv和websocket-flv协议以及websocket-raw私有协议(裸数据,传输量更小,需要搭配Monibuca服务器) 注:以http-flv请求时,存在跨域请求的问题,需要设置access-control-allow-origin, websocket-flv默认不存在此问题
  • 支持HTTPS/WSS加密视频传输,保证视频内容传输安全
  • 手机浏览器内打开视频不会变成全屏播放
特点

无插件:基于 MediaSource/WebAssembly(wasm) 实现的纯 JavaScript 直播播放器

低延时:能够在 PC\Android\iOS 浏览器 Webview 内实现2秒以内低延迟直播播放

自带控制条:可以通过配置显示/隐藏底部控制条

支持创建多个播放实例:支持创建多个播放实例,WebWorker 多核解码,提升多画面播放性能。

支持多种视频缩放模式:支持填充,等比,等比缩放 3 种视频缩放模式

支持音量调节:支持 0-1 的音量调节

支持H264/H265:软解码 H.264/H.265 AAC/PCMA/PCMU 流,WebGL 视频渲染,WebAudio 音频播放。

支持 MediaSource 硬解码:支持 MediaSource 硬解码 H.264 视频。(Safari on iOS 不支持)

支持 Webcodecs 硬解码:支持 Webcodecs 硬解码 H.264 视频。(需在 chrome 94 版本以上,需要 https 或者 localhost 环境)

支持视频录制:支持录制 MP4 和 WebM 格式的视频录制。(基于 MediaRecorder)。

本地测试
  • 执行yarn 或者npm i
  • 执行yarn dev 或者 npm run dev
API

API

源码目录结构
  • obj 存放emscripten编译好的ffmpeg解码库的字节码库
  • demo/public 存放编译输出的js和wasm文件
  • src 存放js源码
打包js

执行yarn build 或者 npm run build

引用关系

src/index.js 引用了jessibuca.js和worker.js 目的是将两个js打包到一起,实际执行中会根据当前是否为主线程来判断是否加载worker线程(把自己加载到webworker中) worker.js 会引用 demo/public/ff.js (该文件由编译C 文件所得,用于加载wasm)

编译C 代码

执行yarn build:wasm 或者 npm run build:wasm

基本原理

推荐一款开源的纯H5直播流播放器(推荐一款开源的纯H5直播流播放器)(1)

欢迎点赞 转发 关注!大家的支持是我分享最大的动力!!!

,

免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com

    分享
    投诉
    首页