• <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>
            隨筆 - 16, 文章 - 0, 評論 - 55, 引用 - 0
            數(shù)據(jù)加載中……

            04 2014 檔案

            在windows下,當(dāng)FLTK界面上包含中文的時(shí)候啟動速度很慢,以下為修正過程
                 摘要: 問題描述:
            在windows下,當(dāng)FLTK界面包含中文的時(shí)候,打開程序的時(shí)候會花費(fèi)好幾秒的時(shí)間才能完整顯示界面

            原因:
            查了代碼,最后發(fā)現(xiàn)原因在于繪制字符的時(shí)候通過GetTextExtentPoint32W這個(gè)函數(shù)獲取字符寬度,由于這個(gè)函數(shù)本身速度不夠快,所以FLTK使用緩存方式來保存寬度,問題在于緩存的方式不適合中文這種寬字符,當(dāng)前的緩存方式是每當(dāng)獲取一個(gè)字符寬度時(shí),把這個(gè)字符左右共1024個(gè)相鄰字符的寬度提前獲取并保存,以后每次獲取字符寬度之前先搜索緩存,如果沒有再通過API實(shí)際獲取。

            這個(gè)做法對于英文沒有問題,因?yàn)镚etTextExtentPoint32W處理英文的速度很快,而且一次獲取1024個(gè)相鄰字符基本就把程序可能會用到的字符全部囊括了,但是當(dāng)界面出現(xiàn)中文的時(shí)候這種做法就出現(xiàn)問題了,中文的字符集是很大的,一次獲取相鄰個(gè)1024字符寬度并不能保證囊括了絕大多數(shù)的字符,所以每次界面顯示之前都會花很多時(shí)間獲取很多用不到的字符寬度,雖然顯示一次之后的速度很快,但是啟動程序的時(shí)候會出現(xiàn)卡頓

            所以我做了修正,每當(dāng)需要  閱讀全文

            posted @ 2014-04-29 17:28 cyantree 閱讀(2058) | 評論 (0)  編輯

            国产成人精品免费久久久久| 久久久久国产精品麻豆AR影院 | 人妻无码αv中文字幕久久琪琪布| 综合久久给合久久狠狠狠97色| 免费精品久久天干天干| 国产精品毛片久久久久久久| 免费精品久久久久久中文字幕| 少妇久久久久久久久久| 99久久亚洲综合精品网站| 亚洲精品久久久www| 91麻豆精品国产91久久久久久| 99蜜桃臀久久久欧美精品网站| 中文字幕亚洲综合久久| 无码人妻久久久一区二区三区| 久久国产高清一区二区三区| 久久大香香蕉国产| 久久人人爽人人人人爽AV| 99久久精品免费观看国产| 伊人久久大香线蕉AV色婷婷色| 精品国产综合区久久久久久| 久久er国产精品免费观看2| 午夜不卡久久精品无码免费| 奇米影视7777久久精品人人爽| 国产成人无码精品久久久久免费| 色综合久久久久久久久五月| 国内精品伊人久久久久777| 久久久久久国产精品无码下载 | 色综合久久无码中文字幕| 麻豆久久久9性大片| 青青草原综合久久大伊人| 久久有码中文字幕| 2020最新久久久视精品爱| 天天久久狠狠色综合| 成人a毛片久久免费播放| 曰曰摸天天摸人人看久久久| 久久久国产精品网站| 9191精品国产免费久久| 久久播电影网| 一本久道久久综合狠狠躁AV| 久久精品国产日本波多野结衣| 一本色道久久综合狠狠躁|