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

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

最近工作上比較忙,加之編碼任務較多,沒來得及繼續之前的講解。抽出時間把這最重要的一部分東西做個闡述。行文以基本的編程思維及個人思考過程為線索。

 

眾所周知,RichEdir強大在于其圖文混排(在這里不跟Word、HTML比),其中的圖替換為動態圖的核心問題就歸結于如何高效刷新。我們知道GDI操作是最消耗CPU的,所以刷新整個RichEdit窗口是不可取的,其副作用會導致更嚴重的閃爍問題。解決問題的思路很簡單:類似于拖拽時候在屏幕繪制異或線,我們的動畫重繪時不請求RichEdit,而直接在其窗口的DC上繪制當前動畫幀,此時缺少是如何確定該OLE的位置,這個是所有問題的關鍵。先看下面這幅圖:

 

假定1-5全部都是GIF圖片,非GIF可以暫時無視,這個后面大家會非常清楚如何處理。在這個過程中,2不見了,而4是新出現的。對于4新出現時,RichEdit自身肯定會觸發其:

Draw(
    DWORD dwDrawAspect, LONG lindex, void* pvAspect,
    DVTARGETDEVICE* ptd, HDC hicTargetDev, HDC hdcDraw,
    LPCRECTL prcBounds, LPCRECTL prcWBounds,
    BOOL (__stdcall *pfnContinue)(DWORD_PTR dwContinue),
    DWORD_PTR dwContinue)

 

這個時候,我們知道新的GIF圖片進入可視區,可以把它添加到集合中。對于2的動畫觸發時間到來時,我們可以確定其位置且與可視區比對,發現其不再可視區,則從集合中移除。這樣就可以得到一個接近于(略大于)當前視口中的動畫控件集合,當有新的動畫觸發時間到來時,我們可以先檢查其是否在可視區,如果不在則不用GDI操作,僅僅更新其當前幀。當然這些工作你也可以不做,但是在動畫控件數量大的時候效率可能略有下降,主要是查找的過程(索引、位置)比較耗時。

 

如何確定一個OLE的位置呢?由于我們插入OLE都使用了REO_BELOWBASELINE標志,也就是跟當前行的底部對齊,所以OLE左下角位置的精確度對我們來說很重要。看下圖:

假設圖中黑框是一個OLE對象,其字符索引為CPN,假定第N+1行的第一個字符索引為CPN1,那么OLE左下角坐標={PosFromChar(CPN).x, PosFromChar(CPN1).y },PosFromChar這個是RichEdit提供的。問題的關鍵是最后一行怎么計算?此時沒有第N+1行。對于這種特殊情況,主要是Y坐標的計算,可以這樣考慮:Y=RichEdit內容高度-滾動條位置。猜測: 計算內容高度可能比較耗時,故QQ的聊天消息顯示部分強制在底部加了一行,以避免這種情況出現。

 

得到左下角位置以后,可能你會覺得就萬事大吉了。錯!還有一個關鍵點!我們可以通過OLE的接口GetExtent得到其大小,然而這個大小沒有考慮縮放比例,所以你需要根據當前縮放比例進行計算,而這個計算牽扯到浮點數運算,過程中的來回不僅麻煩而且不精確,所以OLE的可視大小要想非常精確是不能通過計算來的。我們前面知道OLE繪制的時候會傳入可視范圍,假如我們保存下來是不是就可以解決問題了呢?當然,顯然,你可以試試!

這些問題主要原因是RichEdit的很多接口方法沒有暴露,而Win8的SDK會做重大升級,很多之前的問題都會變成不是問題,或許還會引起更多的新特性,但是動畫本身的邏輯還是需要自己實現,或者會簡單許多,至于多少我還尚不清楚,但是目前來看這種方案效率足夠! 

 

到了這里,核心技術應該大白天下,整個過程,我追求了位置的精準度,并據此獲得最小可視集合進行刷新優化。

 

最新SDK&Demo,參見:http://code.google.com/p/im-solution/。希望你會喜歡!

posted on 2012-09-08 18:10 萬連文 閱讀(4849) 評論(16)  編輯 收藏 引用 所屬分類: 小作品richedit

FeedBack:
# re: richedit研究06 – 高效動畫刷新
2012-09-08 19:09 | iunkown
問一下,GIF對應的IOleInPlaceSite::GetWindowContext 取到的位置是否準確?為什么要用GetExtent呢?

我的一個實驗DEMO的SOURCE CODE如下,
http://m.shnenglu.com/Files/mcs51a/GifDisplayCtrl.rar

DEMO中代碼比較偷懶,可能有不準確的地方  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2012-09-08 19:39 | 萬連文
@iunkown
這個我沒有測試過,也沒有考慮過,不過確實是一種思路,你可以自己確認。但是我的方法未嘗不是好方法,不是么?


