ChromiumWebBrowser如何调用Winform方法.

之前已经实现了将ChromiumWebBrowser浏览器嵌入Winform中了。

但是有的时候,我笨需要调用本地设备,例如打印(套打),读卡,拍照等等功能吧。

这个时候就需要解决,HTML页面中,使用JavaScript方法,调用本地Winform中的方法的办法了。

感觉有点绕嘴,但就是这么回事。

其实CefSharp本身支持browser和本地应用间的交互操作的。只不过一般本地掉页面的不多(但是百度很多),页面调本地的很多(但是百度很少)。

所以这里主要记录如何页面调本地。

这里就牵扯到使用CefSharp将本地类注册到页面的办法了,也很简单。

首先在Winform中写一个类,作为交互的中介。

class SendCarBillPrint
    {
        public string sendcode { set; get; }

        public void showtest()
        {
            SendCarPrintForm form = new SendCarPrintForm();
            form.sendcode = sendcode;
            form.ShowDialog();
            //MessageBox.Show(sendcode);

        }
    } 

这里这个类也很好看懂吧,需要传过来一个SendCode,然后把这个SendCode传给了打印的窗体,然后把窗体显示出来。

那么,接下来,只要能通过html页面的js方法,将SendCode参数传过来,然后调用ShowTest()方法就可以完成任务了。

在之前InitBrowser()方法中,增加如下代码:

CefSharpSettings.LegacyJavascriptBindingEnabled = true;
browser.RegisterJsObject("jsObj", new SendCarBillPrint());

首先是设置了LegacyJavascriptBindingEnabled=true,这里是由于新版本的CefSharp修改了绑定js对象的方法。但是心方法笔者在使用时,没有成功,怀疑有bug,或者兼容性问题。反而老方法一次就OK,这里就这么用了。有兴趣的可以google一下新方法。百度是别指望了。注意科学上网。

第二句代码的意思也很简单,将新创建的SendCarBillPrint对象,作为jsObj对象,注册给browser。这样在browser中加载的html页面上,就能访问到jsObj这个对象了。注意,直接在浏览器打开没用的,必须通过程序使用browser打开页面才行。所以调试其实有点麻烦的。

然后就是在页面上写js脚本了。

            <script>
                function printBill()
                {
                    if (!jsObj)
                    {
                        alert("请使用客户端操作");
                        return;
                    }
                    var rows = $('#dt').datagrid("getSelections");
                    
                    jsObj.sendcode = rows[0].SendCode;
                    
                    jsObj.showtest();
                }
            </script>

这里如果能读取jsObj对象,那么说明是通过browser访问的,反之就是浏览器打开了,可以根据需要进行处理。

这里做了提示,方便调试。其实完全可以屏蔽触发事件的按钮。

然后再客户端打开页面点击页面打印按钮的时候,就会弹出对应的winform窗体了。

下一章继续说怎么保持session会话吧。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值