Avalonia跨平台入门第二十一篇之玩耍CEF

本文介绍了如何使用CEF(Chromium Embedded Framework)在Windows应用中加载网页,重点展示了加载高德地图的实际操作步骤,并提供了GitHub链接。通过CefSettings配置,实现了后台加载和窗口无边框渲染。后续计划探索更复杂功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在前面分享的几篇中咱已经玩耍了PopupListBox多选Grid动态分RadioButton模板控件的拖放效果控件的置顶和置底控件的锁定自定义Window样式动画效果Expander控件ListBox折叠列表聊天窗口ListBox图片消息窗口抖动语音发送语音播放语音播放问题;今晚接着研究CEF去加载网页,下面是加载高德地图效果:

f3fc0b040000274d3ab95b14d91cce67.gif

直接上GitHub的地址:

https://github.com/CefNet/CefNet

1、在入口进行初始化设置:

var settings = new CefSettings();
settings.MultiThreadedMessageLoop = !externalMessagePump;
settings.ExternalMessagePump = externalMessagePump;
settings.NoSandbox = true;
settings.WindowlessRenderingEnabled = true;
settings.LocalesDirPath = Path.Combine(cefPath, "Resources", "locales");
settings.ResourcesDirPath = Path.Combine(cefPath, "Resources");
settings.LogSeverity = CefLogSeverity.Warning;
settings.IgnoreCertificateErrors = true;
settings.UncaughtExceptionStackSize = 8;

2、我直接后台加载测试的:

private void GoToLoadMap() 
{
  string initUrl = "file:///" + AppDomain.CurrentDomain.BaseDirectory + @"Maps/HeatMap.html";
  WebView webView = new WebView();
  webView.InitialUrl = initUrl;
  RootGrid.Children.Add(webView);
}

3、去下载Chromium Embedded Framework:

https://cef-builds.spotifycdn.com/index.html

4、关于配置

Extract all files into the cef/ directory.
Copy cef/Resources/icudtl.dat into cef/Release/

最终简单的效果先这样吧a8e10bd25030e482a1477322d6fca8fd.png;以后有时间的话,可以再去摸索一下更复杂的效果0b599caffbac2d03c52a47420c8b5d39.png;编程不息、Bug不止、无Bug、无生活6eb77a6446ff6d3bc2e9b75ff76d8cbd.png;改bug的冷静、编码的激情、完成后的喜悦、挖坑的激动 、填坑的兴奋;这也许就是屌丝程序员的乐趣吧;今天就到这里吧;希望自己有动力一步一步坚持下去;生命不息,代码不止;大家抽空可以看看今天分享的效果,有好的意见和想法,可以在留言板随意留言;我看到后会第一时间回复大家,多谢大家的一直默默的关注和支持!如果觉得不错,那就伸出您的小手点个赞并关注一下,多谢您的支持!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值