C#中WebView2调用与交互实现

server/2024/9/24 6:27:32/

简要说明:

此控件实际上是 [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.ppmy.cn/server/95614.html

相关文章

J029_UDP通信

一、需求描述 实现UDP的通信 1.1 一发一收 1.1.1 ClientTest1 package com.itheima.udp;import java.net.*;import static java.net.InetAddress.*;//完成udp通信快速入门&#xff0c;实现一收一发 public class ClientTest1 {public static void main(String[] args) thro…

vue实现歌词滚动效果

1.结构 <template><div class"lyricScroll"><div class"audio"><audio id"audio" src"./common/周传雄-青花1.mp3" controls></audio></div><div class"container" id"contai…

GPT-4o mini一手测评:懂得不多,但答得极快

在性能方面,GPT-4o mini 在 MMLU 上的得分为 82%,在 LMSYS 排行榜的聊天方面分数优于 GPT-4。 OpenAI 突然上线新模型 GPT-4o mini, 声称要全面取代 GPT-3.5 Turbo。 在性能方面,GPT-4o mini 在 MMLU 上的得分为 82%,在 LMSYS 排行榜的聊天方面分数优于 GPT-4。 在价格…

太坑了!RabbitMQ+PHP开发的辛酸经历

博主介绍&#xff1a;全网粉丝10w、CSDN合伙人、华为云特邀云享专家&#xff0c;阿里云专家博主、星级博主&#xff0c;51cto明日之星&#xff0c;热爱技术和分享、专注于Java技术领域 &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅…

《Unity3D网络游戏实战》学习与实践--制作一款大乱斗游戏

角色类 基类Base Human是基础的角色类&#xff0c;它处理“操控角色”和“同步角色”的一些共有功能&#xff1b;CtrlHuman类代表“操控角色”​&#xff0c;它在BaseHuman类的基础上处理鼠标操控功能&#xff1b;SyncHuman类是“同步角色”类&#xff0c;它也继承自BaseHuman&…

计时器(Python)

代码 import time from tkinter import ttk import threading from tkinter import scrolledtext import tkinter as tkclass TimerApp:def __init__(self, root):self.root rootself.root.title("计时器")self.screen_w, self.screen_h self.root.winfo_screenwi…

Mybatis面试

Mybatis 面试 1、Mybatis 的执行流程是什么&#xff1f; 1、读取MyBatis配置文件&#xff1a;mybatis-config.xml 加载运行环境 和 映射文件 2、构造会话工厂 SqlSessionFactory &#xff08;全局只有一个&#xff09; 3、会话工厂创建SqlSession对象&#xff08;项目与数据…

【c++】爬虫到底违不违法?

很多小伙伴都想知道爬虫到底违法吗&#xff0c;今天博主就给大家科普一下 爬虫本身并不违法&#xff0c;但使用爬虫采集数据可能涉及违法风险&#xff0c;具体取决于采集行为是否侵犯了他人的合法权益&#xff0c;尤其是隐私权和个人信息权。以下是对爬虫是否违法的详细分析&am…