热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

将html5动画录制到视频-无需人工干预

如何解决《将html5动画录制到视频-无需人工干预》经验,为你挑选了1个好方法。

我有一个大问题:如何在没有人工干预的情况下录制HTML5动画到视频? 我们正在寻找开放/源代码甚至是专有解决方案.

用例:

我们想要开始一个我们将创建Html5动画的项目.动画将是一个简短的技术演示(2-5分钟),将包括所有类型的动画:线条,图表,区域.它还将有一个音轨.

要生成动画,我们将使用不同的JS库:

http://highcharts.com

http://raphaeljs.com

http://greensock.com

......还有其他的

我们需要能够录制这个动画并将其保存为mp4视频或同等视频.

最大的问题是:如何做到?

我看到两个选项:

    用PhantomJs记录下来

根据我的研究,FPS几乎无法控制.我跑了几次测试,效果不是很好.Greensock时间表可能有所帮助,但我们需要灵活使用我们使用的JS库.

    在浏览器中播放并使用某些工具进行录制

如果我们能够实现自动化,这将是非常棒的.

提前致谢!

我的研究中使用的参考文献

https://groups.google.com/forum/#!msg/phantomjs/wluVGGjhL90/oGBXqh7QP44J

http://mindthecode.com/recording-a-website-with-phantomjs-and-ffmpeg

http://www.ultramegatech.com/2010/09/record-html-canvas-animations-to-video/

http://www.tweetbeam.com/blog/generating-facebook-lookback-style-dynamic-videos-html5-using-phantomjs-ffmpeg/

klodoma.. 7

我已经创建/找到了解决这个问题的方法.有些人已经提到xvfb是答案,是的.

我创建了一个docker容器,它预装了xvfb,google chrome和ffmpeg,nodejs.

我使用nodejs和chrome-remote-interface与浏览器进行通信.

实际上我执行以下步骤:

    启动docker容器.

    开始镀铬(尽可能无头)

    使用chrome-remote-interface连接到chrome

    打开动画网址

    准备动画网页通知nodejs(通过控制台)动画准备就绪,从节点开始ffmpeg和浏览器中的动画.

    处理视频

由于许可证问题,我无法发布整个代码,但我可以粘贴部分代码.

如果有人有疑问,请告诉我.



1> klodoma..:

我已经创建/找到了解决这个问题的方法.有些人已经提到xvfb是答案,是的.

我创建了一个docker容器,它预装了xvfb,google chrome和ffmpeg,nodejs.

我使用nodejs和chrome-remote-interface与浏览器进行通信.

实际上我执行以下步骤:

    启动docker容器.

    开始镀铬(尽可能无头)

    使用chrome-remote-interface连接到chrome

    打开动画网址

    准备动画网页通知nodejs(通过控制台)动画准备就绪,从节点开始ffmpeg和浏览器中的动画.

    处理视频

由于许可证问题,我无法发布整个代码,但我可以粘贴部分代码.

如果有人有疑问,请告诉我.


推荐阅读
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
  • 新版本在线体验地点已上线,迎接体验?—2017-01-14喜好就Star,不只是Fork;想要分享的结果才是驱动力,而手艺仅仅是一种要领。TP-adminTP-admin即基于Th ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • 本文介绍了绕过WAF的XSS检测机制的方法,包括确定payload结构、测试和混淆。同时提出了一种构建XSS payload的方法,该payload与安全机制使用的正则表达式不匹配。通过清理用户输入、转义输出、使用文档对象模型(DOM)接收器和源、实施适当的跨域资源共享(CORS)策略和其他安全策略,可以有效阻止XSS漏洞。但是,WAF或自定义过滤器仍然被广泛使用来增加安全性。本文的方法可以绕过这种安全机制,构建与正则表达式不匹配的XSS payload。 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • 第8章 使用外部和内部链接
    8.1使用web地址LearnAboutafricanelephants. ... [详细]
  • Vue基础一、什么是Vue1.1概念Vue(读音vjuː,类似于view)是一套用于构建用户界面的渐进式JavaScript框架,与其它大型框架不 ... [详细]
  • javascript – 关于微信浏览器的疑问
    后端开发|php教程php,javascript,html5后端开发-php教程现在正在开发移动端webapp,遇到了比较麻烦的问题:用户输入帐号密码登陆后,自动跳转到首页,,QQ ... [详细]
  •   html5与js,  本文介绍html5shiv.js和respond.min.js与大家分享,如下:  做 ... [详细]
  • Iamtryingtoachievethearrowpointingupwards..iamtryingtoachieveitinmycssiamnotabl ... [详细]
  • HTML5-web通信之 Cross-Document Messaging(XDM) & Channel Messaging
    在学习跨域,转载几篇好的博客,以后有深刻理解再自己总结吧。HTML5web通信(跨文档通信通道通信)简介byzhangxinxufromhttp:www.zhang ... [详细]
  • js中运行机制的详细分析(示例解析)
    web前端|js教程node.js,html5,html,css,javascriptweb前端-js教程本篇文章给大家带来的内容是关于js中运行机制的详细分析(示例解析),有一定 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
author-avatar
放逐凌晨_690
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有