百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

Cefsharp 的使用(几行代码写个浏览器)

csdh11 2025-02-10 11:57 22 浏览

一、使用工具

VS2022-Winform(.NET Framework 4.7.2)、CefSharp.WinForms(谷歌浏览器开源组件)、TinyMCE

二、实现步骤

1. 安装依赖组件CefSharp.WinForms

① 打开VS2022--顶部菜单“工具”--“NuGet包管理器”--“管理解决方案的NuGet程序包”。

② 搜索“CefSharp.WinForms”,并安装,步骤如下图。

③ 在Winform设计界面,拖拽ChromiumWebBrowser组件到窗口,步骤如下图。

2. 把下载的Tiny-MCE文件夹放到项目根目录(同.sln同目录)

这里以文件夹“@tinymce”为例,把案例的sample.html改成index.html放到@tinymce里面。

3. 编写实现的C#代码。

目标是:前端能调用C#方法,交互传值;既可以使用C#弹窗,也可以使用JS弹窗。

① 配置CefSharp显示的网页位置,并注册JS调用C#的对象JsObj。

注意:指定html位置的时候,如果在配置管理器修改了参数(比如x64改x86),可能导致调试时无法通过如下方法获取index.html文件的正确路径,可以删除一个“.Parent"再试,也可以用MessageBox.Show(url)打印路径确认文件位置是否正确。

public Form1()
{
	InitBrowser();
	InitializeComponent();
	this.StartPosition = FormStartPosition.CenterScreen; // 设置窗体居中
}
public ChromiumWebBrowser browser;
public void InitBrowser()
{
	CefSettings settings = new CefSettings();
	CefSharp.Cef.Initialize(settings);

	//指定html位置。注意:如果在配置管理器修改了参数(比如x64),可能导致调试时无法通过如下方法获取index.html文件的正确路径,可以删除一个“.Parent"再试,也可以用MessageBox.Show(url)打印路径确认文件位置是否正确。
	string path = Directory.GetParent(Directory.GetCurrentDirectory()).Parent.Parent.FullName + @"\@tinymce\index.html";  // 这里注意parent搭配获取目录的方法,index.html是放在项目sln文件同目录内@tiny_mce文件夹里面的。
	// string path = Path.GetFullPath("D:\\GitHub\\WindowsFormsApp4\\@tinymce\\index.html");
	string url = "file://" + path;
	// MessageBox.Show(url);
	browser = new ChromiumWebBrowser(url.ToString());

	browser.Dock = DockStyle.Fill;  // 铺满
	this.Controls.Add(browser);

	// 注册JsObj对象,实现JS调用C#
	CefSharpSettings.WcfEnabled = true;
	browser.JavascriptObjectRepository.Settings.LegacyBindingEnabled = true;  // 允许调用JS函数调用后端代码
	browser.JavascriptObjectRepository.Register("JsObj", new getWinFormData(browser, this), isAsync: false, options: BindingOptions.DefaultBinder);
}
private void Form1_FormClosing(object sender, FormClosingEventArgs e)
{
	CefSharp.Cef.Shutdown();
}

② 编写C#方法,用以前端JS调用。

// 自定义类(JS调用C#)
public class getWinFormData
{
	private static ChromiumWebBrowser chromiumWebBrowser;
	private static Form1 form1;

	private int myId = 2;
	private String text_str = "首发知乎";
	private String startTime = "2023-05-10";

