C#中WebView2调用与交互实现

news2024/12/27 13:07:11

简要说明:

此控件实际上是 [WebView2 COM API] (https://aka.ms/webview2) 的包装器。
 可以通过访问 Microsoft.Web.WebView2.Wpf.WebView2.CoreWebView2 属性来直接访问基础 ICoreWebView2 接口及其所有功能。
一些最常见的 COM 功能也可以通过控件上的包装器方法/属性/事件直接访问。创建时,控件的 Microsoft.Web.WebView2.Wpf.WebView2.CoreWebView2 属性将为 null。
  这是因为创建 Microsoft.Web.WebView2.Wpf.WebView2.CoreWebView2 是一项成本高昂的操作,涉及启动 Edge 浏览器进程等操作。
  有两种方法可以导致创建

注意:这里使用的是WPF的框架,版本是.NET Framework 4.6

一、效果展示

1、传递数据

2、调用弹窗

3、回传信息

二、实现代码

1、包引用

2、界面添加

3、事件关联与初始化

    private async void RecvMsg_Loaded(object sender, RoutedEventArgs e)
    {
        InitializeComponent();
        await webView.EnsureCoreWebView2Async(null);

        webView.Source = new Uri(AppDomain.CurrentDomain.BaseDirectory + "ChartFile\\ContourLineChart.html");
        webView.CoreWebView2.WebMessageReceived += WebView_WebMessageReceived;
    }

    private void WebView_WebMessageReceived(object sender, Microsoft.Web.WebView2.Core.CoreWebView2WebMessageReceivedEventArgs e)
    {
        Console.WriteLine("WebView_WebMessageReceived:"+e.WebMessageAsJson);
     //  var p= JsonConvert.DeserializeObject<Preson>(e.WebMessageAsJson);
    }

需要注意,消息接收事件注册需要在控件初始化完成后,不然对象为空,会报错。JavaScript传递参数时,会默认序列化对象,对于传递对象数据时,C#层面接收后可以直接进行反序列化成对象,这样后序操作更加友好。当然怎么设计传递参数和怎么使用,需要使用者结合实际情况进行合理设计。

4、数据传递调用

1)、序列方式数据

   para = "jsUpdateROIData(true,0,33937.536,true,0,33937.536," +
       "true,[0.0,0.0,0.0,0.0],true,[0.0,0.0,0.0,0.0]," +
       "false,0,0,0,0,false,0,0,0,0,true)";

    webView.ExecuteScriptAsync(para);

2)、单个数据方式

 public void ExeCall2(int num1, int num2)
 {
     string para = $"calAdd({num1},{num2})";
     webView.Dispatcher.Invoke(Process);

     void Process()
     {
         var r = webView.ExecuteScriptAsync(para);
         r.ContinueWith(t =>
         {
             Console.WriteLine("执行结果2:" + t.Result);
         });
     }
 }

5、后台Html文件

1)、数据显示函数

 function jsUpdateROIData(isShowRoi1, dValueRoi1, zValueRoi1, isShowRoi2, dValueRoi2, zValueRoi2,
            flagroi1, Param1, flagroi2, Param2,
            isShowLine1, Line1x1, Line1y1, Line1x2, Line1y2, isShowLine2, Line2x1, Line2y1, Line2x2, Line2y2, isShowMarkArea) {

            option.series[1].data = null;
            option.series[2].data = null;

            ShowRoi1ResultPoint(isShowRoi1, dValueRoi1, zValueRoi1);
            ShowRoi2ResultPoint(isShowRoi2, dValueRoi2, zValueRoi2);
            SetROiPoint(flagroi1, Param1, flagroi2, Param2);
            ShowRoi1ResultLine(isShowLine1, Line1x1, Line1y1, Line1x2, Line1y2);
            ShowRoi2ResultLine(isShowLine2, Line2x1, Line2y1, Line2x2, Line2y2);
            ShowMarkArea(isShowMarkArea);

        }

2)、交互函数

function calAdd(num1, num2) {
            var result = num1 + num2;
            alert("传入参数 num1=" + num1 + ",num2=" + num2 + " num1+num2= " + result);
            return result;
        }

3)、消息发送函数

