h265player开发

news/2025/1/11 10:53:10/

h265player开发

https://github.com/goldvideo/h265player

简介

随着视频编码技术的发展,相比H.264, H.265同等画质体积仅为一半、带宽占用省一半、画质更细腻等诸多优势。 但Web浏览器还不支持H.265的解码播放,因此基于Web Assembly(封装FFmpeg)、JS解封装、Canvas投影以及AudioContext实现Web端的H265播放。

支持主要浏览器及其版本如下:

Chrome(>57) Safari (>11) Firefox (>52)

本项目是一个公开的基础可用版本,并不含有具体的业务代码。业务可基于此项目进行具体业务实现。

安装与测试

下载源码

# 创建根目录 mkdir goldvideo cd goldvideo# 下载h265player源码, 创建h265player目录 git clone https://github.com/goldvideo/h265player.git cd h265player# 安装依赖* npm install****

工程打包

# 以下打包命令任选一 npm run dev # 运行开发环境 npm run test # 运行测试环境 npm run build # 打包正式环境 rollup -c # 打包csj与esm版本****

Nginx配置(或者其他Server)

server { listen 8000; location / { root /goldvideo; index index.html index.htm; autoindex on; }}

测试页面

重启nginx并访问demo地址,就能看到播放器画面,如果可以能正常播放视频时就表示成功了。http://localhost:8000/h265player/demo/demo.html

如果遇到错误,请通过检查路径配置以及资源是否加载完成等。您也可以给我们留言反馈问题,我们将尽快回复。

以上就完成了基本安装,想了解更多详情,可以接着往下看。

安装NPM包,参照example快速运行例子[可选]

# 可以直接npm安装构建后的文件,快速运行DEMO npm i goldvideo-player*

具体参见 goldvideo example

源码安装解封装库demuxer[可选]

