摘要: 問題描述:
在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)需要
閱讀全文