初识 HTML5 Video Blob

初识 HTML5 Video Blob,第1张

为何会有一个 blob?直接点击这个链接,返回了 404!什么情况?于是对此做了一番探索。

The following simple example loads a video chunk by chunk as fast as possible, playing it as soon as it can. This example was written by Nick Desaulniers and can be viewed live here .

首先创建变量名为 video 的 DOM 对象和变量名为 mediaSource 的 MediaSource 对象。通过函数 createObjectURL 来将 DOM::video 对象的属性 src 和 mediaSource 进行“连接”。接下来,通过注册事件 Event::sourceopen 来触发当上述“连接”结束之后的回调处理。回调处理就是需要赋值 视频数据 的地方。 调用 MediaSource::addSourceBuffer 方法来构建一个存放视频数据的 sourceBuffer。 在往 sourceBuffer 中存放数据结束之后会触发事件 Event::updateend 。通过注册这个事件的回调,可以知晓数据已经加载完毕,然后关闭数据流,调用 Video::play 函数通知浏览器播放视频。至此,整个 Blob 运行机制讲解完毕。

W3C 上有明确关于 MediaSource 扩展接口的文档。扩展文档中是这么定义的, 它允许 JS 脚本动态构建媒体流和允许 JS 传送媒体块到 H5 媒体元素。这种接口的应用可以让 H5 播放器实现持续添加数据进行播放。

综上,这个只是 HTML5 提供的新特性,但是截止目前还是处于试验状态。

在上面示例中使用的视频格式不是普通的 MP4 而是 FMP4 。如果没有注意到这个问题,就可能造成:

HTML5 MediaSource works with some mp4 files and not with others (same codecs)。

解决方案:

It works fine if mp4 is fragmented.

You can do that using Bento4's mp4fragment tool.

这种事情,需要分成两步来做。

首先在JSP中,生成img标签,类似:

<img src="/showImage?id=111111111" width="48" height="48" border="0"/>

其次是写一个Servlet(或JSP),可以通过指定的ID查询到图片的Blob字段信息;

先设置response的contentType为图片类型,如: image/JPEG image/PNG 等;

然后用response.getOutputStream(),将图片信息全部写入输出流中。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/7662766.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-08
下一篇 2023-04-08

发表评论

登录后才能评论

评论列表(0条)

保存