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

萬星星@豌豆莢 歡迎加入我們
一個吃軟飯的男人!!!!!我只想寫程序####
微博:http://weibo.com/wanlianwen
posts - 172,  comments - 1253,  trackbacks - 0

存在的必是合理的,都值得我們學習。學什么不重要,重要的是有一技之長。
如果你認為MFC垃圾請不要繼續看。
如果你認為文檔視圖結構丑陋請不要繼續看。
如果你認為ATL過時了請不要繼續看。

MFC應用與框架的聯系
要想分離應用與框架,首先得明白它們之間的聯系。用向導生產一個多文檔程序觀察,可以發現只有一處關聯:

CMainFrame * ?pMainFrame? = ? new ?CMainFrame;
????
if ?( ! pMainFrame -> LoadFrame(IDR_MAINFRAME))
????????
return ?FALSE;
????m_pMainWnd?
= ?pMainFrame;

????
// ?The?main?window?has?been?initialized,?so?show?and?update?it.
????pMainFrame -> ShowWindow(m_nCmdShow);
????pMainFrame
-> UpdateWindow();
既然App與Frame耦合這么松,把它們分離是很自然的想法,也是符合軟件工程中的高內聚低耦合標準的。

MFC應用與框架的剝離
應用需要的只是一個主框架指針而已,可以定義一個插件接口:
interface?IMainFrame?:?IUnknown
{
????[id(
1),?helpstring("method?GetFrame"),?hidden]?HRESULT?GetFrame([out,?retval]long*?pMainFrame);
}
;
為了插件查找以及管理,需要一個類別,所有支持的插件都屬于這個類別:
BEGIN_CATEGORY_MAP(CManager)
????IMPLEMENTED_CATEGORY(CATID_FrameCategory)
END_CATEGORY_MAP()
下面就可以實現主框架插件了,生產一個ATL項目,添加主框架類,添加一個組件Manager,實現插件接口:(示例用中文主框架和英文主框架來演示效果)
STDMETHODIMP?CManager::GetFrame(long*?pDocCls)
{
????CMainFrame
*????????pMainFrame????=?NULL;
????HINSTANCE????????hInst????????
=?AfxGetResourceHandle();
????pMainFrame?
=?(CMainFrame*)(RUNTIME_CLASS(CMainFrame)->CreateObject());
????AfxSetResourceHandle(_Module.m_hInstResource);
????
if(!pMainFrame->LoadFrame(IDR_MAINFRAME))
????
{
????????AfxSetResourceHandle(hInst);
????????
return?E_FAIL;
????}

????AfxSetResourceHandle(hInst);

????pMainFrame
->SetWindowText(_T("中文版本"));
????
*pDocCls?=?(long)pMainFrame;

????
return?S_OK;
}
這樣在主框架啟動的時候就可以遍歷CATID_FrameCategory下面所有框架插件,


選擇一個插件框架后:



有必要這樣做嘛??
這里演示了一個應用根據選擇不同的插件進入不同語言的界面,當然不是為了解決多國語言版本問題而這樣做(多國語言版本可以通過資源文件來解決)。
這樣做到底有沒有必要呢??再來看下向導生產的程序界面:


這里可以清楚看到子框架、文檔、視圖是一個模塊體,主框架、菜單、工具欄、狀態條是一個模塊體、后面看不見的應用app又是一個模塊體。這使我想起小時候的積木,一堆不同形狀的木塊,可以自由的想象去搭建房子汽車。
軟件應該是軟的,是像積木一樣可以自由搭架自由組合的。有些人一直抱怨MFC死板,我也曾經熱衷去的研究一些小巧的界面庫WTL、fox、fltk,但是回頭來看用的最多的、對自己最有幫助然而也最另自己頭痛的還是MFC。
軟件需要美觀,于是乎出來了許多基于MFC的界面庫,其中BCG、XTREME算是有名氣的。試想一個項目的開發需要多少人,又有多少人對BCG之類的庫熟悉(即使它很好用)。我曾經遇到過一個問題:BCG的DockBar標題在上面,占用很大一部分視圖,給人一種擁擠的感覺,而XTREME的標題在左側,這樣視圖看上去大許多。但是引入兩套界面庫是不實際的,于是自己想用MFC做一個。結果是用MFC的DockBar居然加不上去,由于涉及到一些其他問題,所以無奈只能忍受那個霸道的DockBar。最讓人無法忍受的是一些別出心裁的人在MFC對話框上加上一個漂亮的XP按鈕,哭笑不得。我也沖動認為給我Wnd和DC就可以作出任何想要的界面效果,花上幾天時間去繪制一個控件,響應各種消息,做完后才發現離專業美觀相差甚遠,而且放入到應用中不協調,影響軟件的商品化形象。
軟件開發已經進入工業化時代了,手工蠻干顯得笨拙,對MFC進行封裝的界面庫自從有了皮膚之后也顯得蒼白無力。到底如何才能簡化軟件開發,提高軟件應變能力??
回到軟件設計的鐵定律:高內聚低耦合。從面向對象到面向構件到現在流行的面向服務軟件設計理念,無不遵守這條原則,不同只是技術上的更新。對于大型軟件的界面開發,拋開美觀(可以通過皮膚滿足)不談,MFC是值得我們研究的。從開發者的熟悉程度和提供解決方案能力來講,MFC都是最佳選擇。有人會說MFC提供的控件少,不利于開發,請清楚軟件開發已經進入工業化時代了,這已經不再是問題(后續文章會陸續解決)。
軟件要想軟下來,盡量適應變化,只有降低耦合度。我們必須把MFC向導生產的框架拿來進行解剖,斬斷耦合的牽絆。這里把軟件抽象看作App、MainFrame、DocView組成,從上面的剝離可以看到,App與MainFrame、MainFrame與DocView之間是松耦合的,每一個部分是內聚的。只要保證每個部分之間可以正常通信,這樣一個App就可以對應多個MainFrame,一個MainFrame可以對應多個DocView。企業只要有App、MainFrame、DocView三個向導完成三者之間的通信,就足以開發各種不同需求的軟件。

