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

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

這里提及高效稍許有些夸張,僅為應景,因為本身就沒有太多高科技,權且作為一種有效的實現(xiàn)。

 

首先是圖片解碼器的選擇。一般來講有幾種選擇:1、組裝各種開源庫,如libpng, libjpg, giflib等,支持什么格式就得添加對應的解碼器;2、開源解碼包,如freeimage,沒用過但聽說也很不錯;3GDI+,支持圖片格式廣泛,接口簡單,性能一般。當然還有其它方式,大抵差不多。我選擇的是GDI+,圖簡便好用,且目前微軟支持的OS上都是自帶的,無需發(fā)布?!。對QQ的程序集DLL進行分析,發(fā)現(xiàn)其中貫穿了各種解碼技術,有直接采用開源庫的,也有依賴GDI+的,不知道是歷史遺留問題,還是各個部門之間技術偏好,抑或是另有玄機。扯到技術偏好,讓我頭疼的就是程序員在項目中隨意的引入庫,解決同一個問題,往往看到不同的人用不同的技術,甚至同一個人在不同的項目中造不同的輪子,有時候沒法說服別人,只能罷了。

 

GDI+的初始化需要注意一件事情:不要在DLL入口處加載或卸載GDI+,否則會發(fā)生鎖死現(xiàn)象,具體可查閱msdn

 

考慮到高性能的界面中可能會采用多線程UI,因此我建立了ThreadStateTLS對象,所有的數(shù)據(jù)都存儲在這個對象中,同步線程消息是通過慣用手法之隱藏窗口來保證。時至今日,或者早12年,我才深刻理解mfc庫設計時的那些state管理結構體的用處。GDI+的初始化在ThreadState構造函數(shù)中調用,正好避免了加載沖突這個問題。TLS對象的銷毀技巧來自谷歌的chromium源碼中的base庫里的tls實現(xiàn),原始出處來自CodeProjecthttp://www.codeproject.com/threads/tls.asp。嗯,其實牛逼的程序員也是縱覽乾坤,吸取精華。提到CodeProject,順帶提一下我的學習歷程,早期瘋狂的泡這個網(wǎng)站,幾乎VC方面的東西都把玩過,形成了自己的點狀知識積累,類似的有CodeGuruvckbase(現(xiàn)在已經(jīng)成為廣告站了);之后是 sourceforgecodegooglecodeplex 找一些小的項目研究,形成自己的線狀知識結構;再后來就是大型的源碼閱讀,偶爾會去谷歌討論組、微軟新聞組看一些疑難雜癥問題,構成了自己的面狀知識體系。每個人都有自己的學習方法論,這里僅僅是分享我自己的。很多東西都已經(jīng)看上去有些過時,現(xiàn)在的年輕程序員可能接觸的是stackoverflowgithub等。

 

GDI+中的Image是抽象接口,為了方便使用,增加了一層簡易封裝IMImage,主要接口如下:

 

static IMImage* FromFile(const std::wstring& uri);

long AddRef();
long Release();

const std::wstring& uri() const { return uri_; }
UINT frame_count() const { return frame_count_; }
bool IsAnimate() const { return frame_count_ > 1; }
long GetFrameDelay(UINT frame) const;
long GetWidth() const;
long GetHeight() const;
Gdiplus::Image* GetImage(UINT frame);

 

通過uri加載圖片,GDI+對本地圖片的加載非常簡單,Image::FromFile可以直接返回;對于網(wǎng)絡圖片,需要先通過WinINet下載到本地,然后再加載。

 

由于使用了tls技術,這里的引用計數(shù)實現(xiàn)很簡單,就是++-- 操作。曾經(jīng)有人告訴我引用技術是為了解決多線程中對象的生命周期問題,我欲與否認。引用計數(shù)只是為了解決對象的生命周期問題,而這種情況往往在多線程中出現(xiàn),因此多線程中或多或少會用到引用計數(shù)。

 

IMImage類可以簡單的返回一些GDI+Image對象提供的圖片信息,而GetImage需要多做一些事情。對于包含多幀圖片的文件,在繪制的時候需要通過GDI+Image::SelectActiveFrame方法選擇當前幀,該操作非常耗時,因此在加載圖片的時候,發(fā)現(xiàn)如果是多幀的,我們需要額外的decode_image_來解碼存放每一幀圖像,這樣除第一次渲染比較耗時外,后面的獲取都是非常快的。

 