下载 demuxer 库源码 或者 从 npm 安装 (https://www.npmjs.com/package/demuxer)

  • cd goldvideo* git clone https://github.com/goldvideo/demuxer.git* cd demuxer* npm install# 打包模块,详情请查看demuxer项目里面的package.json文件* npm install --global rollup# 构建demuxer模块* rollup -c ./rollup.config.js --environment BUILD_MODE:production* cd h265player# 从本地安装demuxer,调用本地构建的库* npm install …/demuxer

源码编译WASM解码库[可选]

decoder_wasm库之前已经编译并复制到 h265player/dist/lib/目录下。你也可以自己编译并替换libffmpeg.js与libffmpeg.wasm文件。

# 如果想看源码和编译过程,可以查看decoder_wasm模块源码。 cd goldvideo git clone http://github.com/goldvideo/decoder_wasm.git cd decoder_wasm***

wasm安装略微复杂,详细查看README文件

主要模块结构

源码目录结构

├─goldvideo│ ├─demuxer│ ├─h265player│ ├─decoder_wasm│ ├─example

整体架构图

播放器主要分为UI、Loader、数据处理、数据渲染四个部分和3个线程。一个是主线程,包括界面控制、下载控制、数据流控制、音视频控制等功能;数据加载线程,完成元数据和数据片段的请求;数据处理线程,完成数据解封装和解码。

UI:播放器显示成,包括screen和controlbar两部分,screen包括视频图像展示、弹窗、海报图等。controlbar包括进度条、播放按钮、音量控制等组件。
Loader:负责媒体数据的加载和解析,目前仅支持HLS协议。通过worker实现数据的请求,加载完成后,根据设置缓存大小,存储请求的ts数据,当达到缓存上限后停止加载。解码器从ts数据队列获取ts后,Hls Loader会把请求过的ts释放,继续加载下一个ts,达到最大缓存限制后停止加载数据处理:主要包括数据解封装和H265解码,解封装通过demuxe.js这个类库实现,H265解码通过ffmpeg打包生成的wasm软解来实现,cpu使用率较高。数据渲染:包括视屏渲染和音频渲染,视频渲染通过ImagePlayer把解码后的yuv数据直接渲染到canvas,音频通过AudioPlayer把AAC数据解码后进行音频播放,最后通过pts实现音视频的同步。同步策略是以音频为参考,判断当前视频pts与获取到的音频pts的差值来调整视频显示时间来达到音视频同步。

具体流程如下:

解封装器

通过JS实现了视频数据的解封装,从而获取到独立的视频(H265)数据和音频(AAC)数据。详细信息请参考demuxer模块:https://github.com/goldvideo/demuxer。

解码器

通过ffmpeg实现H265数据的软解码,如果要在浏览器中调用ffmpeg,需要把ffmpeg编译成wasm进行调用,具体ffmpeg编译成wasm过程,可参考decoder_wasm

ImagePlayer

通过yuv-canvas实现YUV数据渲染,ImagePlayer中会有一个队列存储YUV数据,并计算当前yuv数据的时间长度,大于等于readybufferLength的值时,会触发ImagePlayerReady事件。当音视频播放器都处于ready状态时,H265播放器触发dataReady事件,开始调用play方法进行视频播放。

AudioPlayer

Web Audio API

Audio Player的实现基于Web Audio API, 包括AAC音频流的解码与PCM数据的播放。

解码:Audio
Player模块接收解封装模块发过来的AAC数据流,通过AudioContext的decodeAudioData
API,解码为待后续播放的PCM数据。
音频节点:音频节点(AudioNode)是Web
Audio API中的音频数据"处理器",Web
Audio API通过不同“处理器”对音频数据做串行处理,最终通过扬声器(audioContext.destination)播放。

ScriptProcessorNode:音频源节点。Web
Audio API提供多种音频源节点以提供音频数据,如AudioBufferSourceNode,
MediaElementAudioSourceNode等。考虑到倍速播放的需求,我们用的是ScriptProcessorNode, 通过onaudioprocess回调函数请求音频数据。
GainNode:音量控制节点。

倍速播放

Audio Context的部分音频节点提供了playbackRate属性以实现倍速播放的功能,但是音频在倍速播放的同时,音频的音调(pitch)也同步地升高/降低。

为实现变速不变调,项目中,我们使用了一个音频数据处理库SoundTouchJS,将处理过的变速不变调的音频数据提供给ScriptProcessorNode。

快速开始

在head标签中添加如下代码

创建一个div,作为播放器的容器

新建一个GoldPlay实例对象,传入相应参数,就可以实现视频的播放

//播放器容器let el = doc.querySelector(’.play-container’)//播放器参数let options = { // 视频播放地址 sourceURL: ‘http://localhost:8000/h265player/data/video2/playlist.m3u8’, type: ‘HLS’ // wasm库地址 libPath: ‘http://localhost:8000/h265player/dist/lib’,}let player = new GoldPlay(el, options}

在线demo

https://omc3i.codesandbox.io/

组件扩展

如何扩展UI组件请参考文档 组件添加componentadd

API

https://goldvideo.github.io/h265player/API/index.html

开发与维护

github: https://github.com/goldvideo/h265player


http://www.ppmy.cn/news/611806.html

相关文章

Android Jetpack Compose - 深入了解 AlertDialog

在开发 Android 应用时,对话框是一个常见的 UI 元素,用于向用户显示信息或获取用户的反馈。在 Jetpack Compose 中,我们可以使用 AlertDialog 组件来创建对话框。在这篇博客中,我们将深入了解如何使用 Jetpack Compose 的 AlertDi…

寒假作业pta3

某地老鼠成灾,现悬赏抓老鼠,每抓到一只奖励10元,于是开始跟老鼠斗智斗勇:每天在墙角可选择以下三个操作:放置一个带有一块奶酪的捕鼠夹(T),或者放置一块奶酪(C),或者什么也不放(X)。捕鼠夹可重复…

微信小程序点击图片切换图片

实现的效果图 实现的方式有2中 先说下思路 1 使用wx:if 写2个图片 点击的显示一张即可, 2 使用数据传递当拿到图片的时候更换图片即可. 看下代码 2中方式:xml <view class"intro"> <image catchtapopen_tap wx:if"{{isShow}}" src"/im…

h265webplayer

h265webplayer https://github.com/ksvc/h265webplayer h265webplayer是金山云的Web端H.265视频播放器&#xff0c;该播放器Web SDK让您可以在支持WebAssembly的浏览器上播放MP4格式的点播视频&#xff0c;FLV http-flv协议的直播视频。 支持的功能 1、mp4格式的点播&#…

java后台的微信小程序支付的解决方案

java的后台主要就写两个controller 一个是 ----------------(1)调用支付统一下单API 生成 prepay_id 二个是 ----------------(2)微信支付完成的回调controller 第一个controller需要传入的参数有如下&#xff0c;如图&#xff1a; 然后&#xff0c;发送到微信端&#xff0c;把…

微信小程序bindtap 与 catchtap 是使用

如果写小程序对二者不理解的,那看到这边博客,将很快帮助到您, 个人总结的一句话:,bindtap点击事件在同一个view中会向上冒泡,而catchtap 不会向上冒泡 下面会有一个demo给出解释, 说他们使用的时候先说下微信小程序的事件分类冒泡事件与非冒泡事件 官网上这样规定的 事件分…

OpenGL 抗锯齿

1.简介 你可以看到&#xff0c;我们只是绘制了一个简单的立方体&#xff0c;你就能注意到它存在锯齿边缘。 可能不是非常明显&#xff0c;但如果你离近仔细观察立方体的边缘&#xff0c;你就应该能够看到锯齿状的图案。如果放大的话&#xff0c;你会看到下面的图案&#xff1a…

KNN算法简介

1&#xff0c;基本概念 邻近算法&#xff0c;或者说K最近邻(kNN&#xff0c;k-NearestNeighbor)分类算法是数据挖掘分类技术中最简单的方法之一。所谓K最近邻&#xff0c;就是k个最近的邻居的意思&#xff0c;说的是每个样本都可以用它最接近的k个邻居来代表。KNN 算法本身简单…