讓思維漫步
在App、MainFrame和DocView剝離開之后,我又運行了向導生產的程序。發現選擇菜單的時候,狀態欄有信息提示。以前從沒有考慮過這些再普通不過的功能是如何實現的,突然之間覺得很神奇。我打開msdn,查閱MainFrame的基類CFrameWnd,里面有個SetMessageText函數,是狀態欄顯示信息用的。嗯,選擇菜單的時候一定會調用它。于是進入CFrameWnd的實現文件WINFRM.CPP,搜索SetMessageText發現OnEnterIdle()、OnIdleUpdateCmdUI()調用了它,

void?CFrameWnd::OnEnterIdle(UINT?nWhy,?CWnd*?pWho)
{
????CWnd::OnEnterIdle(nWhy,?pWho);

????
if?(nWhy?!=?MSGF_MENU?||?m_nIDTracking?==?m_nIDLastMessage)
????????
return;

????SetMessageText(m_nIDTracking);
????ASSERT(m_nIDTracking?
==?m_nIDLastMessage);
}

原來空閑的時候一直會檢測當前菜單跟蹤狀態。
靜下心來,讓思維去自由漫步,當孤獨的智者。
代碼下載。里面有說明文件。

posted on 2006-07-08 14:42 萬連文 閱讀(1277) 評論(0)  編輯 收藏 引用 所屬分類: MFC
簡歷下載
聯系我

<2008年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

常用鏈接

留言簿(66)

隨筆分類

隨筆檔案

