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

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

很近沒有更新了,閑話少說(shuō),直奔主題。

 

微軟做任何技術(shù)的思路:在實(shí)現(xiàn)一個(gè)標(biāo)準(zhǔn)的時(shí)候,往往預(yù)留出一個(gè)通用的擴(kuò)展機(jī)制。呃,貌似很多大公司都是如此,通過擴(kuò)展把開發(fā)者跟自己捆綁。舉例:微軟的ie可以嵌入ActiveX控件、可以用BHO擴(kuò)展;richedit中支持OLE擴(kuò)展。這種擴(kuò)展機(jī)制主要是基于其OLE框架,這也是微軟操作系統(tǒng)框架的基石。開發(fā)層面目前的趨勢(shì)是,淡化OLE強(qiáng)調(diào).NET,有一種無(wú)奈叫騎虎難下,有一種錯(cuò)誤叫脫離群眾,在開發(fā)平臺(tái)、技術(shù)百花齊放,開發(fā)資源極大豐富的今天,開發(fā)者對(duì)微軟的依賴已經(jīng)不那么強(qiáng)烈,以至于現(xiàn)在的Windows開發(fā)者有點(diǎn)小苦逼,尤其是C++開發(fā)者有一種被拋棄的感覺,扯遠(yuǎn)了。

 

談?wù)?/span>OLE/COM/ACTIVEX的關(guān)系。很模糊,有一些說(shuō)不清,有歷史原因,也有普及程度關(guān)系。侯捷說(shuō)玩模板有三境界:會(huì)用標(biāo)準(zhǔn)庫(kù),讀懂標(biāo)準(zhǔn)庫(kù)源碼,會(huì)用模板做設(shè)計(jì)。我覺得COM相關(guān)的也是如此,使用COM組件往往是容易。我的理解:OLE是技術(shù)規(guī)范,COM是語(yǔ)言規(guī)范,而ACTIVEX則是用這2東東來(lái)實(shí)做的可服用組件的稱謂。對(duì)于OLE的支撐主要在MFC庫(kù)中,而ATL庫(kù)則是更純粹的OLE/COM框架。MFCOFFICE有一衣帶水的關(guān)系,OFFICE的應(yīng)用框架促使著MFC的發(fā)展(早期如此,但UI方面早已分道揚(yáng)鑣),OFFICE的應(yīng)用模型也就是MFC的應(yīng)用開發(fā)模型。

 

之所以提及MFCOFFICE,只是想說(shuō)通用的擴(kuò)展機(jī)制沒有那么多條條框框,即便是ACTIVEX框架這種東西。對(duì)于OLE實(shí)踐,也就是微軟最熱衷,其中Windows操作系統(tǒng)和OFFICE系列軟件要最典型,其它則很牽強(qiáng)。OLE技術(shù)標(biāo)準(zhǔn)接口只有極少數(shù)是必須實(shí)現(xiàn),而大部分則是可選實(shí)現(xiàn)或者部分實(shí)現(xiàn),其中richedit更是如此。OLE對(duì)服務(wù)器和客戶端都做了行為規(guī)范,如果一方(一般是服務(wù)器)自行決定如何實(shí)施,則另一方也只需對(duì)應(yīng)實(shí)現(xiàn)。

 

呃,我說(shuō)了這么多,只是為了闡述我的險(xiǎn)惡用心,或許沒人明白。ATL框架定義了四個(gè)標(biāo)準(zhǔn)導(dǎo)出函數(shù)用于規(guī)范注冊(cè)、反注冊(cè)、加載、卸載,這些跟實(shí)際的OLE功能無(wú)關(guān),尤其是在richedit擴(kuò)展中。或許你在網(wǎng)上諸多示例中看到用ATL模板創(chuàng)建一個(gè)控件然后如何簡(jiǎn)單的插入位圖就以為掌握了核心科技,那么我就要潑冷水了,這些東西無(wú)關(guān)大局。既然Windows能用OLE搭建框架,既然MFC可以實(shí)踐OLE,那么我們也可以用純正的C++代碼玩OLE,我的意思無(wú)非就是沒必要遵循ATL,也沒必要一定去注冊(cè)一個(gè)東西,問題的核心不是這些東西,目前我們僅僅是為了插入一個(gè)動(dòng)畫。

 

