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

萬星星@豌豆莢 歡迎加入我們
一個吃軟飯的男人!!!!!我只想寫程序####
微博: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年8月>
303112345
6789101112
13141516171819
20212223242526
272829303112
3456789

常用鏈接

留言簿(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| 黄色一区二区三区四区| 国产小视频国产精品| 韩国一区二区三区美女美女秀| 国产一区二区三区在线观看免费| 极品少妇一区二区三区精品视频| 亚洲国产精品精华液网站| 亚洲精品视频一区| 亚洲男人的天堂在线| 快射av在线播放一区| 亚洲欧洲中文日韩久久av乱码| 嫩草国产精品入口| 亚洲精品日韩在线观看| 亚洲欧美99| 欧美福利一区二区| 国产精品一卡| 亚洲精品视频一区| 久久国产精彩视频| 欧美黑人多人双交| 亚洲欧美激情诱惑| 欧美ab在线视频| 国产精品系列在线| 亚洲久久在线| 久久综合狠狠综合久久综青草| 亚洲精品美女91| 久久精品中文字幕一区二区三区| 欧美巨乳在线| 在线看片第一页欧美| 午夜精品久久久久久久久久久久 | 在线视频欧美一区| 久久成人人人人精品欧| 亚洲精品少妇网址| 久久精品九九| 国产欧美精品久久| 99视频+国产日韩欧美| 久久久爽爽爽美女图片| 中国成人在线视频| 欧美另类极品videosbest最新版本 | 最近中文字幕mv在线一区二区三区四区 | 欧美日韩中文字幕在线| 亚洲国产精品女人久久久| 欧美亚洲一区| 日韩一区二区精品在线观看| 久久亚裔精品欧美| 精品成人一区二区三区| 久久av二区| 一区二区三区四区五区在线| 久久久久久9| 亚洲伦理在线免费看| 久久精品人人做人人综合| 国产精品女人毛片| 亚洲一区二区三区精品在线观看 | 久热国产精品视频| 久久成年人视频| 国产视频一区二区三区在线观看| 亚洲欧美激情视频在线观看一区二区三区| 亚洲国产一区二区a毛片| 久久久久99| 狠狠狠色丁香婷婷综合久久五月 | 国产精品自拍三区| 久久福利毛片| 久久九九精品| 亚洲高清电影| 亚洲欧洲综合另类| 欧美四级剧情无删版影片| 亚洲欧美成人一区二区在线电影 | 91久久久国产精品| 亚洲精品国产日韩| 国产精品v欧美精品v日韩 | 亚洲欧洲精品一区| 亚洲人在线视频| 欧美丝袜一区二区| 久久精品国产久精国产思思| 久久久久久欧美| 日韩视频一区| 亚洲欧美日韩一区二区在线| 激情丁香综合| 日韩一本二本av| 国产自产精品| 亚洲精品视频免费| 国产婷婷色一区二区三区在线| 久久亚洲电影| 欧美激情影院| 久久成人这里只有精品| 免费成人性网站| 亚洲一区二区免费视频| 欧美一区中文字幕| 99国产精品久久久久久久成人热| 一区二区三区四区蜜桃| 好吊色欧美一区二区三区四区| 亚洲国内高清视频| 国产日韩在线不卡| 亚洲欧洲日本国产| 国产亚洲制服色| 亚洲精品一区二区三| 国产亚洲福利| 日韩视频免费大全中文字幕| 精品白丝av| 午夜在线一区| 亚洲一区二区三区四区视频| 久久免费少妇高潮久久精品99| 国内精品久久久久久久影视麻豆| 亚洲国产婷婷| 亚洲欧美另类综合偷拍| 亚洲精品国产系列| 久久国产福利国产秒拍| 亚洲资源av| 欧美激情视频一区二区三区在线播放| 午夜精品视频| 欧美视频不卡| 最新成人av在线| 精品成人一区二区三区四区| 亚洲女优在线| 亚洲欧美中文日韩v在线观看| 欧美高清视频一区二区| 欧美二区视频| 亚洲高清视频一区二区| 久久久久免费观看| 久久久久久一区二区三区| 国产精品天美传媒入口| 一本一道久久综合狠狠老精东影业| 亚洲精品综合在线| 欧美国产精品一区| 亚洲国产日韩一区| 亚洲精品一二三| 欧美理论电影在线观看| 亚洲动漫精品| 亚洲精品国产精品国自产观看浪潮| 久久午夜电影网| 狂野欧美激情性xxxx欧美| 国精品一区二区三区| 欧美一级视频免费在线观看| 久久爱www| 国产在线视频欧美| 久久夜色精品| 亚洲人精品午夜在线观看| 99天天综合性| 欧美午夜视频网站| 亚洲午夜久久久久久久久电影院 | 亚洲视频在线一区观看| 午夜精品久久久久久久| 国产伦精品一区二区三区四区免费| 亚洲欧美视频在线观看| 久久精品国产欧美激情| 一区二区在线看| 欧美国产三级| 中文在线不卡| 久久久人成影片一区二区三区观看 | 亚洲天堂成人在线视频| 欧美视频第二页| 久久久久久自在自线| 久久九九99| 亚洲电影自拍| 欧美了一区在线观看| 亚洲视频你懂的| ●精品国产综合乱码久久久久| 久久综合色8888| 亚洲最黄网站| 久久久久久网址| 亚洲毛片在线| 国产欧美一区二区精品婷婷 | 一本久久综合亚洲鲁鲁| 亚洲一区二区三区四区视频 | 一区二区三区自拍| 欧美日韩国产电影| 先锋亚洲精品| 91久久夜色精品国产九色| 国产精品国内视频| 亚洲欧美美女| 亚洲日本成人在线观看| 久久精品国产清自在天天线| 亚洲欧洲精品一区二区三区不卡| 国产精品99免视看9| 久久精品国产一区二区电影| 亚洲日本成人| 蜜臀av性久久久久蜜臀aⅴ四虎| 一区二区日韩免费看| 韩国免费一区| 欧美日韩在线三区| 久久久久久亚洲精品杨幂换脸| 一本久道久久综合婷婷鲸鱼| 免费在线视频一区| 久久精品观看| 午夜免费在线观看精品视频| 日韩视频在线观看| 亚洲国产小视频| 国模套图日韩精品一区二区| 国产精品进线69影院| 欧美另类一区| 欧美国产精品中文字幕| 蜜桃精品久久久久久久免费影院| 欧美一区二区三区视频免费播放 | 麻豆成人在线|