国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

淺析cef在win和mac上的適配

京東云 ? 來源:jf_75140285 ? 作者:jf_75140285 ? 2025-10-14 16:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

背景

cef是一種跨平臺的框架,屬于chrome內核,可以用來顯示web相關頁面。目前在咚咚工作臺上使用,顯示聊天框,歷史消息,插件頁面等等。之前只是在win平臺上使用,在今年開發mac版本商家咚咚過程中,完成了mac版本的適配,積累了一些在兩個平臺上的使用方法,避免以后再踩坑。

?

一. 庫和資源文件

基本的庫文件包含了多個文件夾和資源文件,這些是運行cef時必須要依賴的,因此需要打包在安裝包中。

win mac 說明
include文件夾 include文件夾 cef內部接口對外暴露的頭文件
libcef_dll文件夾 libcef_dll文件夾 cef對外的wrapper庫相關的cc文件
Resources文件夾 Resources文件夾 cef依賴的pak文件
libcef.dll Chromium Embedded Framework cef核心庫文件
其它dll庫,libEGL.dll等 其它dylib庫,libEGL.dylib等 cef依賴動態庫文件
其它bin文件,natives_blob.bin等 cef依賴bin文件

表1.1 cef依賴文件

以上是cef運行時所依賴的所有文件,其中include和libcef_dll, 可以組合生成一個lib靜態庫,一般名稱為libcef_dll_wrapper.lib,在其它模塊中需要依賴該cef頭文件時,導入lib庫即可。

在升級cef版本的過程中,只需要替換替換對應的文件夾中的文件,就可以升級到對應的版本,目前最新的100以上的版本,基本都是這些固定的文件格式。

如果添加了新的文件或者依賴庫,則需要添加對應的庫和資源。

?

二. 文件路徑查找

資源文件,需要設定路徑才能找到對應的文件,在CefSettings指定對應的路徑。

路徑 win mac
resource目錄(pak文件) resources_dir_path framework_dir_path/main_bundle_path
locales目錄 locales_dir_path framework_dir_path/main_bundle_path
子進程路徑 browser_subprocess_path browser_subprocess_path

表2.1 cef資源路徑設置

2.1 對于資源路徑,win版本可以放到同一目錄下面,例如在安裝目錄下,新建一個CEF目錄,專門用來放置資源文件:

wKgZO2juBIqAKd7-AADmXxEim_A370.png

2.2 dll庫則在主安裝目錄下面:

wKgZPGjuBIuASeKYAAGGxOjU71w170.png

2.3 mac版本的目錄文件基本是固定的:

Chromium Embedded Framework.framework

一般可以放置到app包的頂層或者Frameworks目錄下面

wKgZO2juBIuACpVoAADxKOjYMtI913.png

?

以上的路徑,都需要明確指定絕對路徑,即完整的訪問路徑資源,不能使用相對路徑,比如../../../之類的,因此在程序內部,需要專門封裝查找資源路徑的方法,這樣在應用安裝到用戶電腦上,才能準確找到對應的資源。

若資源文件無法找到,則在后續的初始化,第一步就會報錯,只有找到文件,才能進行后續的步驟。

?

三. 主進程初始化

主進程初始化分為多個步驟:

wKgZPGjuBIyAbzsqAAL9n25qZf4389.png

?

3.1 加載cef動態庫

如果將libcef庫放置在標準目錄下面,即win是exe同級目錄,則無需查找動態庫,系統可以自行查找到,如果放到其它目錄,則需要采用動態加載庫的方式。

mac可以使用cef提供的標準方法:

CefScopedLibraryLoader library_loader;

library_loader.LoadInMain()

來直接加載主進程庫。

若采用顯示路徑來加載的方式,可以指定

Chromium Embedded Framework.framework下面的Chromium Embedded Framework,整個的完整路徑

然后使用cef提供的方法:cef_load_library,加載指定路徑下的主進程文件。

加載主庫必須成功,失敗則直接返回,后續一切步驟都依賴主進程的加載完成。

3.2 獲取啟動參數

啟動的時候,都需要使用CefMainArgs,來獲取命令行的參數

win mac
HINSTANCE hInstance = (HINSTANCE)GetModuleHandle(NULL); CefMainArgs main_args(hInstance); CefRefPtr command_line = CefCommandLine::CreateCommandLine(); command_line->InitFromString(::GetCommandLineW()); CefMainArgs main_args(argc, argv); CefRefPtr command_line = CefCommandLine::CreateCommandLine(); command_line->InitFromArgv(argc, argv);
使用系統方法,直接獲取命令行參數 從main方法傳遞argc, argv,從中獲取命令參數

