首页 web前端 css教程 如何用JavaScript高效生成基于ECharts图表的高清视频或GIF动画?

如何用JavaScript高效生成基于ECharts图表的高清视频或GIF动画?

Apr 05, 2025 pm 04:12 PM
css 解决方法

基于echarts图表生成高清晰度视频的方法

本文将探讨如何将基于echarts生成的动态图表(例如支持动态排序的柱状图)转化为高清晰度的视频。直接使用屏幕录制软件往往会造成视频清晰度不足的问题,而echarts使用canvas或svg渲染,这为我们提供了提升清晰度的机会。

问题在于如何利用echarts的canvas渲染特性直接生成视频,而不是依赖屏幕录制。解决方法是使用javascript库来实现视频录制功能。

一种方法是使用recordrtc.js插件。该插件结合html2canvas,可以将canvas内容录制成视频。 需要引入recordrtc.js和html2canvas.js这两个插件。以下代码片段展示了如何使用recordrtc.js将echarts图表录制成mp4视频:




    <meta charset="utf-8">
    <meta http-equiv="x-ua-compatible" content="ie=edge,chrome=1">
    <meta name="renderer" content="webkit">
    <title>echarts to video</title>
    <style>
        html,body,#mycanvas{
            height: 100%;
            width: 100%;
            padding: 0;
            margin: 0;
        }
    </style>



    <div id="mycanvas"></div>
    <script type="text/javascript" src="https://cdn.bootcss.com/echarts/4.7.0/echarts-en.min.js"></script>
    <script src="https://cdn.bootcss.com/html2canvas/0.5.0-beta4/html2canvas.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/recordrtc/5.5.9/recordrtc.js"></script>
    <script src="https://cdn.bootcss.com/filesaver.js/1.3.8/filesaver.min.js"></script>
    <script>
        let $parent = document.getelementbyid('mycanvas')
        let mychart = echarts.init($parent);
        //这里的option就是echrts案例中的option,代码太多,就不贴了
        mychart.setoption(option);
        
        settimeout(function(){
            //开始录制
            exporttovideo(5000)
        },500)
        
        function exporttovideo(time){
            //time 为录制时长 毫秒
            time = time || 0
            
            let $canvas = document.queryselector('#mycanvas canvas')
            
            var recordrtc = recordrtc($canvas, {
                type: 'canvas'
            });
            //开始录制
            recordrtc.startrecording();
            
            settimeout(function(){
                //录制结束
                recordrtc.stoprecording(function(videourl) {
                    console.log(videourl)
                
                    var recordedblob = recordrtc.getblob();
                    //recordrtc.getdataurl(function(dataurl) { });
                    saveas(recordedblob, "test.mp4");
                });
            }, time)
        }
    </script>


登录后复制

如果需要生成gif动画,可以使用gif.js插件。 需要引入gif.js插件。代码片段如下:




    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="renderer" content="webkit">
    <title>echarts to gif</title>
    <style>
        html,body,#myCanvas{
            height: 100%;
            width: 100%;
            padding: 0;
            margin: 0;
        }
    </style>



    <div id="myCanvas"></div>
    <script type="text/javascript" src="https://cdn.bootcss.com/echarts/4.7.0/echarts-en.min.js"></script>
    <script type="text/javascript" src="https://cdn.bootcss.com/gif.js/0.2.0/gif.js"></script>
    <script src="https://cdn.bootcss.com/FileSaver.js/1.3.8/FileSaver.min.js"></script>
    <script>
        let $parent = document.getElementById('myCanvas')
        let myChart = echarts.init($parent);

        //这里的option就是echrts案例中的option,代码太多,就不贴了
        myChart.setOption( option );
        
        setTimeout(function(){
            //开始录制gif
            exportToGif(5000)
        }, 20)
        
        function exportToGif(time){
            var start = Date.now()
            //time 为录制时长 毫秒
            time = time || 0
            
            let $canvas = document.querySelector('#myCanvas canvas')
            
            function loop(){
                window.requestAnimationFrame(function(){
                    gif.addFrame($canvas, {delay: 100});
                    if(Date.now() - start >= time){
                        gif.render();
                    }else{
                        loop()
                    }
                })
            }
            
            var gif = new GIF({
              workers: 2,
              quality: 10
            });
            
            gif.on('finished', function(blob) {
                  saveAs(blob, "test.gif");
            });
            
            loop()
        }
    </script>