后來我看了你的東西,覺得就是前面說的毫無章法,無頭蒼蠅。你的那個鏈接我看了,連運行一下的心情都木有。  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2012-09-08 20:04 | 路障
呵呵,萬大俠,我之前以為你用了OLE接口的其它方法刷新的,原來也是直接在DC上面繪制的。

我還想問個問題,當你在DC上面繪制GIF幀的時候,你如何獲取RichEdit的背景顏色或者背景圖片?因為自己直接在DC上面繪制時,是不會像在OLE接口的Draw()函數里面那樣,已經由系統先繪制了背景的。  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2012-09-08 20:06 | 萬連文
@路障
看我的Demo,看我的接口,你就會發現我是怎么做的!!給我點面子唄。  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2012-09-09 11:30 | Loaf
一直RSS,博主非常高產啊……  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2012-09-09 12:32 | 萬連文
@Loaf
其實我非常少做項目,很多工作時間用來搞這些興趣。

我個人表示對RSS不太了解,有點土鱉。  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2012-09-09 15:50 | 路障
@萬連文

萬大俠,之前的評論絕對沒有取笑的意思。還是多虧了萬大俠,提供了這么多篇網上幾乎沒有詳細講的教程,使我們受益良多。否則還要走更多的彎路呢。繼續膜拜萬大俠。
  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2012-09-12 14:07 | M77
@Loaf

google Reader的RSS鏈接出現錯誤了
  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2012-09-12 14:09 | M77
@萬連文
樓主這SDK頭文件寫得很有Google的范  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2012-09-12 14:28 | 萬連文
@M77
過獎,回頭一看又發現幾個不標準的地方,努力遵守Google規范。  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2013-01-05 03:28 | 程旭
慨嘆天下文章一大抄,天下程序也是一大抄,就看你怎么抄,抄的有沒有思想,呵呵。老萬研究很透徹,盡管描述不適合初學者,但是非常不錯了。  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2013-01-05 20:36 | 程旭
全部重建感覺放棄ATL太浪費,盡管Ctrl鍵按的次數不多,呵呵。重建了Create其他可以沿用ATL也可以,這方面效率沒影響。繪制方法對效率可差萬倍。所以重點還是對richedit的擴展,STL使用必不可少,不嫌費事當然可以自己寫鏈表之類的。不知 萬老師 現在又開始研究什么新東西了?  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2013-01-05 22:54 | 萬連文
@程旭
最近這幾個月從研究webkit,轉向虛擬機字節碼,然后有轉向IDA OD學習,比較閑散自由無目的,但是沒有偷懶就好。  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2013-01-07 01:16 | 程旭
@萬連文
IDA對沒加密的很好用,OD對付加密的絕佳。  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2013-01-11 07:14 | 程旭
600動態表情同時顯示,CPU占用1%也許0%。  回復  更多評論
  
# re: richedit研究06 – 高效動畫刷新
2013-05-21 16:25 | 楊瀟
我來這里是為了感謝博主@萬連文 的。博主提供了從動畫OLE類要實現的接口,到如何精確地找出需重繪的動畫這一整套信息,在思路上的參考價值再怎么高估也不過分。

同時,通過對微軟WindowlessRE項目的參考,我終于成功地將無窗口模式的RichEdit、RichEdit動畫控件集成到了我們內部自己實現的DirectUI界面之中。

萬大俠提供的思路讓我節省了大量時間,少走了N多彎路。

再次謝謝萬大俠的分享!
  回復  更多評論
  
簡歷下載
聯系我

