當(dāng)前位置:首頁 > 芯聞號 > 充電吧
[導(dǎo)讀]概述 ?????之前研究了一段時間chromium源碼,根據(jù)自己的興趣了解了一下其中部分功能的實(shí)現(xiàn)。通過在在網(wǎng)上查看博文、chromium官方文檔以及加上自己的一些理解,整理出了一點(diǎn)資料。本文中主要

概述 ?????之前研究了一段時間chromium源碼,根據(jù)自己的興趣了解了一下其中部分功能的實(shí)現(xiàn)。通過在在網(wǎng)上查看博文、chromium官方文檔以及加上自己的一些理解,整理出了一點(diǎn)資料。本文中主要是介紹chromium UI中的一些內(nèi)容。接下來我會一一介紹?chromium?中窗口的創(chuàng)建過程、布局方式。
基礎(chǔ)鋪墊 ? ? ?1、Widget ? ? ?Widget?中管理著一個真窗口,用于接收事件消息,以及管理整個?UI?界面,在windows?下就是管理一個?HWND?,它通過NativeWidgetWin?中的?HWNDMessageHandler來實(shí)現(xiàn)。在?Widget中包含一個?RootView?,因此也可以算是整個view系統(tǒng)中的一層,同時,它也可以包含其他的Widgets。Widget中如果涉及到跟平臺相關(guān)的處理,它會把他們隱藏起來實(shí)現(xiàn),通過一個指定的NativeWidget去實(shí)現(xiàn),具體實(shí)現(xiàn)如下:? ? ? ?在widget中同樣使用了delegate,在NativeWidgetPrivate中會實(shí)現(xiàn)具體的跟窗口自己相關(guān)的操作,而當(dāng)涉及到具體的業(yè)務(wù)邏輯相關(guān)的操作時則會調(diào)用到?NativeWidgetDelegate中去做具體的處理。而要如何創(chuàng)建一個窗口的實(shí)現(xiàn)也會通過?NativeWidgetDelegate?回調(diào)到NativeWidgetPrivate?中在去進(jìn)行進(jìn)一步的處理。?Chromium?中多出都使用了?delegate這種模式。用來實(shí)現(xiàn)?MVC?模式的處理。 ? ? ?chromium中有主窗口、omnibox、findbar、以及omnibox搜索建議彈出框幾個控件使用了真窗口,使用真窗口的一個很重要的原因是所設(shè)計的窗口需要浮在其他創(chuàng)口之上,在windows中只有windows自己的窗口具有這樣的能力。
? ? ?2、View ? ? ?在chromium中,它們自己實(shí)現(xiàn)了一套稱作?View?的UI?系統(tǒng),View負(fù)責(zé)界面的渲染,布局和消息傳遞。其中的?view的分層如下圖:? ? ?這張圖是從chromium的代碼中截出來的,可以從這里看出chromium的注釋寫的有多強(qiáng)大,在chromium中這種用文字表述一個設(shè)計結(jié)構(gòu)的方式隨處可見。從上圖可以看出,Widget可以說是整個UI層的根,RootView是整個View?控件樹的根,Widget會接受系統(tǒng)消息并將其裝換為view控件能夠識別的消息,并將此消息傳遞給views::RootView,并通過RootView?將消息分發(fā)給下層的View,其中Widget和RootView是一一對應(yīng)的。下層的View?主要分為三種: ? ? ?用于表示整個窗體非客戶區(qū)的?NonClientView?,負(fù)責(zé)設(shè)置窗口邊框大小。他也是其他兩種?View?的父view,原因很簡單:他管著整個窗體的邊框,所以其他的View必須是它的子view。 ? ? ?用于表示非客戶區(qū)的內(nèi)容的?NonClientFrameView?,負(fù)責(zé)繪制非客戶區(qū)里面的元素,如標(biāo)題欄,關(guān)閉按鈕等等。 ? ? ?用于表示客戶區(qū)和其內(nèi)容的?ClientView?,負(fù)責(zé)生成各種窗口元素。 ? ? ?上圖中另外幾個view的意義如下: ? ? ?NativeFrameView?,用于生成默認(rèn)的窗口。 ? ? ?CustomFrameView?,用于自繪窗口邊框。 ? ? ?DialogClientView?,用于生成對話框的窗口。 ? ? ? ? ? ?3、WidgetDelegate ? ? ?WidgetDelegate?是一個為Widget?顯示窗口時提供信息的接口,比如說窗口的標(biāo)題,圖標(biāo),以及是否可以被重設(shè)大小。同時它也可以提供事件回調(diào)接口,每個?Widget?都有一個WidgetDelegate?提供的?ContentsView,這個?view?是被插入在窗口的?client area中的。? ? ?BrowserView?是views::WidgetDelegate?的子類,可以由?BrowserView?來直接和Widget?之間通信。 ??? 在chromium中,直接在Widget初始化的時候定義non_client_view_ =new NonClientView;而BrowserNonClientFrameView是其NonClientFrameView,包括GlassBrowserFrameView和OpaqueBrowserFrameView兩種。BrowserView是其?ClientView。 具體可以通過?views Windowing進(jìn)一步了解。 ???? 所有new出來的view?都無需自己進(jìn)行釋放,它們會在窗口收到最后一個消息時把view樹中的所有對象都釋放掉。
窗口創(chuàng)建 ???? 在widget中,有幾個這樣的一些實(shí)現(xiàn): ???? static Widget* CreateWindowWithParentAndBounds(WidgetDelegate* delegate, gfx::NativeWindow parent, const gfx::Rect& bounds); ??? 這些函數(shù)是通過指定的屬性來創(chuàng)建出一個相應(yīng)的窗口。在這個函數(shù)的實(shí)現(xiàn)中會先創(chuàng)建一個Widget,之后再將其中的NonClientView創(chuàng)建出來,并在其中通過SetContentsView將RootView與NonClientView關(guān)聯(lián)起來。
在chromium中,Chromium在啟動的時候就會在StartupBrowserCreatorImpl中創(chuàng)建出一個browser,并初始化。而在構(gòu)造Browser的時候會調(diào)用CreateBrowserWindow,來創(chuàng)建BrowserView及BrowserFrame。而BrowserFrame是Widget的一個子類。 Chromium的主窗口browser window有幾個對象相互聯(lián)系共同組成,這些對象之間的關(guān)系如圖:

