当前位置: 首页 > java >正文

在winform中使用chromiumWebBrowser显示Echarts图表

首先,在项目引用中添加CefSharp,这个是谷歌的控件。

然后在form中添加一个chromiumWebBrower控件

在form初始化时,执行浏览器组件的初始化

 //浏览器组件只初始化一次,所以放在主界面
 CefSettings settings = new CefSettings();     //参数设置
 settings.CefCommandLineArgs.Add("save-image-download", "true");  // 确保开启图片下载支持
 Cef.Initialize(settings);

执行控件的初始化

       try
       {
           //加载Html
           this.webBrowser1.Load(Environment.CurrentDirectory + "\\Web\\WeldChart.html");
           //暴漏 C#方法给JavaScript调用
           this.webBrowser1.JavascriptObjectRepository.ResolveObject += (sender, e) => {
               var repo = e.ObjectRepository;
               if (e.ObjectName == "JavaScriptCallFormClass")
               {
                   repo.NameConverter = null;
                   repo.NameConverter = new CamelCaseJavascriptNameConverter();
                   repo.Register("JavaScriptCallFormClass", new JavaScriptCallFormClass(), isAsync: true, BindingOptions.DefaultBinder);
               }
           };
           //禁用右键菜单
           this.webBrowser1.MenuHandler = new DisableContextMenuHandler();
           //在webBrowser完全初始化完成后 通知启动线程
           this.webBrowser1.FrameLoadEnd += (sender, e) => {
               if (e.Frame.IsMain)
               {
                   browserInitializedEvent.Set();

                   bool isEnableBanner = false;
               }
           };
       }
       catch (Exception ex)
       {
           MessageBox.Show("页面初始化异常,请联系管理员: " + ex.Message);
       }

对控件要显示的曲线数据进行赋值

 // 将列表转换为 JSON 格式
 string xValueJson = JsonConvert.SerializeObject(xValue);
 string seatNumJson = JsonConvert.SerializeObject(seamNum);
 string currentJson = JsonConvert.SerializeObject(current);
 string voltageJson = JsonConvert.SerializeObject(voltage);
 string speedWireJson = JsonConvert.SerializeObject(speedWire);
 string airFlowJson = JsonConvert.SerializeObject(airFlow);

 // 调用 JavaScript 的 updateHourProductionChart 函数并传递数据
 webBrowser1.ExecuteScriptAsync($"updateWeldChart({xValueJson},{seatNumJson},{currentJson},{voltageJson},{speedWireJson},{airFlowJson})");

Web\\WeldChart.html里面就是Echarts的代码

<!DOCTYPE html>

<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta charset="utf-8" />
    <title>小时产量平滑折线图</title>
    <script src="../ECharts.Js/echarts.min.js"></script>
</head>
<body>
    <div id="main" style="width:100%; height:100vh;"></div>
    <script>
        var chartDom = document.getElementById('main');
        var weldChart = echarts.init(chartDom);
        var option;

        const colors = ['#FF3333', '#91CC75', '#33ffec', '#ff33da', '#2E2676'];
        option = {
            tooltip: {
                trigger: 'axis',
                position: function (pt) {
                    return [pt[0], '10%'];
                }
            },

http://www.xdnf.cn/news/2419.html

相关文章:

  • 【RabbitMQ】保证消息不丢失
  • 汽车网络安全 -- 理解暴露面、攻击面和攻击向量
  • 极狐GitLab 议题权重有什么作用?
  • 编译流程、make命令与nccl-test中的Makefile解析
  • 【Spark入门】Spark简介:分布式计算框架的演进与定位
  • C++?动态内存管理!!!
  • 云计算赋能质检LIMS的价值 质检LIMS系统在云计算企业的创新应用
  • Unity3D Cinemachine 高级应用指南
  • PyDantic入门介绍:Python数据验证与解析的利器
  • 57页PPT|非结构化数据管理方案:从顶层设计到应用实践的系统方法论
  • AVL树的介绍与学习
  • 技能点总结
  • X11安装备忘
  • arcpy列表函数的应用(4)
  • 超参数详解:从基础概念到优化策略的全面指南
  • 大学之大:索邦大学2025.4.27
  • Linux的权限
  • RISC-V MCU定时器架构与低功耗设计
  • Redis ssd是什么?Redis 内存空间优化的点都有哪些?embstr 和 row、intset、ziplist分别是什么?
  • 区块链:去中心化应用(DApp)开发全流程解析
  • 区块链基石解码:分布式账本的运行奥秘与技术架构
  • Java 深度与实战 · 每日一读 :高频面试真题解析 · ReentrantLock / CAS / AQS 篇
  • 智慧水库与AI深度融合的实现方案及典型应用场景
  • CREATION OF UNIVERSES FROM NOTHING
  • 练习普通话,声音细柔和
  • Spring Boot配置中YAML文档结构的理解
  • Nacos-SpringBoot 配置无法自动刷新问题排查
  • React自定义Hook之useMutilpleRef
  • CD33.【C++ Dev】初识模版
  • 深度学习4.1 多层感知机