資源描述:
《點(diǎn)陣漢字顯示方法源程序》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在行業(yè)資料-天天文庫。
1、點(diǎn)陣漢字顯示方法源程序(C語言)作者:佚名位置導(dǎo)航:?微控實(shí)驗(yàn)網(wǎng)?>>?51技術(shù)文章?>>由于TurboC應(yīng)用于DOS操作系統(tǒng)下,在使用TurboC進(jìn)行程序設(shè)計(jì)時(shí),一般情況下只好使用英文進(jìn)行人機(jī)交互。要是想直接用中文界面,就需要另想他法了?! ∪绻褂弥形腄OS系統(tǒng)(如UCDOS),則可以解決在字符界面下的漢字顯示問題。也就是說,可以用printf或其他字符串函數(shù)來輸出漢字?! 〉?,這樣仍然有一些不方便。必須先啟動(dòng)中文DOS系統(tǒng),再執(zhí)行TurboC或編譯好的程序。并且在中文版DOS下運(yùn)行TuborC時(shí),還可能出現(xiàn)一些問題。而對(duì)于圖
2、形界面來說,這種辦法也行不通了?! ∧敲丛趫D形界面下顯示漢字的問題就迫切需要解決了。既然是圖形界面,只要把漢字當(dāng)成一幅畫,畫在顯示屏上不就可以了。關(guān)鍵在于如何取得漢字的圖形,也就是漢字的點(diǎn)陣字模呢。其實(shí)那些中文版的DOS顯示漢字的方式也就是在圖形界面下畫出漢字的,它們已經(jīng)提供了現(xiàn)成的點(diǎn)陣字庫文件。例如常用的16×16點(diǎn)陣HZK16文件,12×12點(diǎn)陣HZK12文件等等,這些文件包括了GB2312字符集中的所有漢字?,F(xiàn)在只要弄清漢字點(diǎn)陣在字庫文件中的格式,就可以按照自己的意愿去顯示漢字了?! ∠旅嬉訦ZK16文件為例,分析取得漢字字模
3、的方法?! ZK16文件是按照GB2312-80標(biāo)準(zhǔn),也就是通常所說的國標(biāo)碼或區(qū)位碼的標(biāo)準(zhǔn)排列的。國標(biāo)碼分為94個(gè)區(qū)(Section),每個(gè)區(qū)94個(gè)位(Position),所以也稱為區(qū)位碼。其中01~09區(qū)為符號(hào)、數(shù)字區(qū),16~87區(qū)為漢字區(qū)。而10~15區(qū)、88~94區(qū)是空白區(qū)域?! ∪绾稳〉脻h字的區(qū)位碼呢?在計(jì)算機(jī)處理漢字和ASCII字符時(shí),使每個(gè)ASCII字符占用1個(gè)字節(jié),而一個(gè)漢字占用兩個(gè)字節(jié),其值稱為漢字的內(nèi)碼。其中第一個(gè)字節(jié)的值為區(qū)號(hào)加上32(20H),第二個(gè)字節(jié)的值為位號(hào)加上32(20H)。為了與ASCII字符區(qū)別開
4、,表示漢字的兩個(gè)字節(jié)的最高位都是1,也就是兩個(gè)字節(jié)的值都又加上了128(80H)。這樣,通過漢字的內(nèi)碼,就可以計(jì)算出漢字的區(qū)位碼。 具體算式如下: qh=c1-32-128=c1-160wh=c2-32-128=c2-160 或 qh=c1-0xa0wh=c2-0xa0 qh,wh為漢字的區(qū)號(hào)和位號(hào),c1,c2為漢字的第一字節(jié)和第二字節(jié)?! 「鶕?jù)區(qū)號(hào)和位號(hào)可以得到漢字字模在文件中的位置: location=(94*(qh-1)+(wh-1))*一個(gè)點(diǎn)陣字模的字節(jié)數(shù)?! ∧敲匆粋€(gè)點(diǎn)陣字模究竟占用多少字節(jié)數(shù)呢?我們來分析
5、一下漢字字模的具體排列方式?! ±缦聢D中顯示的“漢”字,使用16×16點(diǎn)陣。字模中每一點(diǎn)使用一個(gè)二進(jìn)制位(Bit)表示,如果是1,則說明此處有點(diǎn),若是0,則說明沒有。這樣,一個(gè)16×16點(diǎn)陣的漢字總共需要16*16/8=32個(gè)字節(jié)表示。字模的表示順序?yàn)椋合葟淖蟮接?,再從上到下,也就是先畫左上方?個(gè)點(diǎn),再是右上方的8個(gè)點(diǎn),然后是第二行左邊8個(gè)點(diǎn),右邊8個(gè)點(diǎn),依此類推,畫滿16×16個(gè)點(diǎn)。對(duì)于其它點(diǎn)陣字庫文件,則也是使用類似的方法進(jìn)行顯示。例如HZK12,但是HZK12文件的格式有些特別,如果你將它的字模當(dāng)作12*12位計(jì)算的話,根
6、本無法正常顯示漢字。因?yàn)樽謳煸O(shè)計(jì)者為了使用的方便,字模每行的位數(shù)均補(bǔ)齊為8的整數(shù)倍,于是實(shí)際該字庫的位長(zhǎng)度是16*12,每個(gè)字模大小為24字節(jié),雖然每行都多出了4位,但這4位都是0(不顯示),并不影響顯示效果。還有UCDOS下的HZK24S(宋體)、HZK24K(楷體)或HZK24H(黑體)這些打印字庫文件,每個(gè)字模占用24*24/8=72字節(jié),不過這類大字模漢字庫為了打印的方便,將字模都放倒了,所以在顯示時(shí)要注意把橫縱方向顛倒過來就可以了?! ∵@樣我們就完全清楚了如何得到漢字的點(diǎn)陣字模,這樣就可以在程序中隨意的顯示漢字了?! ∪绻?/p>
7、在程序中使用的漢字?jǐn)?shù)目不多,也可以不必總是在程序里帶上幾百K的字庫文件,也許你的程序才只有幾十K。這樣可以事先將所需要顯示的漢字字模提取出來,放在另一個(gè)文件里,按照自己的順序讀取文件就可以了?! ∠旅娴某绦蛘f明了具體顯示漢字的方法,以16×16漢字為例,使用HZK16文件。#include#include/*x,y為顯示坐標(biāo),s為顯示字符串,colour為顏色*/voidhanzi16(intx,inty,char*s,intcolour){FILE*fp;charbuffer[32];/*32字節(jié)的字模緩沖區(qū)*/registerI
8、,j,k;unsignedcharqh,wh;unsignedlonglocation;if((fp=fopen("hzk16","rb"))==NULL){printf("Cantopenhzk16!");getch();exit(