	// 构造方法
	public getWinFormData(ChromiumWebBrowser OriginachromiumWebBrowser, Form1 Originaform1)
	{
		chromiumWebBrowser = OriginachromiumWebBrowser;
		form1 = Originaform1;
	}
	// 窗口加载完毕时需要出发的全局JS对象
	public void OnFrameLoadEnd(object sender, FrameLoadEndEventArgs e)
	{
		if (e.Frame.IsMain)
		{
			chromiumWebBrowser.ExecuteScriptAsync(@"document.body.onmouseup = function()
			{
				JsObj.onSelected(window.getSelection().toString());
			}");
		}
	}
	public void showMsg(string msg)
	{
		//String Content = msg;  // 后台接收前端提供的值,可以进行其它处理,比如本地存储;
		MessageBox.Show("C#弹窗:" + msg);
	}
	public string readMessage()
	{
		return myId +";"+ text_str + ";" + startTime;
	}
	public int getId()
	{
		return myId;
	}
}

③ 如下是实现:Winform窗体大小变化时,执行JS代码实时更新前端TinyMCE编辑器尺寸。

void Form1_SizeChanged(object sender, EventArgs e)
{
	int formHeight = this.ClientSize.Height;
	string jsCode =
	$"document.querySelector('#idcardmsg').value = {formHeight};"
	+ $"tinymce.activeEditor.editorContainer.style.height = {formHeight - 300} + 'px'"  // 减去200是为了让底部的“提交”按钮在合适位置;公式可以按需调整。
	;
	browser.ExecuteScriptAsync(jsCode);
}

这里注意,需要给Winform设计界面的窗口属性绑定事件。

4. 编写前端代码。




     
    
    



    
输入框1(窗体大小调整时,会把窗体高度值更新到这里 ——实时更新)
输入框2(=输入框1的值,自动更新 ——非实时更新,快速调整窗口高度时可以看出效果差异)
(读取输入框1的值传递给C#进行winform弹窗)
(读取C#定义的参数值,然后进行js弹窗)

TinyMCE快速开始示例

三、运行界面

界面如下图。

  • 点击“测试弹出框”可以读取“输入框1”的值并由C#弹窗。
  • 点击“读取信息”可以读取C#定义参数并由JS弹窗。
  • 调整Winform应用程序窗口的大小,可以看到2个输入框的值都在随着变动。
  • 点击底部“提交”按钮,会把TinyMCE的内容提交到后台并进行C#弹窗。

四、补充说明

1. 代码已上传GitHub

地址:
https://github.com/Griked/CefSharp-TinyMCE

2. 劝退提醒

使用Winform内嵌谷歌浏览器(CefSharp)的方法,生成的文件目录非常大,上面程序调试生成的文件夹接近300MB,因为几乎把开源的谷歌浏览器放进去了。

相关推荐

pdf怎么在线阅读?这几种在线阅读方法看看

pdf怎么在线阅读?我们日常生活中经常使用到pdf文档。这种格式的文档在不同平台和设备上的可移植性,以及保留文档格式和布局的能力都很强。在阅读这种文档的时候,很多人会选择使用在线阅读的方法。在线阅读P...

PDF比对不再眼花缭乱:开源神器diff-pdf助你轻松揪出差异

PDF比对不再眼花缭乱:开源神器diff-pdf助你轻松揪出差异在日常工作和学习中,PDF文件可谓是无处不在。然而,有时我们需要比较两个PDF文件之间的差异,这可不是一件轻松的事情。手动逐页对比简直是...

全网爆火!580页Python编程快速上手,零基础也能轻松学会

Python虽然一向号称新手友好,但对完全零基础的编程小白来讲,总会在很长时间内,都对某些概念似懂非懂,每次拿起书本教程,都要从第一章看起。对于这种迟迟入不了门的情况,给大家推荐一份简单易懂的入门级教...

我的名片能运行Linux和Python,还能玩2048小游戏,成本只要20元

晓查发自凹非寺量子位报道|公众号QbitAI猜猜它是什么?印着姓名、职位和邮箱,看起来是个名片。可是右下角有芯片,看起来又像是个PCB电路板。其实它是一台超迷你的ARM计算机,不仅能够运...

由浅入深学shell,70页shell脚本编程入门,满满干货建议收藏

不会Linux的程序员不是好程序员,不会shell编程就不能说自己会Linux。shell作为Unix第一个脚本语言,结合了延展性和高效的优点,保持独有的编程特色,并不断地优化,使得它能与其他脚本语言...

真工程师:20块钱做了张「名片」,可以跑Linux和Python

机器之心报道参与:思源、杜伟、泽南对于一个工程师来说,如何在一张名片上宣告自己的实力?在上面制造一台完整的计算机说不定是个好主意。最近,美国一名嵌入式系统工程师GeorgeHilliard的名片...

《Linux 命令行大全》.pdf

今天跟大家推荐个Linux命令行教程:《TheLinuxCommandLine》,中文译名:《Linux命令行大全》。该书作者出自自美国一名开发者,兼知名Linux博客LinuxCo...

PDF转换是难题? 搜狗浏览器即开即看

由于PDF文件兼容性相当广泛,越来越多的电子图书、产品说明、公司文告、网络资料、电子邮件选择开始使用这种格式来进行内容的展示,以便给用户更好的再现原稿的细节,但需要下载专用阅读器进行转化才能浏览的问题...

彻底搞懂 Netty 线程模型

点赞再看,养成习惯,微信搜一搜【...

2022通俗易懂Redis的线程模型看完就会

Redis真的是单线程吗?我们一般说Redis是单线程,是指Redis的网络IO和键值对操作是一个线程完成的,这就是Redis对外提供键值存储服务的主要流程。Redis的其他功能,例如持久化、异步删除...

实用C语言编程(第三版)高清PDF

编写C程序不仅仅需要语法正确,最关键的是所编代码应该便于维护和修改。现在有很多介绍C语言的著作,但是本书在这一方面的确与众不同,例如在讨论C中运算优先级时,15种级别被归纳为下面两条原则:需要的...

手拉手教你搭建redis集群(redis cluster)

背景:最近需要使用redis存储数据,但是随着时间的增加,发现原本的单台redis已经不满足要求了,于是就倒腾了一下搭建redistclusterredis集群。好了,话不多说,下面开始展示:...

记录处理登录页面显示: HTTP Error 503. The service is unavailable.

某天一个系统的登录页面无法显示,显示ServiceUnavailableHTTPError503.Theserviceisunavailable,马上登录服务器上查看IIS是否正常。...

黑道圣徒杀出地狱破解版下载 免安装硬盘版

游戏名称:黑道圣徒杀出地狱英文名称:SaintsRow:GatOutofHell游戏类型:动作冒险类(ACT)游戏游戏制作:DeepSilverVolition/HighVoltage...

Exchange Server 2019 实战操作指南

...