????Frame:
??? frame也是整個browser window的一部分,管理著瀏覽器主窗口中的"non-client"區(qū)域,如標(biāo)題欄、邊框及其他傳統(tǒng)區(qū)域。 Chromium中提供了一個BrowserFrame的frame,BrowserFrame類繼承自views::Widget類。
??? Browser View :
??? BrowserView 對象管理著所有與 frame類似的元素,包括 tab strip, toolbar, bookmarks bar及其它的 UI 元素。這些元素都是整個 browser window 中不可或缺的以部分。
??? BrowserView 是抽象接口 BrowserWindow的一個具體實(shí)現(xiàn),Browser對象會通過這個接口與View進(jìn)行聯(lián)系。
??? Browser :
??? Browser 是整個browser window的核心狀態(tài)及命令執(zhí)行組件,它會通過與Browser Window接口的交互來更新UI。

窗口布局
??? chromium中可以為每一個View創(chuàng)建了一個專門用于控制布局的LayoutManager 。
??? 在layout目錄中,可以發(fā)現(xiàn) Chromium?還提供幾種不同的布局策略:
????? FillLayout ,用于將第一個子 View保持和當(dāng)前 View 一樣大的策略。
????? GridLayout ,將子View 排布成表格狀。
????? BoxLayout ,排布成一個貼一個的格子。

窗口釋放 ??? 所有?new出來的?view?都無需自己進(jìn)行釋放,它們會在窗口收到最后一個消息時把?view?樹中的所有對象都釋放掉。
參考資料 ??? GPU Accelerated Compositing in Chrome

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