教程五 在Go中使用Energy创建跨平台GUI - 执行开发者工具方法
创始人
2024-02-19 09:25:33
0

教程-示例-文档 


介绍

本文介绍在Energy中如何执行开发者工具方法

开发者工具方法,可以设置浏览器头,模拟仿真设备等.


使用方式

  • 字典对象创建

cef.NewCefDictionaryValue()
  • 字典对象是key=value方式, chromium定义的字典名称和对应的值,通过字典对象设置执行的参数
    • 字典对象有五种类型
    1. 字典本身类型 ICefDictionaryValue
    2. 字符串 String
    3. 整型  Int
    4. 浮点  Double
    5. 布尔  Boolean
  • 示例 - 创建字典

//字典对象
var dict = cef.NewCefDictionaryValue()
//根据chromium字典设置
dict.SetInt("width", 500)
dict.SetBoolean("mobile", true)
dict.SetDouble("deviceScaleFactor", 1)
dict.SetString("type", "portraitPrimary")
TempDict := cef.NewCefDictionaryValue()
dict.SetDictionary("screenOrientation", TempDict)

  • 执行开发者工具方法

Chromium().ExecuteDevToolsMethod(messageId, name, dict)
  • 示例 - 调用访真设备方法
//字典对象
var dict = cef.NewCefDictionaryValue()
//根据chromium字典设置
dict.SetInt("width", 500)
dict.SetInt("height", 768)
dict.SetInt("x", 100)
dict.SetInt("y", 100)
dict.SetBoolean("mobile", true)
dict.SetDouble("deviceScaleFactor", 1)
TempDict := cef.NewCefDictionaryValue()
TempDict.SetString("type", "portraitPrimary")
TempDict.SetInt("angle", 0)
dict.SetDictionary("screenOrientation", TempDict)
//执行方法
windowInfo.Chromium().ExecuteDevToolsMethod(0, "Emulation.setDeviceMetricsOverride", dict)
  • 示例 - 设置浏览器 userAgent
dict := cef.NewCefDictionaryValue()
dict.SetString("userAgent", "Mozilla/5.0 (Linux; Android 11; M2102K1G) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.101 Mobile Safari/537.36")
windowInfo.Chromium().ExecuteDevToolsMethod(0, "Emulation.setUserAgentOverride", dict)

完整示例

一如既往先配置好go和energy环境, 然后创建一个main函数来创建应用

这个示例稍微有点复杂,使用了事件机制内置资源内置http服务

内置http服务

启用了Energy简单的内置http服务-参考: 示例-内置http服务

//在主进程启动成功之后执行
//在这里启动内置http服务
//内置http服务需要使用 go:embed resources 内置资源到执行程序中
cef.SetBrowserProcessStartAfterCallback(func(b bool) {fmt.Println("主进程启动 创建一个内置http服务")//通过内置http服务加载资源server := assetserve.NewAssetsHttpServer()server.PORT = 22022               //服务端口号server.AssetsFSName = "resources" //必须设置目录名和资源文件夹同名server.Assets = &resourcesgo server.StartHttpServer()
})

事件监听

在应用初始化时使用 SetOnEvent 函数,监听Go消息事件

ipc.IPC.Browser().SetOnEvent(func(event ipc.IEventOn) {
})

通过 event.On 来监听一个事件

event.On(eventName, func(context ipc.IIPCContext){
})

事件触发

在web端使用js代码,ipc.emit 触发go监听的事件

ipc.emit(eventName,[callback function]);
  • Go示例代码
