青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

我們知道Windows的窗口消息處理函數(shù)是C方式, 面向過程的, 所以窗口框架的基本任務就是將它轉(zhuǎn)成面向?qū)ο蟮姆绞剑?確切的說如何將消息處理函數(shù)第一參數(shù)HWND轉(zhuǎn)成對象指針。

關于這個問題, 其實網(wǎng)上大家已經(jīng)說濫了,  這里只是簡單記錄一下。

Map方式:MFC就是采用這種方式, 就是建立一張從HWND到CWindow*的映射表, 每次收到消息都從Map中根據(jù)HWND找到CWindow*, 再進行調(diào)用

UserData的方式:CreateWindow時將最后一個附加數(shù)據(jù)設置為對象CWindow* 指針, 當收到第一個消息WM_NCCREATE時, 取出傳過來的附加數(shù)據(jù)指針, 將該指針設置成窗口的UserData,  SetWindowLongPtr(hWnd, GWLP_USERDATA, reinterpret_cast(pThis)), 后面收到任何消息就可以直接調(diào)用GetWindowLongPtr(hWnd, GWLP_USERDATA)取出窗口指針, 進行面向?qū)ο蠓绞降恼{(diào)用。

Thunk方式:這是ATL采用的方式,通過匯編代碼,直接將窗口消息處理函數(shù)的第一個參數(shù)HWND改寫成CWindow*, 然后進行面向?qū)ο蠓绞降恼{(diào)用, 原理可以見我以前寫的 理解ATL中的一些匯編代碼

這里也有一篇文章總結(jié)了這些封裝方式: MFC、ATL窗口消息封裝機制對比分析

最近工作中要寫一些簡單窗口相關的代碼, 考慮用什么方式封裝窗口過程:
MFC肯定不引入, map方式也不考慮。
UserData方式太低效 ,而且窗口的UserData讓框架用了,我們其他地方可能還要用呢。
ATL的Thunk方式不錯, 但是我們不想引入COM, 也不想用ATL的庫和代碼。
原始的 C API方式, 依賴性和效率都最佳, 可惜就是不是面向?qū)ο蟮摹?br />
各有優(yōu)缺,怎樣才能熊掌和魚翅兼得?

最后決定把ATL中窗口Thunk相關的核心代碼剝離出來, 做一個完全獨立的最基本窗口框架。我們框架的基本目標是可以讓我們方便的開發(fā)一些簡單的窗口, 所以去掉了ATL窗口中一些不常用或是可替代的東西, 只留下必須和最有用的。簡單說來,把ATL中的CWindow給去掉了,它只是窗口API的封裝, 我們可以直接調(diào)用API來實現(xiàn);把CWinTraits給去掉了,因為它只是窗口風格的封裝; 把SubClass和SuperClass也去掉了, 我們的簡單窗口用不到這個特性; 把Dialog, Container和COM相關的都去掉了, 這些都不是窗口的核心部分。最后只留下,窗口注冊創(chuàng)建, thunk和消息映射相關的代碼。

測試了下,這個窗口框架基本上只有2個核心文件,完全獨立, 可以直接放到任何現(xiàn)有框架中使用(ATL/WTL中使用可能要改下內(nèi)部一些類名, 但是用了ATL/WTL肯定就不用這個框架了)。

測試代碼: CAltWinTest.rar
posted on 2013-09-08 14:47 Richard Wei 閱讀(4423) 評論(11)  編輯 收藏 引用 所屬分類: windows desktop

FeedBack:
# re: 關于Windows窗口框架[未登錄]
2013-09-08 17:46 | avlee
做一個最基本窗口框架,可以完全不要使用消息映射,也就可以不需要使用thunk了。  回復  更多評論
  
# re: 關于Windows窗口框架
2013-09-08 19:16 | Richard Wei
@avlee
嗯,關鍵我們希望是面向?qū)ο蟮模?方便的支持多實例, 并且希望是線程安全的,這個框架都很好的滿足了。消息處理是窗口程序的根本, 所以簡單方便的消息映射也很重要。  回復  更多評論
  
# re: 關于Windows窗口框架
2013-09-08 22:27 | jilei
也可以用 SetProp 吧  回復  更多評論
  
# re: 關于Windows窗口框架
2013-09-09 08:52 | Richard Wei
@jilei
不錯, UserData方式也可以用SetProp存儲, 但是低效同樣也是它的缺點。  回復  更多評論
  
# re: 關于Windows窗口框架
2013-09-09 14:52 | 聶晏冰
UserData方式太低效 只需要取一次,何來低效之說? 求解  回復  更多評論
  