表3.1 cef獲取啟動命令

接著生成 CefRefPtr app,這個類繼承自cef的基本app類:CefApp

繼承ClientApp,來生成主進程方法:

app = new ClientAppBrowser();

3.3 設置其它參數

設置日志級別:settings.log_severity

日志目錄:settings.log_file

瀏覽器版本和說明:settings.user_agent

調試時的端口:settings.remote_debugging_port

3.4 主進程初始化

直接調用CefInitialize(main_args, settings, app.get(), sandbox_info)

傳入命令,設置選項,app實例,sandbox的內容,通常來說sandbox為空,不啟用即可

返回成功可以進行后續步驟,失敗表示主進程啟動異常,后續也無法顯示頁面。

?

四.渲染進程生成

渲染進程,可以采用和主進程合并模式,也可以采用單獨的進程。一般比較大型或者復雜的項目,都需要單獨的進程,并為了不同的頁面,還需要啟動多個子進程。

啟動流程和主進程類似,先加載子進程路徑,再獲取命令行參數,繼承CefApp啟動實例,最后再初始化。

進程名稱,win可以自己定義,mac有嚴格限制,必須以xxx Helper結尾,否則找不到對應的渲染子進程。

win mac
獨立的exe應用 獨立的app應用
子進程名稱.exe 子進程核心應用:xxx Helper.app 子進程GPU應用:xxx Helper (GPU) 子進程Plugin應用:xxx Helper (Plugin) 子進程Render應用:xxx Helper (Renderer)

表1.1 cef子進程名稱

4.1 子進程的路徑,理論上可以設置到專門的目錄下面,但也可以讓系統去默認路徑查找,即和主應用同級別即可。

加載cef資源的時候,win版本在主應用同級別的exe,不用專門的方法去加載。

mac版本需要使用cef的專用方法:

CefScopedLibraryLoader library_loader;

library_loader.LoadInHelper()

若是需要專門的路徑,則仍然使用cef_load_library去加載庫的絕對路徑,加載成功后,才能正常初始化子進程。

?

4.2 在最后初始化時,可以直接調用cef的方法:

CefExecuteProcess(main_args, app, nullptr)

返回值大于0,表示啟動子進程已經成功,可以開啟渲染頁面等操作。

返回值小于0,表示啟動子進程失敗,頁面將無法進行渲染,但是不影響主進程的正常運行。

子進程實現的最好方式,是將所有的依賴文件,都集成在同一個模塊工程中,不依賴其它的模塊,這樣在編譯運行的時候,就不會由于依賴過多導致各種錯誤。

?

五. 消息循環

不同的系統版本中,采用不同的消息循環模式,需要和主應用的消息循環合作運行。

5.1 在win版本中,可以通過設置multi_threaded_message_loop為true的參數,開啟瀏覽器多線程模式。能夠和主應用的主消息循環并行處理運行。

wKgZO2juBI2AWC4ZAAPOsS4W7H4735.png

如圖所示,win應用中,在main方法中需要開啟主界面的消息循環,這里的消息循環就一直在UI主線程中運行,直到應用退出,消息循環主線程才會結束退出。

另外在cef的瀏覽器主進程中,也同時開啟多線程消息循環,此時Browser獨享自己的消息循環線程,和主消息循環互不影響,可以實時的收到界面的點擊響應和顯示web界面等。

?

5.2 在mac版本中,有兩種cef消息循環方式

第一種:直接將主應用的消息循環設置為cef的消息循環,即所有的消息接收和傳遞,都在CefRunMessageLoop()中進行,此時cef的消息循環占據了主導地位,主界面的按鈕點擊等操作,都需要cef拋出并提交給主線程。

第二種:當mac中采用了Qt等框架時,它本身有自己的消息主循環,而cef在mac中無法再開啟自己的消息主循環,也不支持采用多線程機制單獨運行。因此采用了將cef消息循環嵌入到Qt的消息循環中的方式,相當于時間片分割方式,到了定時時間,去專門處理cef的事件響應。

wKgZPGjuBI6AB-GCAAS__6-3i5I697.png

主循環消息啟動后,生命周期跟隨主應用,一直到應用退出才會結束。此時定一個時間片分割,時間自定義,可以50幀也就是每隔20ms處理一次。

當定時周期到的時候,就執行cef的消息循環處理,在CefDoMessageLoopWork()中去處理cef的具體事件響應。

另外在cef本身的回調中,也可以使用onScheduleMessageLoopWork()中拿到事件,然后到cef事件循環中去處理。