相冊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲一级片在线观看| 久久夜色撩人精品| 一区在线免费观看| 国产真实久久| 国内精品久久久久影院色 | 亚洲欧洲一区二区三区| 欧美大学生性色视频| 亚洲激情午夜| 亚洲一级黄色| 久久久精品国产免费观看同学| 久久久久久久久久码影片| 嫩草伊人久久精品少妇av杨幂| 日韩视频一区二区三区在线播放免费观看 | 亚洲免费播放| 亚洲一区视频在线| 欧美在线免费播放| 欧美黄色免费| 国产日韩欧美综合精品| 亚洲级视频在线观看免费1级| 国产精品99久久久久久宅男| 欧美在线观看一区二区| 免费日韩一区二区| 亚洲一区二区高清| 麻豆av一区二区三区久久| 欧美三级网址| 亚洲第一综合天堂另类专| 中文欧美字幕免费| 欧美成人自拍视频| 亚洲欧美日韩系列| 欧美片第1页综合| 韩国自拍一区| 亚洲一区视频在线观看视频| 欧美a级在线| 亚洲欧美日韩一区在线观看| 欧美国产日韩a欧美在线观看| 国产日韩在线一区| 亚洲图片欧洲图片av| 欧美国产日本高清在线| 亚洲欧美视频在线观看视频| 欧美精品大片| 亚洲国产精品久久精品怡红院| 亚洲一区二区三区乱码aⅴ| 欧美不卡视频一区| 欧美有码视频| 国产精品免费视频观看| 一本色道久久加勒比88综合| 浪潮色综合久久天堂| 亚洲欧美激情一区| 国产精品美女久久久久aⅴ国产馆| 亚洲精品视频二区| 欧美大片免费久久精品三p | 欧美日韩国产丝袜另类| 1204国产成人精品视频| 久久九九免费视频| 亚洲男人av电影| 欧美日韩视频一区二区| 日韩一区二区福利| 亚洲国产精品一区制服丝袜| 免费短视频成人日韩| 久久亚洲免费| 亚洲图片欧洲图片av| 老司机午夜精品视频在线观看| 国产色综合网| 久久精品一区二区| 久久爱www久久做| 国产精品尤物| 久久精品国产精品亚洲精品| 欧美在线不卡视频| 激情亚洲成人| 欧美国产91| 欧美国产极速在线| 99精品国产福利在线观看免费 | 久久精品在这里| 黄色亚洲免费| 欧美.www| 欧美日韩视频一区二区三区| 亚洲欧美日韩国产成人精品影院| 9i看片成人免费高清| 国产精品国产亚洲精品看不卡15 | 亚洲福利一区| 欧美人与性动交cc0o| 在线亚洲精品| 亚洲欧美日韩国产另类专区| 国内精品久久久久久 | 亚洲国产成人av| 欧美日韩午夜在线| 欧美影视一区| 毛片基地黄久久久久久天堂| 亚洲乱码国产乱码精品精天堂| 亚洲精品一级| 中文无字幕一区二区三区| 国产精品视频午夜| 男人天堂欧美日韩| 欧美日产在线观看| 久久激情网站| 欧美国产日本韩| 欧美在现视频| 欧美成人免费在线| 欧美一区二区啪啪| 欧美成人高清| 欧美一区二区三区男人的天堂| 久久亚洲一区| 亚洲欧美不卡| 欧美阿v一级看视频| 午夜精品久久久久久久99水蜜桃| 久久av一区二区| 亚洲一区999| 亚洲国产精选| 国产一区亚洲一区| 99成人精品| 亚洲高清不卡在线| 亚洲一区欧美激情| 一本一本大道香蕉久在线精品| 久久精品夜夜夜夜久久| 久久亚洲国产精品一区二区 | 日韩视频免费| 亚洲国产精品激情在线观看| 午夜久久福利| 亚洲视频一区二区| 欧美v日韩v国产v| 久久久久久一区| 国产精品国产三级国产普通话三级| 欧美成人免费在线观看| 国产亚洲美州欧州综合国| 欧美一区二区三区喷汁尤物| 嫩草成人www欧美| 久久精品在线| 国产精品日韩一区二区| 日韩视频免费看| 亚洲精品一区二区网址| 久久久噜噜噜久久| 久久久久久久999精品视频| 国产精品乱人伦一区二区| 亚洲美女精品久久| 亚洲美女av黄| 欧美麻豆久久久久久中文| 亚洲国产一区二区三区a毛片| 伊人久久av导航| 新67194成人永久网站| 欧美在线高清| 国产视频综合在线| 久久er99精品| 老牛影视一区二区三区| 精品电影在线观看| 久久精品视频免费| 久久香蕉国产线看观看网| 国产资源精品在线观看| 久久精品主播| 亚洲第一天堂av| 亚洲九九精品| 欧美午夜精品久久久| 中文日韩欧美| 久久久亚洲欧洲日产国码αv| 激情五月综合色婷婷一区二区| 久久精品三级| 亚洲高清免费| 一区二区三区欧美成人| 欧美午夜精品| 欧美在线观看视频一区二区三区 | 中文精品视频一区二区在线观看| 亚洲影音一区| 国产一区二区三区自拍| 老司机一区二区三区| 日韩一级片网址| 久久亚洲综合色一区二区三区| 亚洲第一中文字幕| 国产精品a久久久久| 久久激情网站| 亚洲美女尤物影院| 久久国产一区二区| 亚洲国产精品一区二区第一页| 欧美成人午夜激情视频| 亚洲素人一区二区| 免费影视亚洲| 午夜精品在线视频| 1024日韩| 国产精品免费电影| 女人色偷偷aa久久天堂| 在线一区二区三区四区五区| 久久视频精品在线| 一区二区欧美精品| 久久人人爽国产| 久久三级福利| 日韩午夜视频在线观看| 久久九九热免费视频| 日韩一区二区免费看| 国产欧美短视频| 欧美福利专区| 午夜日韩激情| 亚洲久久视频| 女女同性女同一区二区三区91| 宅男在线国产精品| 在线免费不卡视频| 国产美女精品| 欧美韩日一区二区三区| 久久大逼视频| 亚洲伊人第一页| 亚洲精品一区二区三区樱花 | 国产一区二区三区黄视频| 欧美激情精品久久久久久大尺度|