# re: 關于Windows窗口框架
2013-09-09 18:34 | Richard Wei
@聶晏冰

怎么取一次?
每次收到消息都要轉(zhuǎn)的, 大概代碼如下:
LRESULT CALLBACK XWindow::WndProc(HWND hWnd, UINT uMsg,
WPARAM wParam, LPARAM lParam)
{
XWindow* pThis = NULL;
if (WM_NCCREATE == uMsg)
{
assert(!::IsBadReadPtr((void*)lParam, sizeof(CREATESTRUCT)));
LPCREATESTRUCT lpcs = reinterpret_cast(lParam);
pThis = static_cast(lpcs->lpCreateParams);
pThis->m_hWnd = hWnd;

assert(!::IsBadReadPtr(pThis, sizeof(XWindow)));
::SetWindowLongPtr(hWnd, GWLP_USERDATA, reinterpret_cast(pThis));
}
else
pThis = reinterpret_cast(::GetWindowLongPtr(hWnd, GWLP_USERDATA));

if (pThis)
return pThis->MsgProc(hWnd, uMsg, wParam, lParam);
else
return DefWindowProc(hWnd, uMsg, wParam, lParam);
}  回復  更多評論
  
# re: 關于Windows窗口框架
2013-09-24 21:34 | 多多
現(xiàn)在很多界面框架采用DirectUI的方式,一個窗口中的所有控件都由自己繪制,而不是像使用API那樣每個控件都對應一個窗口類,簡單的說就是一個窗口和它內(nèi)嵌的所有控件都只屬于一個窗口類,對應一個HWND。窗口和控件的消息不依賴于API,完全由自己定義。

優(yōu)點是靈活性非常大,窗口和控件的風格完全由自己決定,不受限于系統(tǒng)風格。
框架接口完全不依賴于系統(tǒng)API,使用者完全不用關系系統(tǒng)的事件和消息,只需要使用你提供的事件和消息就行。
缺點是工作量較大,每個控件都要自己重寫,每個控件的事件和消息都要重新考慮。

QQ就是用的這種方式,另外很流行的界面框架Qt也是用的這種方式。  回復  更多評論
  
# re: 關于Windows窗口框架
2015-07-02 21:06 |
@多多 自己決定風格跟是不是directui沒啥關系。
  回復  更多評論
  
# re: 關于Windows窗口框架
2015-07-02 21:11 | 多多
@龍 你沒看懂我在說什么。  回復  更多評論
  
# re: 關于Windows窗口框架
2015-08-07 13:10 | 溪流
@多多
大概是你沒看懂他在說什么吧  回復  更多評論
  
# re: 關于Windows窗口框架
2015-08-14 11:56 | 多多
@溪流
我是說用directui可以決定自己的風格,不是說決定自己的風格要用directui。這下懂了沒?