這樣主循環和cef自己的的循環,就不斷運行起來,在用戶使用時,感覺不到這個細微的延時差距,主界面和cef界面基本都是在同時響應。

?

六.窗口適配

在界面顯示過程中,打開網頁或者本地頁面時,通常需要重新修改窗口尺寸。在不同的版本需要不同的處理方式:

功能 win mac
獲取窗口id (CefWindowHandle)this->winId() (CefWindowHandle)this->winId()
改變窗口大小 ::MoveWindow(hwnd, rect.x(), rect.y(), rect.width(), rect.height(), true) [nsview setFrameSize:NSMakeSize(rect.width(), rect.height())]
獲取窗口句柄 browser->GetHost()->GetWindowHandle() browser->GetHost()->GetWindowHandle() browser->GetHost()->GetOpenerWindowHandle()

表6.1 cef窗口適配

在創建一個瀏覽器窗口時,需要調用SetAsChild設置瀏覽器的子窗口,這里首先獲取當前生成的窗口id,可以直接用CefWindowHandle來進行轉換。

在重繪窗口大小的時候,需要移動窗口,調整高和寬,這里cef沒有提供通用的方法,只能使用不同平臺的原生方法,因此調用了操作系統的系統接口。

獲取窗口可以直接使用cef內部封裝好的GetWindowHandle,這個是通用的接口,需要在UI線程中調用,但是在一些特殊的web窗口中,需要使用GetOpenerWindowHandle來獲取非pop窗口的句柄,從而操作窗口界面正常顯示。

?

七.版本區分

7.1 操作系統版本區分可以直接使用開源庫的方法:

win系統:Q_OS_WIN

mac系統:Q_OS_MAC

當需要區分使用不同操作系統的接口,或者調用對應系統的原生方法時,需要使用該宏定義進行區分處理。

7.2 cef版本區分,可以使用cef_version中的定義:

#define CEF_VERSION_MAJOR 106

#define CEF_VERSION_MINOR 1

#define CEF_VERSION_PATCH 0

#define CEF_COMMIT_NUMBER 2678

通常來說,若應用程序中,同時存在多個cef版本,比如89,106等,主要是主版本號不同,則直接判斷CEF_VERSION_MAJOR的數值即可,另外的三個小版本可以不做過多關注,若大版本相同,則需要進行小版本的詳細區分。

不同的cef大版本,接口基本是一樣的,但是當相差幾十個版本的cef庫時,則會出現接口參數變更,或者名稱變化,新增部分接口等差異點,則需要在不同版本進行對應的處理和適配。

?

結尾

使用cef在win和mac上用的同一套文件,利用Qt的宏定義對平臺進行了區分,利用cef版本對不同版本進行兼容,因此同樣的源代碼文件,在兩個平臺都可以運行,不同的cef版本也可以同時運行,比較方便維護升級。