GetFrameDelay函數(shù)是獲取某一幀之間的時間間隔,通過GDI+PropertyItem可以很容易的獲取。需要指出的是PropertyItem類使用起來卻不是類的方式,需要手動new出一塊內存,所以這里用一個結構體我看更合適,而且還是C風格的。

再增加一個IMImageService,管理整個系統(tǒng)中用到的IMImage對象,接口很簡單:

 

IMImage* GetImage(const std::wstring& uri);
void ReleaseImage(IMImage* image);

 

需要圖像就找它要,用完之后記得釋放即可。

 

這樣就完成了圖片的管理,目前來說足夠用,也非常簡單,不是么?

posted on 2012-06-17 09:48 萬連文 閱讀(2978) 評論(2)  編輯 收藏 引用 所屬分類: richedit

FeedBack:
# re: richedit研究03 – 高效圖片管理
2012-06-17 10:44 | 春秋十二月
boost中也有tls的實現(xiàn),早期的時候,我一直也想自己弄個tls,但至今沒動手,引用計數(shù)一是生命周期,二是共享資源。  回復  更多評論
  
# re: richedit研究03 – 高效圖片管理
2012-08-23 22:00 | 路障
對于包含多幀圖片的文件,在繪制的時候需要通過GDI+的Image::SelectActiveFrame方法選擇當前幀,該操作非常耗時,因此在加載圖片的時候,發(fā)現(xiàn)如果是多幀的,我們需要額外的decode_image_來解碼存放每一幀圖像,這樣除第一次渲染比較耗時外,后面的獲取都是非常快的。

解碼存放每一幀圖像,當一個GIF有很多幀的時候,也全部解碼出來,這樣會不會占用比較多的內存?  回復  更多評論
  
