cefsharp wpf C#监听JavaScript事件

本文介绍如何在WPF项目中使用CEFSharp控件加载百度地图,并通过CEFSharp实现C#与JavaScript之间的事件交互。具体包括如何设置地图Marker监听事件、通过JS向C#发送消息、以及C#如何监听和处理这些消息。

看官方文档比中文百度效果好太多,使用cefsharp强烈建议看官方文档,FAQ中可能就有你的问题。
最近做的一个WPF项目,嵌入cefsharp控件加载html,实现百度地图显示和交互,在地图上利用百度地图api添加了Marker,我需要点击marker执行C#的事件,marker的监听事件是JS事件,cefsharp执行事件使用函数ExecuteJavaScriptAsync,获取事件返回值使用函数EvaluateScriptAsync,可当点击marker发生的JS事件是通过事件监听实现的,而JS中addEventListener是没有返回值的,故cefsharp采用了message进行交互,html中代码如下

var point = new BMapGL.Point(longtitude, latitude);
			var myIcon = new BMapGL.Icon(url, new BMapGL.Size(10, 15));
			var marker = new BMapGL.Marker(point, {
				icon: myIcon
			});
			marker.setTitle(id);
			// 将标注添加到地图
			var infoWindow = new BMapGL.InfoWindow(id, point);
			map.addOverlay(marker);
			marker.addEventListener('click', clickListener);
			function clickListener(e) {
				if (e.target instanceof BMapGL.Marker) {
					CefSharp.PostMessage(e.target.getTitle());
				}
			}

我们只需要在每次事件发生时向cefsharp发送message就能是实现C#后台对事件的监听
C#部分代码,browser是cefsharp浏览器对象,已经进行过初始化,这两个事件会对浏览器加载和获取message进行监听

browser.JavascriptMessageReceived += OnBrowserJavascriptMessageReceived;
browser.FrameLoadEnd += OnFrameLoadEnd;
public void 
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值