<2006年4月>
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>
            国产精品日韩在线一区| 99这里只有精品| 亚洲黄色av| 亚洲国产精品精华液2区45 | 久久精品卡一| 久久精品亚洲一区二区| 免费不卡在线视频| 欧美三级欧美一级| 国产欧美综合一区二区三区| 伊人伊人伊人久久| 亚洲另类在线视频| 亚洲欧美日韩国产中文在线| 久久狠狠亚洲综合| 亚洲国产mv| 亚洲三级免费观看| 亚洲一区二区三区视频播放| 午夜精品亚洲| 欧美黄在线观看| 国产女主播一区| 亚洲高清久久网| 亚洲女优在线| 欧美成人激情视频| 一区二区三区高清不卡| 久久久久99| 欧美午夜在线观看| 亚洲国产小视频在线观看| 亚洲欧美日韩另类| 亚洲成人自拍视频| 亚洲欧美美女| 欧美日韩hd| 在线成人小视频| 香港成人在线视频| 亚洲乱码一区二区| 久久综合伊人77777尤物| 国产精品国产自产拍高清av王其| 1024成人网色www| 欧美一区在线看| 日韩天堂在线观看| 一本色道久久精品| 在线日韩中文字幕| 欧美自拍偷拍午夜视频| 亚洲激情一区二区| 久久久久亚洲综合| 国产一区二区三区在线免费观看| 亚洲视频欧美在线| 91久久亚洲| 久久综合九色综合欧美狠狠| 国产一区二区视频在线观看| 久久久亚洲午夜电影| 国产欧美日韩一区二区三区在线| 在线亚洲免费视频| 欧美激情在线狂野欧美精品| 久久精品一区二区三区中文字幕| 国产精品久久久久久久久免费桃花| 亚洲精品1区2区| 欧美激情亚洲视频| 久久综合色影院| 黑人巨大精品欧美一区二区| 欧美一级片一区| 亚洲欧美另类国产| 国产精品一区二区三区久久久| 亚洲午夜激情| 亚洲视频一区二区| 欧美天天影院| 午夜精品三级视频福利| 亚洲欧美激情一区| 国产麻豆日韩欧美久久| 欧美在线视频不卡| 欧美影视一区| 伊人精品成人久久综合软件| 久久露脸国产精品| 久久久噜噜噜久久中文字幕色伊伊 | 99精品欧美一区二区三区| 亚洲第一精品影视| 欧美伦理a级免费电影| 一区二区av在线| 99在线观看免费视频精品观看| 国产精品久久久久永久免费观看| 午夜影院日韩| 久久久久久久久久久久久久一区 | 欧美另类综合| 先锋影音网一区二区| 久久久久久久高潮| 99视频超级精品| 亚洲永久免费精品| 在线日韩av永久免费观看| 最新国产成人av网站网址麻豆| 欧美日韩精品不卡| 久久久久久久91| 欧美精品激情在线| 久久精品免费播放| 欧美大片免费久久精品三p| 亚洲字幕在线观看| 久久久久久伊人| 亚洲午夜激情网页| 欧美精品一区二区久久婷婷| 一区电影在线观看| 久久精品人人做人人综合| 日韩午夜免费视频| 欧美在线一级va免费观看| 99在线视频精品| 久久9热精品视频| 亚洲视频视频在线| 久久久久久久久伊人| 亚洲一区二区高清| 另类天堂视频在线观看| 欧美一区二视频| 欧美日韩国产精品自在自线| 久久综合导航| 国产精品一香蕉国产线看观看 | 欧美黑人国产人伦爽爽爽| 亚洲在线观看免费视频| 久久综合伊人77777尤物| 欧美在线视频一区二区三区| 欧美成人一区二区在线| 久久三级福利| 国产伦精品一区二区三区照片91| 亚洲第一网站| 国内精品久久久久久| 亚洲午夜在线观看视频在线| 亚洲青涩在线| 老牛国产精品一区的观看方式| 欧美一区视频| 欧美网站在线| 在线一区二区日韩| 一本大道久久精品懂色aⅴ| 美脚丝袜一区二区三区在线观看| 久久精品国产精品亚洲| 国产日韩欧美三区| 午夜免费在线观看精品视频| 午夜视频精品| 国产精品久久久久影院亚瑟| 一本色道久久88综合亚洲精品ⅰ| 一区二区高清| 欧美视频一区二区三区…| 一区二区三区视频在线看| 亚洲一区免费| 国产精品亚发布| 午夜天堂精品久久久久| 久久xxxx| 狠狠爱www人成狠狠爱综合网| 欧美一级午夜免费电影| 久久久久久久一区| 一区视频在线看| 免费成人网www| 亚洲国产日韩一级| 日韩视频免费在线观看| 欧美日韩免费视频| 一区二区三区高清| 久久se精品一区二区| 在线成人激情| 欧美日韩1080p| 亚洲网站在线观看| 久久麻豆一区二区| 亚洲欧洲日产国产综合网| 欧美老女人xx| 午夜精品www| 模特精品裸拍一区| 日韩视频免费观看高清在线视频| 欧美日韩黄视频| 欧美一区二区三区婷婷月色 | 香蕉成人伊视频在线观看| 久久久国产视频91| 亚洲福利在线视频| 欧美日韩精品欧美日韩精品一| 日韩小视频在线观看专区| 久久精品卡一| 91久久国产综合久久91精品网站| 欧美肉体xxxx裸体137大胆| 亚洲欧美日韩精品在线| 欧美成人午夜剧场免费观看| 一区二区三区日韩精品视频| 国产欧美一区二区视频| 久久免费视频网| 亚洲人成在线观看网站高清| 亚洲欧美一区在线| 在线日本高清免费不卡| 国产精品白丝jk黑袜喷水| 久久久久综合网| 亚洲女性裸体视频| 欧美国产日韩一区二区| 亚洲欧美日韩天堂一区二区| 亚洲二区在线视频| 国产麻豆精品视频| 欧美久久成人| 久久野战av| 亚洲综合清纯丝袜自拍| 亚洲国产精品黑人久久久| 久久久福利视频| 午夜精品久久久| 99国产精品| 亚洲黄网站在线观看| 国产性色一区二区| 国产酒店精品激情| 欧美三级电影精品| 欧美大色视频| 你懂的视频一区二区| 久久久人成影片一区二区三区 | 亚洲欧美日韩精品一区二区| 日韩午夜激情av|