簡歷下載
聯(liá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>
            久久人人九九| 久久综合五月天婷婷伊人| 亚洲国产成人av在线| 久久久最新网址| 欧美成人一品| 一区二区三区四区蜜桃| 欧美区在线观看| 亚洲一区二区日本| 久久久久国产成人精品亚洲午夜| 国产一区二区按摩在线观看| 久久婷婷成人综合色| 亚洲大片免费看| 亚洲成在人线av| 亚洲女同在线| 亚洲国产精品专区久久| 欧美日韩在线直播| 久久国产手机看片| 亚洲日本中文字幕免费在线不卡| 亚洲一区久久久| 亚洲国产高清一区| 国产综合香蕉五月婷在线| 欧美日韩一区二区欧美激情| 久久综合给合| 午夜视频一区在线观看| 亚洲国产福利在线| 一本色道婷婷久久欧美| 国产精品爽黄69| 农村妇女精品| 久久精品视频免费播放| 亚洲欧美国产视频| 洋洋av久久久久久久一区| 欧美~级网站不卡| 久久九九久久九九| 亚洲第一中文字幕在线观看| 亚洲婷婷综合色高清在线| 欧美顶级大胆免费视频| 99国产精品视频免费观看一公开| 久久激情综合| 国产精品成人一区二区三区吃奶 | 欧美在线首页| 亚洲综合国产精品| 欧美黄色成人网| 欧美大片在线影院| 免费不卡亚洲欧美| 毛片av中文字幕一区二区| 国产精品视频99| 一本综合久久| 亚洲国产精品嫩草影院| 免费视频久久| 亚洲精品美女在线观看播放| 欧美在线亚洲综合一区| 国产精品亚洲аv天堂网| 亚洲香蕉成视频在线观看 | 日韩午夜在线视频| 亚洲免费成人| 亚洲视频精品| 亚洲欧美视频一区| 久久久精品2019中文字幕神马| 亚洲另类黄色| 亚洲视频在线一区| 欧美另类videos死尸| 亚洲国产日韩一级| 国产亚洲精品久久久久久| 亚洲一区二区在| 亚洲性av在线| 国产精品久久久久久av福利软件| 亚洲一区二区欧美日韩| 在线一区二区三区四区五区| 亚洲欧美日韩国产一区二区| 午夜精品久久久久久久99樱桃| 国产精品porn| 亚洲高清在线播放| 欧美高清在线视频观看不卡| 另类图片国产| 亚洲精品在线三区| 国产一区二区三区最好精华液| 久久久最新网址| 亚洲综合日本| 在线播放精品| 亚洲午夜在线观看| 在线综合亚洲| 国产日韩欧美制服另类| 最近中文字幕mv在线一区二区三区四区| 日韩一级精品| 在线亚洲+欧美+日本专区| 国产精品久久久久一区二区| 亚洲国产一区二区精品专区| 欧美a级一区| 欧美日韩另类视频| 午夜一区不卡| 欧美国产一区视频在线观看| 香蕉久久a毛片| 狠狠色丁香婷婷综合影院| 校园激情久久| 久久久精品免费视频| 一本一本a久久| 羞羞答答国产精品www一本| 亚洲高清123| 在线中文字幕一区| 亚洲国产精品久久精品怡红院| 亚洲国产高清一区| 国产午夜一区二区三区| 亚洲精品欧美精品| 国产一区二区三区奇米久涩| 亚洲高清视频在线| 国产欧美日韩麻豆91| 亚洲一区国产| 久久久久久久欧美精品| 亚洲午夜精品| 玖玖玖国产精品| 久久av老司机精品网站导航| 亚洲在线免费观看| 亚洲精品乱码久久久久| 免费成人美女女| 国产精品久久二区二区| 欧美高清免费| 黄色成人在线网站| 亚洲欧美在线观看| 亚洲一区二区高清| 欧美精品一区二区蜜臀亚洲| 亚洲精品久久久久久久久久久 | 久久久久91| 亚洲欧美日韩精品久久| 欧美日韩国产综合在线| 亚洲一区免费观看| 蜜臀久久99精品久久久画质超高清| 亚洲欧美美女| 欧美美女日韩| 亚洲欧洲日韩在线| 欧美日韩日本网| 亚洲国产一区二区三区在线播| 国内精品写真在线观看| 亚洲图色在线| 亚洲一区制服诱惑| 欧美视频精品在线| 日韩视频免费观看高清在线视频| 欧美成人午夜激情在线| 另类春色校园亚洲| 亚洲第一区在线| 正在播放日韩| 正在播放欧美视频| 欧美日韩国产成人精品| 国产日韩精品久久| 一区二区高清| 免费成人av| 亚洲特色特黄| 欧美日韩亚洲高清一区二区| 亚洲区国产区| 久久久久久国产精品mv| 久久嫩草精品久久久久| 国语自产精品视频在线看抢先版结局| 午夜精品免费| 久久精品一本久久99精品| 国产一区欧美| 久热这里只精品99re8久| 亚洲国产婷婷| 亚洲女爱视频在线| 国产色综合网| 欧美成人亚洲成人日韩成人| 欧美一区二区三区另类 | 亚洲一区二区三区视频播放| 美女诱惑黄网站一区| 欧美日韩福利| 国产亚洲毛片在线| 亚洲精品国产精品乱码不99按摩 | 欧美在线免费观看亚洲| 国产精品av一区二区| 午夜欧美大片免费观看| 久久久久久欧美| 亚洲大胆人体视频| 欧美日韩视频第一区| 一本色道久久88精品综合| 欧美日韩1234| 欧美一二区视频| 亚洲成人在线视频播放| 亚洲深夜av| 国户精品久久久久久久久久久不卡| 久久亚洲不卡| 亚洲免费大片| 久久婷婷人人澡人人喊人人爽| 欧美连裤袜在线视频| 亚洲神马久久| 欧美成人免费小视频| 亚洲一区二区三区四区五区午夜 | 欧美天天在线| 久久精品亚洲国产奇米99| 91久久精品国产91久久| 欧美亚洲综合网| 日韩视频一区| 国产精品日日摸夜夜摸av| 老司机免费视频一区二区| 亚洲一区二区在线免费观看视频 | 亚洲一级免费视频| 在线成人亚洲| 欧美一级艳片视频免费观看| 国产精品分类| 欧美xx视频| 久久成人18免费观看| 99在线热播精品免费| 日韩视频精品在线|