function SendMessage(msg) {

            window.chrome.webview.postMessage(msg);
        }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1972132.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

解决k8s flannel网络插件国内镜像docker拉取不到问题

一、准备下载资源 https://download.csdn.net/download/weixin_43205308/89608560 以下&#xff0c;每个k8s节点都要执行 二、载入镜像 解压上面的下载资源的文件夹后&#xff0c;会有图中的两个资源 载入资源 docker load --input flannel-flannel-v0.25.1-amd64.tar.gzd…

59在Linux中加docker中加mysql,tomcat,redis

一、引言 1.1 环境不一致 我本地运行没问题啊&#xff1a;由于环境不一致&#xff0c;导致相同的程序&#xff0c;运行结果却不一致。 1.2 隔离性 哪个哥们又写死循环了&#xff0c;怎么这么卡&#xff1a;在多用户的操作系统下&#xff0c;会因为其他用户的操作失误影响到你自…

基于STM32的智能家居控制系统教程

目录 引言环境准备智能家居控制系统基础代码实现&#xff1a;实现智能家居控制系统 照明控制模块温度与湿度监控模块安防监控模块用户界面与远程控制应用场景&#xff1a;智能家居优化常见问题与解决方案收尾与总结 引言 随着物联网技术的发展&#xff0c;智能家居控制系统变…

libvir服务机制与通信原理

libvir服务机制 前言 libvirt服务机制是一个复杂的结构&#xff0c;里面包含了event事件&#xff0c;rpc网络通信&#xff0c;线程池以及相关的job机制&#xff0c;哪一个单拿出来都是一个复杂的模型结构&#xff0c;更何况libvirt服务是这几个机制之间相互协作的复杂结构&…

【数据结构】——二叉树OJ题

文章目录 前言1. 单值二叉树2. 检查两颗树是否相同3. 判断一棵树是否为另一颗树的子树4. 对称二叉树5. 平衡二叉树6. 二叉树的前序遍历7. 二叉树的中序遍历8. 二叉树的后序遍历9. 二叉树的构建及遍历 前言 我们先想想二叉树我们学习了哪些内容再来做题哈 其实学习二叉树重要的…

JavaScript (十四)——JavaScript typeof和类型转换

目录 JavaScript typeof, null, 和 undefined typeof 操作符 null undefined undefined 和 null 的区别 JavaScript 类型转换 JavaScript 数据类型 JavaScript 类型转换 将数字转换为字符串 将布尔值转换为字符串 将日期转换为字符串 将字符串转换为数字 一元运算符…

新浪微博笔试秋招管培笔试测评肯耐珂萨题型题库解析

新浪微博的笔试是该公司用于筛选潜在候选人的重要环节&#xff0c;主要目的在于评估应聘者的逻辑推理、图表计算和文字理解能力。以下是新浪微博笔试题型的详细解析&#xff1a; 1. 逻辑推理 - **题型概述**&#xff1a;逻辑推理部分通常包含20题&#xff0c;考察应试者的逻…

算法板子:树形DP、树的DFS——树的重心

思想&#xff1a; 代码&#xff1a; #include <iostream> #include <cstring> using namespace std;const int N 1e5 10;// vis标记当前节点是否被访问过; vis[1]true代表编号为1的节点被访问过 bool vis[N]; // h数组为邻接表; h数组上的每个坑位都串了一个单链…

商业购物中心开业活动方案怎么写?附230个案例

商业购物中心开业活动方案的撰写是一个综合性的过程&#xff0c;需要结合购物中心的特点、目标消费群体、市场环境以及活动目的等多方面因素进行考虑。 以下是一个详细的撰写指南&#xff0c;带你一步步了解如何撰写一个成功的商业购物中心开业活动方案。 码字不易&#xff0…

处理kkFileView的com.aspose:aspose-cad:iar:23.9 not found 问题

背景: 一款很强大的开源的文件预览工具包下载地址:aspose-cad-23.9.jar 启动成功界面: 一、.问题描述:com.aspose:aspose-cad:iar:23.9 not found 处理方案:直接下载aspose-cad-23.9.jar 安装到本地 二、处理步骤(win环境):1.安装maven 下载地址:https://maven.apach…

CSP-J 复赛 模拟题