也是強行秀自己語文……  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品自拍视频| 亚洲精品欧美精品| 国产精品99久久久久久久久久久久 | 亚洲国产精品成人精品| 久久亚洲国产精品日日av夜夜| 久久久久久久999精品视频| 久久久999精品| 亚洲国产高清aⅴ视频| 99亚洲伊人久久精品影院红桃| 亚洲一区二区成人在线观看| 久久精彩免费视频| 欧美精品v日韩精品v国产精品| 欧美系列一区| 亚洲第一黄色网| 亚洲一区二区三区视频| 久热国产精品| 9l国产精品久久久久麻豆| 先锋影音久久| 欧美精品三级日韩久久| 国产无遮挡一区二区三区毛片日本| 影音先锋日韩精品| 亚洲午夜精品福利| 免费在线观看一区二区| 一区二区三欧美| 久久亚洲综合色| 国产精品午夜视频| 99www免费人成精品| 久久久亚洲高清| 亚洲私人影院| 欧美国产视频一区二区| 国模一区二区三区| 亚洲伊人伊色伊影伊综合网| 欧美不卡视频一区| 亚洲欧美日韩精品久久亚洲区| 欧美激情五月| 雨宫琴音一区二区在线| 久久av老司机精品网站导航| 99精品视频免费在线观看| 免费久久99精品国产自在现线| 国产欧美日韩在线视频| 一区二区三区精品视频| 欧美大色视频| 久久激情综合网| 国产精品手机视频| 亚洲女人天堂成人av在线| 亚洲国产精品成人综合| 久久9热精品视频| 国产精品美女久久久免费| 一区二区三区国产盗摄| 亚洲欧洲另类| 欧美日本在线| 夜夜嗨网站十八久久| 亚洲激情在线观看| 欧美激情a∨在线视频播放| 亚洲国产婷婷香蕉久久久久久| 美日韩精品免费| 欧美在线观看一二区| 亚洲国产精品黑人久久久| 久久女同互慰一区二区三区| 欧美亚洲在线观看| 国产午夜亚洲精品理论片色戒| 欧美一区二区三区精品电影| aa级大片欧美三级| 国产精品高潮呻吟久久av无限| 亚洲自拍三区| 亚洲欧美国产视频| 国产亚洲一区二区在线观看 | 久久国产精品毛片| 午夜亚洲视频| 激情视频一区二区三区| 嫩模写真一区二区三区三州| 久久久久免费观看| 亚洲日本中文| 一区二区三区不卡视频在线观看| 欧美图区在线视频| 欧美一级黄色网| 久久精品视频免费观看| 亚洲国产合集| a91a精品视频在线观看| 国产日韩在线一区| 欧美激情第10页| 欧美日韩久久精品| 欧美在线免费观看亚洲| 久久综合激情| 亚洲天堂偷拍| 久久av二区| 99视频精品全部免费在线| 亚洲伊人久久综合| 亚洲福利国产精品| 亚洲特级毛片| 在线观看欧美成人| 中文国产亚洲喷潮| 1024成人网色www| 一本不卡影院| 亚洲国产一区在线| 午夜精品视频在线观看| 亚洲精品日韩在线观看| 性18欧美另类| 一区二区三区精品在线| 久久久水蜜桃| 香蕉av福利精品导航| 欧美sm极限捆绑bd| 久久精品一本| 欧美天堂亚洲电影院在线观看| 免费观看成人www动漫视频| 欧美色欧美亚洲另类二区| 欧美v日韩v国产v| 国产精品久久久久av| 亚洲国产精品久久久久婷婷884| 国产日韩欧美综合精品| 日韩视频免费观看高清完整版| 红桃视频国产一区| 亚洲欧美成人一区二区在线电影| 亚洲毛片在线观看| 久久蜜桃香蕉精品一区二区三区| 午夜影院日韩| 欧美成人精品| 亚洲人成网站777色婷婷| 欧美日韩亚洲精品内裤| 久久久噜噜噜久久中文字幕色伊伊| 嫩草国产精品入口| 久久资源在线| 国产亚洲电影| 亚洲一区二区三区涩| 亚洲视频自拍偷拍| 欧美日韩国产成人精品| 亚洲精品麻豆| 99精品视频网| 欧美久久综合| 亚洲精品免费一二三区| 日韩视频第一页| 欧美激情一区二区三区蜜桃视频| 欧美成人免费大片| 在线观看国产精品淫| 久久久www成人免费毛片麻豆| 久久久久久久性| 一区二区三区亚洲| 久久一二三国产| 欧美激情久久久久| 亚洲日本中文| 欧美日韩精品在线视频| 99re热精品| 午夜精品久久久久久| 国产欧美一区二区精品仙草咪| 亚洲欧美日韩精品一区二区| 久久精品一区| 91久久精品国产91久久| 欧美日本三级| 亚洲欧美久久久久一区二区三区| 久久精品免费观看| 在线观看成人网| 欧美激情亚洲综合一区| 一本久道久久久| 久久精品亚洲热| 亚洲国产小视频| 欧美三区在线观看| 午夜精品网站| 欧美黄色小视频| 亚洲一区二区在线看| 国产一区二区三区精品欧美日韩一区二区三区 | 在线欧美影院| 欧美成人免费在线视频| 一区二区三区久久网| 久久国产精品网站| 亚洲精品社区| 国产精品一区二区在线| 久久一区二区三区超碰国产精品| 亚洲人www| 久久精品视频在线播放| 日韩视频一区二区在线观看| 国产精品一级久久久| 免费国产自线拍一欧美视频| 亚洲一区美女视频在线观看免费| 免费看的黄色欧美网站| 亚洲欧美日韩视频一区| 亚洲夫妻自拍| 国产亚洲视频在线| 欧美日韩免费在线观看| 久久久久99| 亚洲图色在线| 91久久国产精品91久久性色| 久久九九免费| 欧美日韩国产综合视频在线| 欧美一区1区三区3区公司| 亚洲电影免费观看高清完整版在线 | 欧美激情欧美狂野欧美精品| 亚洲欧美清纯在线制服| 最新日韩中文字幕| 久久免费视频观看| 亚洲一区二区成人| 亚洲激情网站免费观看| 国产亚洲综合在线| 国产精品videosex极品| 欧美激情网站在线观看| 久久夜色精品| 久久久噜噜噜久久中文字幕色伊伊| 亚洲网在线观看| 一区二区三区福利| 亚洲激情av在线| 欧美成人亚洲|