Richedit是一個(gè)不完全的OLE實(shí)踐,前面提到能完全實(shí)踐OLE的框架不多。因?yàn)?/span>richedit實(shí)現(xiàn)了圖文混排,所以在IM領(lǐng)域很受歡迎,尤其是早期(現(xiàn)在基于chromium的擴(kuò)展或許可以改變現(xiàn)狀)。Richedit是一個(gè)容器,可以容納OLE控件進(jìn)入,典型的擴(kuò)展就是動(dòng)畫控件。基于ATL框架開發(fā),你可以實(shí)現(xiàn)一個(gè)標(biāo)準(zhǔn)的控件,但當(dāng)你面對(duì)一個(gè)非標(biāo)準(zhǔn)的容器時(shí),那些條條框框顯得不是那么重要,這也是為什么能做好動(dòng)畫控件不容易的原因。

 

根據(jù)我的調(diào)查(呃,通過實(shí)踐,通過QueryInterface觀察),我發(fā)現(xiàn)實(shí)現(xiàn)一個(gè)richedit中的動(dòng)畫控件只需要實(shí)現(xiàn)二個(gè)接口:IOleObjectIViewObject2,前者為了融入到richedit環(huán)境中,后者為了渲染顯示。由于richedit默認(rèn)只喜好無(wú)窗口模式,所以針對(duì)IOleInPlaceSiteWindowless之類的,你去實(shí)現(xiàn)意義也不大,因?yàn)槿思胰萜鞑徽J(rèn)你,當(dāng)然還有IPersist系列接口,對(duì)于標(biāo)準(zhǔn)的環(huán)境有用(比如IDE),但這里并不是很需要,所以認(rèn)清核心問題能減少很多困惑。更顯然的是我的控件沒有用ATL框架,因?yàn)榇丝丶撾x了richedit環(huán)境生存的意義也不大,更有甚者我沒必要讓使其成為標(biāo)準(zhǔn)(也沒可能),僅僅是為了在一個(gè)系統(tǒng)中的richedit中更好地展示。實(shí)現(xiàn)的接口越少,引入的麻煩越少,這樣才能使精力集中在主要問題上。

 

綜上所述,我的控件是一個(gè)C++類,只實(shí)現(xiàn)了兩個(gè)接口:

 

X_BEGIN_INTERFACE_MAP(IMRichPicture, ObjectRootBase)
  X_INTERFACE_PART(IMRichPicture, IID_IOleObject, OleObject)
  X_INTERFACE_PART(IMRichPicture, IID_IViewObject, ViewObject)
  X_INTERFACE_PART(IMRichPicture, IID_IViewObject2, ViewObject)
X_END_INTERFACE_MAP()

 

 