package mainimport ("embed""fmt""github.com/energye/energy/cef""github.com/energye/energy/common/assetserve""github.com/energye/energy/ipc"
)//资源目录,内置到执行程序中
//go:embed resources
var resources embed.FSfunc main() {//全局初始化 每个应用都必须调用的cef.GlobalCEFInit(nil, &resources)//创建应用cefApp := cef.NewApplication(nil)//主窗口的配置//指定一个URL地址,或本地html文件目录cef.BrowserWindow.Config.DefaultUrl = "http://localhost:22022/execute-dev-tool-method.html"//chromium配置config := cef.NewChromiumConfig()config.SetEnableMenu(true)     //启用右键菜单config.SetEnableDevTools(true) //启用开发者工具cef.BrowserWindow.Config.SetChromiumConfig(config)//这里演示使用ipc通信实现js和go互相调用,在go监听事件中执行开发者工具方法//使用内置http服务和自定义页面//这里执行的方法是仿真移动端//1. js使用ipc.emit触发 go事件//2. go中"execute-dev-method"事件执行,通过context获得browserId//3. 通过browserId获得chromium//4. 使用字典对象传递方法参数//5. 点击Note链接ipc.IPC.Browser().SetOnEvent(func(event ipc.IEventOn) {event.On("execute-dev-method", func(context ipc.IIPCContext) {//获得当前窗口信息windowInfo := cef.BrowserWindow.GetWindowInfo(context.BrowserId())//字典对象var dict = cef.NewCefDictionaryValue()//根据chromium字典设置dict.SetInt("width", 500)dict.SetInt("height", 768)dict.SetInt("x", 100)dict.SetInt("y", 100)dict.SetBoolean("mobile", true)dict.SetDouble("deviceScaleFactor", 1)TempDict := cef.NewCefDictionaryValue()TempDict.SetString("type", "portraitPrimary")TempDict.SetInt("angle", 0)dict.SetDictionary("screenOrientation", TempDict)windowInfo.Chromium().ExecuteDevToolsMethod(0, "Emulation.setDeviceMetricsOverride", dict)//设置浏览器 userAgentdict = cef.NewCefDictionaryValue()dict.SetString("userAgent", "Mozilla/5.0 (Linux; Android 11; M2102K1G) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.101 Mobile Safari/537.36")windowInfo.Chromium().ExecuteDevToolsMethod(0, "Emulation.setUserAgentOverride", dict)})})//在主进程启动成功之后执行//在这里启动内置http服务//内置http服务需要使用 go:embed resources 内置资源到执行程序中cef.SetBrowserProcessStartAfterCallback(func(b bool) {fmt.Println("主进程启动 创建一个内置http服务")//通过内置http服务加载资源server := assetserve.NewAssetsHttpServer()server.PORT = 22022               //服务端口号server.AssetsFSName = "resources" //必须设置目录名和资源文件夹同名server.Assets = &resourcesgo server.StartHttpServer()})//运行应用cef.Run(cefApp)
}
  • html示例代码


执行开发者工具方法



Note

示例效果图

相关内容

热门资讯

泽连斯基:乌不会在法律或事实上... 12月16日,据《乌克兰独立新闻社》报道,乌克兰总统弗拉基米尔·泽连斯基在回答记者提问时明确表示,乌...
柳城警方通报:犯罪嫌疑人李某致... 12月16日,柳州市柳城县公安局发布警情通报,内容如下: 来源:柳城警方
国泰海通:政策推动加生态适配 ... 智通财经APP获悉,国泰海通发布研报称,数字人民币在产业链上游技术支撑、中游系统适配、下游终端落地等...
“他们把话塞进我嘴里”——恶意... 智通财经获悉,美国总统唐纳德·特朗普于当地时间周一晚间在迈阿密联邦法院对英国广播公司(即BBC)正式...
靠谱拆迁律师机构推荐,有名拆迁... 在拆迁过程中,遇到纠纷、权益受损等问题是许多人头疼的事,这时候靠谱的拆迁律师机构和有名的拆迁专业律师...
正规老牌有实力,拆迁律师事务所... 在拆迁过程中,许多人都会遇到各种各样的法律问题,这时候选择一家正规、老牌且有实力的拆迁律师事务所就显...
李世纬:币圈KOL刑事法律风险... 厚积薄发 启行千里 2025年12月5日,中国互联网金融协会联合六大行业协会重磅发布《关于防范涉虚...
北京市卫健委答复“女律师体检争... DoNews12月16日消息,据新华财经消息,近日北京市卫生健康委员会向“体检10年未查出癌症”当事...
广西柳城警方通报:马山镇发生一... 12月16日,广西柳城县公安局发布警情通报,全文如下:
以《条例》为遵循 锻造坚强有力... 近日,中共中央印发修订后的《中国共产党工作机关条例》(以下简称《条例》),这是健全党的领导制度体系、...