1.生产计划&#xff1a; 样例 #1 样例输入 #1 2 4 5 6 12 1 3 6 15 8 1 3 100 3 200 4 300 6 100 样例输出 #1 YES NO 2.分组和为3&#xff1a; 样 例 # 1 样 例 输 入 # 1 5 1 1 1 2 1 样 例 输 出 # 1 2 样 例 # 2 样 例 输 入 # 2 7 2 2 1 1 2 1 1 样 例 输 出 # …

2024最简七步完成 将本地项目提交到github仓库方法

2024最简七步完成 将本地项目提交到github仓库方法 文章目录 2024最简七步完成 将本地项目提交到github仓库方法一、前言二、具体步骤1、github仓库创建2、将远程仓库拉取并合并&#xff08;1&#xff09;初始化本地仓库&#xff08;2&#xff09;本地仓库与Github仓库关联&…

Linux驱动开发—并发与竞争,原子操作,自旋锁,信号量详解

1.并发与并行的概念 并发是指在同一时间段内&#xff0c;多个任务交替执行。并发可以发生在单核处理器上&#xff0c;通过任务切换实现 并行是指在同一时间段内&#xff0c;多个任务同时执行。并行可以发生在多核处理器上&#xff0c;例如下图任务1 和任务3同时进行&#xff0…

JAVA基础知识点3 (String 和 StringBuffer 以及 StringBuilder 的特点以及区别)

1&#xff0c;String 和 StringBuffer 以及 StringBuilder 的特点 &#xff08;1&#xff09;String的特点&#xff1a;String是final修饰的字符序列是不可改变的&#xff0c; 是字符串常量&#xff0c;一旦初始化就不可以被更改,因此是线程安全的 因为是常量每次对其操作都会…

C++必修:STL之vector的模拟实现

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ &#x1f388;&#x1f388;养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; 所属专栏&#xff1a;C学习 贝蒂的主页&#xff1a;Betty’s blog 为了让我们更加深入理解vector&#xff0c;接下来我们将模拟实现一个简易版的vect…

龙迅#LT8918适用于TTL/LVDS转MIPIDSI/CSI应用方案,分辨率高达1080P@60HZ,可提供技术支持!

1. 描述 Lontium LT8918 是一款高性能 MIPIDSI/CSI-2 发射器&#xff0c;适用于移动显示面板或相机应用。 LT8918 的 TTL 输入在 SDR 或 DDR 采样下支持 24 位 RGB 和 BT656/1120 视频格式。最大输入像素时钟频率为 SDR 148.5MHz 或 DDR 74.25MHz&#xff0c;适用于1080P60Hz高…

PCL从理解到应用【08】 点云特征 | 法线估计 | 主曲率估计

前言 在PCL中&#xff0c;有多种方法和函数可以用来提取点云特征&#xff0c;本文介绍几何特征。 其中&#xff0c;几何特征主要包括法线估计和主曲率估计。 这些特征能够描述点云表面的几何形状&#xff0c;常用于进一步的点云处理和分析&#xff0c;如配准、分割和物体识别…

为什么 Kubernetes 是现代开发的必备工具

引言 在现代软件开发中&#xff0c;容器已经成为打包和运行应用程序的标准方式。然而&#xff0c;在生产环境中&#xff0c;管理这些运行中的容器并确保服务的高可用性和稳定性并不是一件容易的事。比如&#xff0c;当一个容器发生故障时&#xff0c;需要快速启动另一个容器来代…

C++ std::atomic和std::mutex

C11 引入了两个重要的同步机制用于多线程编程&#xff1a;std::atomic 和 std::mutex。它们各自适用于不同的并发控制需求&#xff0c;并在实现和使用上有很大的不同。 1. 目的和用途 std::atomic: 设计目的&#xff1a;为原子操作提供支持&#xff0c;保证对变量的操作&#…

Python试讲

Python试讲 导语Python简介Python及其特点如何使用Python Python与计算计算变量 导语 本次试讲内容如下&#xff1a;Python简介与使用&#xff0c;Python与基本运算 辅助教材为 《趣学Python编程》和《Python编程从入门到实践》 Python简介 Python是目前入门最简单最好学的…