其中大部分接口都可以無(wú)視,因?yàn)槲覀冎恍枰@個(gè)控件在richedit中能夠占位(長(zhǎng)寬),能夠展示(效率關(guān)鍵),至于其他的可編程、在位激活、對(duì)象識(shí)別都不重要。我觀察了QQ的動(dòng)畫控件,呃,比現(xiàn)在網(wǎng)上流行的要改變很多(網(wǎng)上內(nèi)容沒有與時(shí)俱進(jìn))。現(xiàn)在的`QQ的動(dòng)畫控件很簡(jiǎn)單(后面會(huì)講述如何找到這個(gè)控件),看起來(lái)只是作為一個(gè)占位工具,如何觸發(fā)動(dòng)畫則是由host控制。觀其接口:

interface IRichFrameObj : IDispatch {
    };
interface IRichPicObj : IDispatch {
        [id(0x00000001), propput, helpstring("property src")]
        HRESULT src([in] BSTR rhs);
        [id(0x00000002), propput, helpstring("property static")]
        HRESULT na([inlong rhs);
        [id(0x00000003), propput, helpstring("property autoHeight")]
        HRESULT autoHeight([inlong rhs);
        [id(0x00000004), propput, helpstring("property autoWidth")]
        HRESULT autoWidth([inlong rhs);
        [id(0x00000005), propput, helpstring("property maxAutoWidth")]
        HRESULT maxAutoWidth([inint rhs);
        [id(0x00000006), propput, helpstring("property onerror")]
        HRESULT onerror([in] BSTR rhs);
        [id(0x00000007), propput, helpstring("property objid")]
        HRESULT objid([in] BSTR rhs);
    };

 

IrichFrameObj的作用我不是很理解居然一個(gè)接口都沒有而后者模糊的能夠理解一些src大概就是動(dòng)畫圖片路徑,auto系列是為了動(dòng)態(tài)縮放。現(xiàn)在的QQ只允許一個(gè)自定義動(dòng)畫,依據(jù)老衲猜測(cè),因?yàn)樽远x動(dòng)畫往往是截圖,比較大,在一行容易引起點(diǎn)擊時(shí)視圖跳躍。再有其他的屬性是為了識(shí)別所用,無(wú)法推測(cè)具體行為。

 

呃,事情看起來(lái)沒有那么復(fù)雜,的確,我只實(shí)現(xiàn)了2個(gè)接口,而其中大部分也都是返回E_NOTIMPL,因?yàn)?/span>richedit確實(shí)沒有那么標(biāo)準(zhǔn),你實(shí)現(xiàn)的再標(biāo)準(zhǔn)也無(wú)濟(jì)于事。當(dāng)然richeit也在更新,win8sdk對(duì)其改動(dòng)最大,但win7sdk也暴露了一些更早的功能,這或許是目前實(shí)現(xiàn)的最大亮點(diǎn)(技術(shù)含量,高風(fēng)險(xiǎn)高回報(bào),一般人難以置信)。

 

對(duì)于動(dòng)畫控件闡述到此為止,或許很多人會(huì)很失望,但也僅僅如此,因?yàn)樗旧硎裁炊紱]有,尤其是在你真正明白之后,所以這里或許你會(huì)很失望,但是真正的內(nèi)容就這么多,我也不知怎么添油加醋。

 

最后一個(gè)建議,希望尊重所有的玩技術(shù)的:

1、中國(guó)官本位思想很嚴(yán)重,技術(shù)搞得不錯(cuò)(或許是運(yùn)氣)立馬轉(zhuǎn)管理

2、文人相輕

3、資本運(yùn)作,體制運(yùn)作,技術(shù)作用不明顯

4、吃飽肚皮,難以維系理想

 

大道無(wú)形,大音希聲,牛叉的技術(shù)很多都是巧工,而真正的產(chǎn)業(yè)才是大無(wú)畏的研發(fā),我們只不過在投機(jī)取巧。

posted on 2012-08-05 19:18 萬(wàn)連文 閱讀(1734) 評(píng)論(0)  編輯 收藏 引用 所屬分類: richedit
簡(jiǎn)歷下載
聯(lián)系我

<2006年9月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567

常用鏈接

留言簿(66)

隨筆分類

隨筆檔案

相冊(cè)

搜索

  •  

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美大片免费观看| 中文日韩欧美| 日韩一级黄色大片| 亚洲一区二区三区色| 日韩午夜在线电影| 在线视频欧美精品| 亚洲男人影院| 久久激情综合网| 欧美成人xxx| 一本久久综合亚洲鲁鲁五月天| 亚洲免费观看视频| 亚洲欧美国产va在线影院| 久久se精品一区二区| 久久综合色88| 欧美日韩亚洲一区二区三区在线观看| 国产精品露脸自拍| 红杏aⅴ成人免费视频| 亚洲人成在线免费观看| 亚洲自拍高清| 欧美成人情趣视频| 亚洲香蕉网站| 猫咪成人在线观看| 国产精品一区二区久久| 在线精品国产成人综合| 亚洲一区二区三区免费在线观看| 久久久亚洲国产美女国产盗摄| 亚洲黑丝在线| 午夜精品久久久久久久久久久久久| 久久精品国产免费观看| 欧美日韩在线视频首页| 亚洲成人在线视频播放| 亚洲欧美日本另类| 亚洲国产经典视频| 久久国产精品99久久久久久老狼| 欧美好吊妞视频| 极品少妇一区二区三区精品视频| 亚洲天堂网在线观看| 老司机精品福利视频| 亚洲午夜久久久久久久久电影网| 欧美大片在线观看| 伊人婷婷久久| 欧美在线欧美在线| 在线性视频日韩欧美| 男女av一区三区二区色多| 国产一区二区丝袜高跟鞋图片| 亚洲一区二区欧美| 日韩亚洲欧美综合| 欧美日韩小视频| 中文在线一区| 夜夜嗨av一区二区三区| 欧美日韩成人精品| 日韩亚洲在线| 亚洲人成亚洲人成在线观看图片 | 欧美日韩亚洲另类| 在线 亚洲欧美在线综合一区| 小黄鸭精品密入口导航| 一区二区三区四区五区视频| 欧美影院在线| 欧美成人精品高清在线播放| 欧美日韩国产高清视频| 欧美日韩中文字幕日韩欧美| 欧美与欧洲交xxxx免费观看 | 欧美激情久久久久久| 国内一区二区三区在线视频| 久久不见久久见免费视频1| 亚洲视频一区在线| 国产精品自在线| 欧美在现视频| 久久国产直播| 亚洲国产一成人久久精品| 免费h精品视频在线播放| 久久综合给合久久狠狠色| 亚洲一区国产一区| 欧美伦理91| 欧美α欧美αv大片| 国产精品福利在线观看网址| 亚洲精选大片| 亚洲男人的天堂在线| 欧美日本乱大交xxxxx| 欧美电影免费观看高清完整版| 国产欧美日韩一区二区三区在线观看 | 亚洲综合色噜噜狠狠| 亚洲在线成人精品| 亚洲一区欧美激情| 榴莲视频成人在线观看| 在线日韩中文字幕| 亚洲国产日韩在线一区模特| 欧美精品黄色| 亚洲欧美一区二区原创| 久久大综合网| 亚洲精品免费在线| 在线综合亚洲| 在线不卡a资源高清| 亚洲激情成人在线| 欧美日韩精品二区第二页| 国产精品剧情在线亚洲| 免费视频一区二区三区在线观看| 欧美成年人视频网站欧美| 亚洲视频在线看| 欧美一区二区三区四区在线观看| 亚洲激情在线观看视频免费| 日韩午夜av在线| 国产在线欧美| 一本久久综合亚洲鲁鲁五月天| 国产一区二区三区的电影| 最近中文字幕日韩精品| 狠狠入ady亚洲精品| 这里只有精品视频| 亚洲精品女av网站| 久久国产精品色婷婷| 日韩视频一区二区在线观看 | 中文精品在线| 久久午夜电影网| 午夜精品一区二区在线观看| 农村妇女精品| 免费精品视频| 国产专区一区| 亚洲在线观看免费| 亚洲视频狠狠| 91久久在线播放| 久久久国产一区二区| 午夜在线一区二区| 欧美激情一区二区三区不卡| 久久久久国产成人精品亚洲午夜| 欧美日韩四区| 亚洲国产精品一区二区www在线| 国产亚洲一区二区精品| 中文在线资源观看网站视频免费不卡 | 亚洲免费电影在线| 麻豆久久久9性大片| 久久午夜影视| 国产一区二区三区久久久久久久久 | 樱花yy私人影院亚洲| 亚洲欧美日韩精品久久久| 亚洲一区二区三区精品动漫| 欧美精品久久久久久久久老牛影院 | 99伊人成综合| 欧美人成免费网站| 亚洲精品社区| 亚洲一级在线观看| 国产精品啊v在线| 亚洲一区二区免费在线| 亚洲午夜精品久久久久久浪潮 | 欧美精品九九99久久| 亚洲福利在线观看| 亚洲国产精品成人综合| 免费高清在线一区| 最新亚洲电影| 亚洲欧美日韩久久精品| 国产欧美日韩亚洲精品| 欧美一区二区三区在线播放| 久久国产精品一区二区| 国产一区二区电影在线观看| 久久国产免费| 亚洲高清免费在线| 亚洲一区二区在线| 国产一区二区三区在线观看免费视频| 久久精品成人一区二区三区| 老鸭窝91久久精品色噜噜导演| 亚洲国产精品久久久久秋霞影院| 欧美aⅴ99久久黑人专区| 99国产成+人+综合+亚洲欧美| 久久国产欧美精品| 亚洲精品123区| 国产精品毛片va一区二区三区| 久久99伊人| 91久久午夜| 久久精品动漫| 夜夜嗨网站十八久久| 国产午夜精品全部视频在线播放 | 欧美不卡激情三级在线观看| 国产一区视频在线观看免费| 欧美了一区在线观看| 亚洲一区二区三区中文字幕| 欧美一激情一区二区三区| 韩国成人福利片在线播放| 欧美高清视频一区二区| 亚洲天堂av在线免费| 免费在线亚洲欧美| 午夜激情久久久| 亚洲清纯自拍| 国内久久婷婷综合| 欧美吻胸吃奶大尺度电影| 久久九九热re6这里有精品| 亚洲美女色禁图| 美国十次成人| 久久国产视频网站| 亚洲一区二区在线观看视频| 亚洲国产精品一区制服丝袜 | 欧美国产日韩在线观看| 欧美在线91| 一本一本久久a久久精品牛牛影视| 一区二区高清视频| 极品日韩久久| 国产精品一区视频| 欧美日韩一区在线观看| 美女尤物久久精品| 性欧美大战久久久久久久免费观看 | 亚洲欧美日韩天堂| 亚洲欧美日韩精品久久|