后續可以繼續完善,形成更多不同的功能,并進一步拆分成獨立的模塊,讓大家少走一些彎路。

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • Win
    Win
    +關注

    關注

    0

    文章

    69

    瀏覽量

    28997
  • Mac
    Mac
    +關注

    關注

    0

    文章

    1126

    瀏覽量

    54941
  • CEF
    CEF
    +關注

    關注

    0

    文章

    38

    瀏覽量

    18814
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    集特GM0-5602海光3350主板:國產芯強適配Win7系統穩定運行新選擇

    處理器,主頻3.0GHz,基于自主x86架構,多核性能強勁,滿足Win7系統下多任務并行需求。 · ? 系統適配 ?:通過驅動優化與內核調整,完美兼容Windows 7(64位),支持傳統工業軟件與辦公應用無縫運行,降低信創場景遷移成本。 ? 工業級設計:嚴苛環境穩定運行
    的頭像 發表于 12-11 15:25 ?214次閱讀
    集特GM0-5602海光3350主板:國產芯強<b class='flag-5'>適配</b>,<b class='flag-5'>Win</b>7系統穩定運行新選擇

    win7無法識別USB設備怎么解決?

    我現在有一個添加了CDC的FX3固件,該設備可以win10和win11正常工作,但在win7似乎并不能正確的識別設備,串口和USB設備都
    發表于 07-16 06:52

    win10系統,通過控制中心下載MDK編譯的.hex后,硬件能被識別,但讀寫無反應,usb不能工作,是什么原因?

    win10系統,通過控制中心下載MDK編譯的.hex后,硬件能被識別,但讀寫無反應,usb不能工作;win7上操作正常,請問這是什么問題呢?
    發表于 05-30 07:15

    S7win10安裝步驟

    S7win10安裝步驟,經過多次測試,均成功。
    發表于 04-10 18:09 ?0次下載

    ESP32平臺使用以太網DM9051ANX自帶的MAC地址

    本帖最后由 jf_36651975 于 2025-4-11 10:38 編輯 之前的ESP32行業網關項目,需要以太網通信功能,當時選用了DM9051ANX,相較于老款,每一個
    發表于 04-10 17:17

    iMX6ULL設置MAC地址,啟動后無法獲得相同的mac id?

    我正在開發基于 imx6ull 的定制板。 U Boot with Fuse Prog Command 中,我編寫了 mac id,但是啟動后我無法獲得相同的 mac id。還需要
    發表于 04-10 06:02

    通過注冊表和Technitium MAC Address Changer修改MAC地址(支持W5500模塊及通用網卡)

    一、前言 某些場景下(如網絡調試、隱私保護或設備唯一性管理),需要修改網絡設備的MAC地址。本教程將詳細介紹兩種方法:注冊表修改(適合高級用戶)和?Technitium MAC Address
    的頭像 發表于 03-28 09:27 ?6471次閱讀
    通過注冊表和Technitium <b class='flag-5'>MAC</b> Address Changer修改<b class='flag-5'>MAC</b>地址(支持W5500模塊及通用網卡)

    通過注冊表和Technitium MAC Address Changer修改MAC地址(支持W5500模塊及通用網卡)

    輸出中找到W5500對應的以太網適配器,記錄 物理地址(如 E8-6A-64-71-8D-A0) 步驟2:定位設備實例路徑 打開設備管理器: Win + X → 設備管理器 找到
    發表于 03-28 09:18

    如何修復S32G gmac的mac地址?

    您好,我想修復 S32G gmac 的 mac 地址,我 uboot 下執行以下命令 setenv ethaddr d6:20:eb:40:75:d8 保存 在內核運行 ifconfig
    發表于 03-21 06:49

    MAC mini4 安裝與使用 ComfyUI 文生圖軟件完整指南

    ,還是簡單的文字配圖,ComfyUI 都能為用戶提供便捷的解決方案,能夠幫助用戶將文本內容轉化為圖像。本教程將指導您如何在 MAC MINI4 安裝并配置 ComfyUI。 二,步驟 1:下載 ComfyUI 1, 打開瀏覽器,訪問 ComfyUI 的官方網站,找到適用
    的頭像 發表于 03-11 17:15 ?2571次閱讀
    <b class='flag-5'>在</b> <b class='flag-5'>MAC</b> mini4 <b class='flag-5'>上</b>安裝與使用 ComfyUI 文生圖軟件完整指南

    MAC mini4 使用 VSCode 和 Cline 插件對接 Deepseek-R1:32b 的完整指南

    可以 MAC mini4 上高效地編寫和調試代碼。本教程將詳細介紹如何在 MAC mini4 配置 VSCode 和 Cline 插件,并成功對接 Deepseek-R1:32b,
    的頭像 發表于 03-11 17:14 ?1440次閱讀
    <b class='flag-5'>在</b> <b class='flag-5'>MAC</b> mini4 <b class='flag-5'>上</b>使用 VSCode 和 Cline 插件對接 Deepseek-R1:32b 的完整指南

    電源適配器怎么使用?

    和重量,只有極少數的機型把電源內置主機內。   電源適配都有一個銘牌,上面標示著功率,輸入輸出電壓和電流量等指標,特別要注意輸入電壓的范圍,這就是所謂的“旅行電源
    發表于 01-18 11:04

    Mac使用Docker構建noVNC環境并運行MyCobot

    這篇文章主要內容是關于如何在 Ros2 環境中構建在 Mac 模擬 Mycobot 280 M5 的環境。
    的頭像 發表于 01-15 09:17 ?1873次閱讀
    <b class='flag-5'>在</b><b class='flag-5'>Mac</b><b class='flag-5'>上</b>使用Docker構建noVNC環境并運行MyCobot

    window 10系統生成的安裝包程序win7運行,我生成時也選了配置win7,但是還是報需要win10以上配置系統

    window 10系統生成的安裝包程序win7運行,我生成時也選了配置win7,但是還是報需要win10以上配置系統,怎么解決啊
    發表于 01-02 14:33

    ChatGPT深度融入蘋果Mac軟件生態

    ,OpenAI推出了MacOS桌面應用程序,使得用戶能夠Mac更加便捷地查看和自動化他們的ChatGPT工作。這一桌面應用程序不僅具備出色的兼容性和穩定性,還提供了豐富的功能選項,滿足了用戶多樣化的需求。 更重要的是,Cha
    的頭像 發表于 12-23 10:50 ?1033次閱讀