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

萬星星@豌豆莢 歡迎加入我們
一個吃軟飯的男人!!!!!我只想寫程序####
微博: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 萬連文 閱讀(4861) 評論(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年9月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567

常用鏈接

留言簿(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一区二区三区| 亚洲欧美久久| 韩国精品久久久999| 欧美大色视频| 欧美日韩另类字幕中文| 亚洲欧美日本视频在线观看| 亚洲尤物在线视频观看| 狠狠入ady亚洲精品| 欧美国产日韩在线| 欧美日韩国产一区| 欧美在线免费播放| 久久三级福利| 亚洲一区二区三区四区五区午夜 | 亚洲一区黄色| 午夜精品999| 在线精品国产欧美| 日韩午夜在线| 国产综合色精品一区二区三区| 男男成人高潮片免费网站| 欧美片在线观看| 欧美在线免费观看| 欧美韩日精品| 久久精品国产99国产精品| 美女国产精品| 欧美伊人久久久久久久久影院| 久久精品国产亚洲一区二区| 99这里只有久久精品视频| 亚洲欧美国产精品va在线观看| 亚洲福利国产| 亚洲欧美激情四射在线日| 亚洲电影免费在线观看| 亚洲在线观看免费视频| 亚洲精品一区二区三区四区高清| 中国亚洲黄色| 亚洲精品一区在线观看| 香蕉久久夜色精品国产| 日韩亚洲欧美一区| 久久久视频精品| 欧美怡红院视频| 欧美日韩在线观看一区二区| 美女露胸一区二区三区| 国产精品一区毛片| 亚洲免费成人av| 一区二区三区在线视频免费观看| 国产精品99久久久久久宅男| 日韩视频免费看| 久久久久在线观看| 久久国产精品99精品国产| 欧美日韩国产首页在线观看| 欧美激情中文字幕一区二区 | 久久精品男女| 欧美一区二区高清在线观看| 欧美日韩在线观看一区二区| 亚洲高清不卡av| 一区二区在线观看视频在线观看| 亚洲专区国产精品| 午夜精彩国产免费不卡不顿大片| 欧美日韩午夜剧场| 日韩一区二区免费高清| av成人毛片| 欧美日韩精品一区二区天天拍小说| 欧美mv日韩mv国产网站| 黄色综合网站| 久久久久国产精品麻豆ai换脸| 欧美一级午夜免费电影| 国产精品五区| 午夜亚洲福利在线老司机| 欧美一级欧美一级在线播放| 国产欧美69| 欧美一区二区日韩| 久久人91精品久久久久久不卡 | 欧美精品午夜视频| 亚洲激情电影中文字幕| 亚洲精品综合精品自拍| 欧美日本国产视频| 亚洲视频观看| 性久久久久久久| 国产一区自拍视频| 久久人人爽国产| 亚洲激情小视频| 亚洲午夜精品久久| 国产精品一区二区在线观看不卡 | 亚洲成人在线视频播放 | 欧美午夜无遮挡| 亚洲新中文字幕| 久久免费视频网站| 亚洲国产精品一区二区尤物区| 蜜桃av久久久亚洲精品| 亚洲人成网站777色婷婷| 亚洲一区免费看| 国产亚洲激情| 免费观看在线综合| 一区二区三区四区精品| 久久精品女人天堂| 亚洲精品免费电影| 国产精品h在线观看| 久久成人精品无人区| 亚洲福利专区| 香蕉尹人综合在线观看| 亚洲二区免费| 国产精品黄色| 久久综合网络一区二区| 一区电影在线观看| 久久亚洲影音av资源网| 99热免费精品| 狠狠综合久久av一区二区老牛| 欧美国产日产韩国视频| 欧美一级大片在线免费观看| 亚洲国产精品久久久久婷婷老年| 亚洲在线成人精品| 亚洲欧洲中文日韩久久av乱码| 国产精品高精视频免费| 欧美成人激情视频| 欧美在线一区二区三区| 中国成人亚色综合网站| 亚洲第一区色| 久久综合狠狠综合久久综合88| 亚洲视频每日更新| 亚洲区一区二| 国产一区二区三区四区hd| 国产精品福利在线观看网址| 可以看av的网站久久看| 欧美一级视频精品观看| 一本色道久久综合亚洲精品不| 老司机精品福利视频| 香港久久久电影| 亚洲一区二区精品视频| 亚洲精品永久免费| 亚洲激情av| 亚洲国产精品久久久久婷婷老年| 久久深夜福利| 欧美淫片网站| 性做久久久久久久久| 亚洲性视频网址| 一本色道久久综合狠狠躁篇的优点| 在线播放精品| 一区二区三区我不卡| 韩日精品在线| 影音先锋欧美精品| 尤物在线精品| 亚洲福利视频一区二区| 黑人一区二区| 黑丝一区二区| 永久免费视频成人| 在线看片成人| 亚洲人体大胆视频| 日韩视频在线观看国产| avtt综合网| 亚洲综合色网站| 午夜精品久久久久久久白皮肤| 亚洲免费影视| 欧美制服丝袜第一页| 久久国产精品99国产精| 久久深夜福利| 欧美电影在线| 亚洲日本欧美| 亚洲一区二区三区四区中文| 午夜精彩视频在线观看不卡 | 午夜精品视频| 久久久精品午夜少妇| 欧美成人dvd在线视频| 欧美成人精品1314www| 欧美日韩免费看| 国产精品影音先锋| 国内精品视频一区| 亚洲精品社区| 亚洲欧美一区二区激情| 久久九九免费视频| 欧美国产一区二区| 99天天综合性| 久久精品免费电影| 欧美国产一区二区三区激情无套| 欧美性事在线| 激情综合网址| 亚洲校园激情| 久久午夜激情| 亚洲精品在线观看免费| 午夜视频一区在线观看| 免费在线欧美视频| 国产精品乱码人人做人人爱| 亚洲国产黄色片| 亚洲综合999| 欧美大片免费观看在线观看网站推荐| 日韩视频在线免费| 久久午夜视频| 国产精品制服诱惑| 日韩系列欧美系列| 老司机精品视频网站| 在线视频欧美日韩精品| 裸体丰满少妇做受久久99精品| 国产精品国码视频| 日韩一级成人av| 免费短视频成人日韩| 亚洲午夜三级在线| 欧美日韩国语|