在用Turbo C提供的圖形函數進行作圖時,為了使屏幕顯示更加直觀明瞭,常常需要在圖形顯示的同時,顯示必要的漢字説明,Turbo C在圖形狀態下快速顯示彩色漢字的方法。這時Turbo C提供的一些函數就不能用了。
在漢字操作系統中,有一個16×16點陣的漢字庫,主要用於屏幕顯示。字庫中的漢字按16×16點陣模式存儲,即每個漢字相當於16×16=256個點組成。佔用16×2=32個連續的字節單元。字節的每一位(bit)表示一個點的屬性:1表示亮點,0表示暗點。連續的兩個字節表示該漢字字模的一行。32個字節的排列順序如圖:
@@T5S08100.GIF;圖1@@
計算機對西文字符采用一個字節表示,我國規定漢字用內碼(2個字節)表示。為了保證中西文兼容,也就是説,漢字系統的內碼必須同時允許ASCII碼和漢字的同時使用,而兩者之間不能發生衝突。目前規定每個字節只用七位,若兩個字節的最高位均為1,則該字符為漢字。
國標對漢字庫的結構作了統一的規定:即將漢字庫分為若干個區,每個區有94個漢字。
每一個漢字在字庫中有一個固定的區和位,即每一個漢字有一個區位碼。知道了區位碼也就相當於知道了漢字在字庫中的位置。由於漢字的內碼與區位碼有一定的關係,所以,只要通過內碼就可以得到區位碼,從而也就得到了漢字的字模。
設一個漢字的內碼為ddff,則此漢字的區碼為dd-161;位碼為ff-161;該漢字字模的第一個字節在字庫中的位置是(94×區碼 位碼)×32。這時只要連續的讀出32個字節,就可以得到該漢字的字模。
有些文章和書籍採用寫點的方式來處理這32個字節。即某位為1,則寫點,某位為0,則不寫點。如果這樣處理,則每個漢字需循環256次,寫256個點,字數越多,則會顯得很慢。
Turbo C提供了這樣兩個函數:
setlinestyle(int linestyle,unsignedupattern,int thickness);
line(int x0,int y0,int x1,int y1);
setlinestyle函數為設置線型函數,當linestyle取USERBIT-LINE且thickness取NORM-WIDTH時,其後的line函數就會按upattern的16位二進制數畫一點寬的線,計算機論文《Turbo C在圖形狀態下快速顯示彩色漢字的方法》。upattern的每一位代表一個象元,如果那位為1,則該象元打開,否則該象元關閉。
我們在讀字模的時候可以一次讀2個字節,形成一個16位的'二進制數,把此二進制數設為upattern,然後畫線。這樣只需循環16次就可寫完一個漢字。速度得到很大的提高。尤其在字數較多時,更體現出此方法的優勢。
以下為用畫線的方法在西文狀態下顯示漢字的函數,在Turbo C 1.0、DOS6.0、兼容386機上運行通過。
#include
#include
#include
FILE *stream; //設 stream為全程變量//
void open-file
{//打開漢字庫函數,使用的漢字庫為UCDOS的16點陣字庫:HZK16//
if((stream=fopen("hzk16","rb"))==NULL)
{ printf("Can't Open File HZK16"); exit(1);}
}
void close-file
{//關閉漢字庫函數//
fclose(stream); return;
}
void write16(unsigned char *word,int x,int y,int wd,int col)
{//word為所要顯示的漢字串,x,y為要顯示漢字的起始座標,wd為兩個漢字//
//之間的間隔,col為要顯示漢字的顏色.//
register int k,i;
unsigned char cw[33];
char c[2];
unsigned long int qu-ma,wei-ma;
setcolor(col);settextstyle(0,HORIZ-DIR,1);
for(k=0;word[k]!='/0';k =2)