登录后复制

这些代码片段展示了如何使用相应的javascript库来录制视频或gif,从而避免了屏幕录制带来的清晰度问题。 记住,需要根据实际情况调整录制时长以及gif的帧率和质量参数。

以上是如何用JavaScript高效生成基于ECharts图表的高清视频或GIF动画?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

HTML:结构,CSS:样式,JavaScript:行为 HTML:结构,CSS:样式,JavaScript:行为 Apr 18, 2025 am 12:09 AM

HTML、CSS和JavaScript在Web开发中的作用分别是:1.HTML定义网页结构,2.CSS控制网页样式,3.JavaScript添加动态行为。它们共同构建了现代网站的框架、美观和交互性。

公司安全软件导致应用无法运行?如何排查和解决? 公司安全软件导致应用无法运行?如何排查和解决? Apr 19, 2025 pm 04:51 PM

公司安全软件导致部分应用无法正常运行的排查与解决方法许多公司为了保障内部网络安全,会部署安全软件。...

解决 Craft CMS 中的缓存问题:使用 wiejeben/craft-laravel-mix 插件 解决 Craft CMS 中的缓存问题:使用 wiejeben/craft-laravel-mix 插件 Apr 18, 2025 am 09:24 AM

在使用CraftCMS开发网站时,常常会遇到资源文件缓存的问题,特别是当你频繁更新CSS和JavaScript文件时,旧版本的文件可能仍然被浏览器缓存,导致用户无法及时看到最新的更改。这个问题不仅影响用户体验,还会增加开发和调试的难度。最近,我在项目中遇到了类似的困扰,经过一番探索,我找到了wiejeben/craft-laravel-mix这个插件,它完美地解决了我的缓存问题。

如何优化网站性能:使用Minify库的经验与教训 如何优化网站性能:使用Minify库的经验与教训 Apr 17, 2025 pm 11:18 PM

在开发网站的过程中,提升页面加载速度一直是我的首要任务之一。曾经,我尝试使用Minify库来压缩和合并CSS及JavaScript文件,以期提升网站的性能。然而,使用过程中遇到了不少问题和挑战,最终让我意识到Minify可能不再是最佳选择。下面我将分享我的使用经验,以及如何通过Composer安装和使用Minify的过程。

如何利用 Composer 简化 CMS 开发:Lebenlabs/SimpleCMS 库的实践应用 如何利用 Composer 简化 CMS 开发:Lebenlabs/SimpleCMS 库的实践应用 Apr 18, 2025 am 09:45 AM

在开发一个新的内容管理系统(CMS)时,我遇到了一个常见但棘手的问题:如何在不增加过多复杂性的情况下,快速搭建一个功能齐全的CMS。市面上有许多现成的CMS解决方案,但它们通常过于庞大,配置复杂,对于小型项目来说可能是一种负担。经过一番探索,我发现了lebenlabs/simplecms这个库,它通过Composer提供了一种简洁而高效的解决方案。

HTML与CSS和JavaScript:比较Web技术 HTML与CSS和JavaScript:比较Web技术 Apr 23, 2025 am 12:05 AM

HTML、CSS和JavaScript是构建现代网页的核心技术:1.HTML定义网页结构,2.CSS负责网页外观,3.JavaScript提供网页动态和交互性,它们共同作用,打造出用户体验良好的网站。

sublime怎么生成html sublime怎么生成html Apr 16, 2025 am 09:03 AM

在 Sublime Text 中生成 HTML 代码有两种方法:使用 Emmet 插件,可通过输入缩写并按 Tab 键生成 HTML 元素,或使用预定义的 HTML 文件模板,可提供基本的 HTML 结构和其他功能,如代码片段、自动完成功能和 Emmet Snippets。

See all articles