Demo | 媒资信息 |
---|---|
Input #0, hevc, from 'res/video40_265_moov.hevc' :Duration: N/A, bitrate: N/A Stream #0:0: Video: hevc (Main), yuv420p(tv), 1280x720, 25 fps, 25 tbr, 1200k tbn, 25 tbc |
- 能力
能力 | 是否支持 | 其他 |
---|---|---|
HEVC/H.265 Nalu解析 | 是 | ---- |
HEVC/H.265 帧解码 | 是 | ---- |
HEVC/H.265 多窗口播放 | 是 | ---- |
- 协议
协议 | 是否支持 | 说明 |
---|---|---|
HEVC/H.265 点播 | 是 | ---- |
HEVC/H.265 点播 | 是 | ---- |
token = "base64:QXV0aG9yOmNoYW5neWFubG9uZ3xudW1iZXJ3b2xmLEdpdGh1YjpodHRwczovL2dpdGh1Yi5jb20vbnVtYmVyd29sZixFbWFpbDpwb3JzY2hlZ3QyM0Bmb3htYWlsLmNvbSxRUTo1MzEzNjU4NzIsSG9tZVBhZ2U6aHR0cDovL3h2aWRlby52aWRlbyxEaXNjb3JkOm51bWJlcndvbGYjODY5NCx3ZWNoYXI6bnVtYmVyd29sZjExLEJlaWppbmcsV29ya0luOkJhaWR1";
- Github: https://github.com/numberwolf
- Email(porschegt23@foxmail.com)
- QQ: 531365872
- Discord:numberwolf#8694
- 微信:numberwolf11
-
1)使用流程也可以直接看
example.js
和example.html
的Demo使用 -
2)自己直接运行Demo
-
将以下文件拷贝到http服务器下同目录访问即可
-
-
3)或者自己编译Demo
-
编译
npm start
-
访问
-
- 核心文件
文件 | 必要 | 说明 | 其他 |
---|---|---|---|
index.js | 是 | SDK入口文件 | ---- |
decoder.js | 是 | H.265解码能力 | ---- |
missile-dec.wasm | 是 | 解码WASM | ---- |
raw-parser.js | 是 | 解析265流并分割Nalu | ---- |
package.json | 否 | ---- | ---- |
package-lock.js | 否 | ---- | ---- |
- Sdk使用示例Demo文件
文件 | 说明 | 其他 |
---|---|---|
example.html | 示例Html | ---- |
example.js | 示例API使用方法JS文件 | ---- |
example-dist.js | 直接编译好的可以直接使用的js文件 | 与wasm放同一个目录 |
render-yuv420p.js | 渲染YUV420P |
这个最好自己写 这里只是一个demo |
-
将
核心文件
拷贝到你项目下同一目录 -
在你的工程文件引入 index.js
-
1)引入文件
import MissileEngineDecoder from './index';
-
2)新建H265数据解析器
var rawParserObj = new MissileEngineDecoder.CRawParser();
-
3)将H265的字节流数据
喂给解析器
// Uint8Array chunk rawParserObj.appendStreamRet(chunk);
-
4)从
解析器吐出
一帧H265 数据let nalBuf = rawParserObj.nextNalu(); // nal if (nalBuf != false) { // todo }
-
5)完整示例代码
import MissileEngineDecoder from './index'; var url265 = "res/video40_265_moov.hevc"; var rawParserObj = new MissileEngineDecoder.CRawParser(); fetch(url265).then(function(response) { let pump = function(reader) { return reader.read().then(function(result) { if (result.done) { // todo } let chunk = result.value; rawParserObj.appendStreamRet(chunk); return pump(reader); }); } return pump(response.body.getReader()); }) .catch(function(error) { console.log(error); }); for(var i = 0; i < 100; i++) { let nalBuf = rawParserObj.nextNalu(); // nal if (nalBuf != false) { // todo } }
-
1)引入文件
import MissileEngineDecoder from './index';
-
2)新建H265解码器
var token = "base64:QXV0aG9yOmNoYW5neWFubG9uZ3xudW1iZXJ3b2xmLEdpdGh1YjpodHRwczovL2dpdGh1Yi5jb20vbnVtYmVyd29sZixFbWFpbDpwb3JzY2hlZ3QyM0Bmb3htYWlsLmNvbSxRUTo1MzEzNjU4NzIsSG9tZVBhZ2U6aHR0cDovL3h2aWRlby52aWRlbyxEaXNjb3JkOm51bWJlcndvbGYjODY5NCx3ZWNoYXI6bnVtYmVyd29sZjExLEJlaWppbmcsV29ya0luOkJhaWR1"; var version = '100.1.0'; var decoderMod = null; decoderMod = new MissileEngineDecoder.CMissileDecoder(token, version);
-
3)解码器绑定回调事件 - 获取解码结果数据
-
初始化成功回调
decoderMod.initFinish = xxx
-
绑定解码成功事件
decoderMod.bindCallback(callback)
function( y, u, v, stride_y, stride_u, stride_v, width, height, pts, pix_name ) { // @TODO }
- y, u, v
- 说明:解码最终YUV数据
Uint8Array
类型
- 说明:解码最终YUV数据
- stride_y, stride_u, stride_v
- 说明:解码stride长度
int
类型
- 说明:解码stride长度
- width, height, pts
- 说明:解码图像 长、宽、时间戳(用户传入一致)
- pix_name
- 说明:解码YUV格式
- y, u, v
-
代码如下
// 解码器初始化成功事件 decoderMod.initFinish = () => { console.log("init Finshed"); // 解码结果回调 let bind_ret = decoderMod.bindCallback(function( y, u, v, stride_y, stride_u, stride_v, width, height, pts, pix_name) { console.log("======> One Frame "); console.log("======> ======> width, height, pts", width, height, pts); console.log("======> ======> pix_name", pix_name); console.log("======> ======> Y ", stride_y, y); console.log("======> ======> U ", stride_u, u); console.log("======> ======> V ", stride_v, v); }); // todo };
-
-
4)解码器初始化
初始化成功后,会调用
decoderMod.initFinish
decoderMod.initDecoder();
-
5)解码一帧数据 - 解码结果最终会通过
decoderMod.bindCallback(callback)
回调回来Uint8Array
nalBuf 一帧265数据float32
pts 时间戳毫秒数据
decoderMod.decodeNalu(nalBuf, pts);
微信 | 支付宝 | PayPal |
---|---|---|
TODO |
-
用
ffmpeg
转码一个测试H.265/HEVC的
Demo文件ffmpeg -i input265.mp4 -vcodec libx265 -an -vtag hev1 -y video40_265_moov.h265