WinForm使用CefSharp,嵌入浏览器

简介: WinForm使用CefSharp,嵌入浏览器

引入库:CefSharp.WinForms

using CefSharp;
using CefSharp.WinForms;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace 大屏Win
{
    public partial class Form1 : Form
    {
        static string url = System.Configuration.ConfigurationManager.AppSettings["url"].ToString();//从配置文件中读取要打开的url
        static ChromiumWebBrowser chromeBrowser = null;
        public Form1()
        {
            InitializeComponent();
            try
            {
                CefSettings settings = new CefSettings();
                settings.Locale = "zh-CN";//中文环境
                settings.AcceptLanguageList = "zh-CN";//中文环境
                settings.CachePath = System.IO.Directory.GetCurrentDirectory()+"\\cache";//设置缓存
                Cef.Initialize(settings);
                chromeBrowser = new ChromiumWebBrowser(url);
                chromeBrowser.AddressChanged += Browser_AddressChanged;//监听地址变化
                this.Controls.Add(chromeBrowser);
                chromeBrowser.Dock = DockStyle.Fill;
                //js和cs交互
                chromeBrowser.JavascriptObjectRepository.Settings.LegacyBindingEnabled = true;
                chromeBrowser.JavascriptObjectRepository.Register("yfcsobj", new yfcsobj(), isAsync: true, options: BindingOptions.DefaultBinder);
                chromeBrowser.ExecuteScriptAsync("refreshdata()");//c# 调用 js方法
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
                Application.Exit();
            }
        }
        private void Browser_AddressChanged(object sender, AddressChangedEventArgs e)
        {
            //MessageBox.Show(e.Address);
        }
        private void Form1_FormClosing(object sender, FormClosingEventArgs e)
        {
            Cef.Shutdown();
        }
        //监听键盘按键
        private void Form1_KeyDown(object sender, KeyEventArgs e)
        {
            if (e.KeyData == Keys.F12)
            {
                chromeBrowser.ShowDevTools();//打开调试模式
            }
        }
    }
}
    public class yfcsobj
    {
        public void test(string msg)
        {
           MessageBox.Show(msg);
        }  
        public void closeApp()
        {
            //彻底关闭进程
            System.Environment.Exit(0);
            Application.Exit();
        }
    }

html中使用

<html>
<body>
<button onclick="test()">test</button>
<button onclick="test2()">test2</button>
<script>
function test(){
  yfcsobj.test('test js');
}
function test2(){
  yfcsobj.closeApp();
}
</script>
</body>
<html>
相关文章
|
JavaScript 前端开发 Java
【JCEF】SWT嵌入浏览器(包含VUE的)
【JCEF】SWT嵌入浏览器(包含VUE的)
227 1
|
移动开发 Linux HTML5
Linux下将swf文件用浏览器读取打开(html、html5嵌入swf格式文件)
Linux下将swf文件用浏览器读取打开(html、html5嵌入swf格式文件)
|
Web App开发 JavaScript C#
在WPF中使用CefSharp嵌入浏览器
原文:在WPF中使用CefSharp嵌入浏览器 日常开发中,我们需要将一些Web页面嵌入到桌面客户端软件中。下面我们使用CefSharp嵌入浏览器来实现。  首先先介绍一下CefSharp嵌入式浏览器,它是基于Google浏览器的一个组件,我们可以在WPF/WinForm客户端软件中使用它。
2436 0
关于嵌入浏览器开发的一点总结
宠辱不惊,看庭前花开花落;去留无意,望天上云卷云舒
989 0
|
移动开发 JavaScript Android开发
|
Windows
Qt for Windows嵌入IE浏览器
//嵌入浏览器 WebBrowser= new QAxWidget(this); WebBrowser->setControl(QString::fromUtf8("{8856F961-340...
1494 0
|
9天前
|
JavaScript 前端开发
js之浏览器对象|28
js之浏览器对象|28
|
2月前
|
机器学习/深度学习 人工智能 前端开发
【人工智能】利用TensorFlow.js在浏览器中实现一个基本的情感分析系统
使用TensorFlow.js在浏览器中进行情感分析是一个非常实用的应用场景。TensorFlow.js 是一个用于在JavaScript环境中训练和部署机器学习模型的库,使得开发者能够在客户端直接运行复杂的机器学习任务。对于情感分析,我们可以使用预先训练好的模型来识别文本中的积极、消极或中性情感。
65 4
【人工智能】利用TensorFlow.js在浏览器中实现一个基本的情感分析系统
|
2月前
|
机器学习/深度学习 存储 前端开发
实战揭秘:如何借助TensorFlow.js的强大力量,轻松将高效能的机器学习模型无缝集成到Web浏览器中,从而打造智能化的前端应用并优化用户体验
【8月更文挑战第31天】将机器学习模型集成到Web应用中,可让用户在浏览器内体验智能化功能。TensorFlow.js作为在客户端浏览器中运行的库,提供了强大支持。本文通过问答形式详细介绍如何使用TensorFlow.js将机器学习模型带入Web浏览器,并通过具体示例代码展示最佳实践。首先,需在HTML文件中引入TensorFlow.js库;接着,可通过加载预训练模型如MobileNet实现图像分类;然后,编写代码处理图像识别并显示结果;此外,还介绍了如何训练自定义模型及优化模型性能的方法,包括模型量化、剪枝和压缩等。
34 1
|
2月前
|
编解码 JavaScript 前端开发
JS逆向浏览器脱环境专题:事件学习和编写、DOM和BOM结构、指纹验证排查、代理自吐环境通杀环境检测、脱环境框架、脱环境插件解决
JS逆向浏览器脱环境专题:事件学习和编写、DOM和BOM结构、指纹验证排查、代理自吐环境通杀环境检测、脱环境框架、脱环境插件解决
58 1

相关实验场景

更多
下一篇
无影云桌面