在C程序中顯示漢字
發(fā)布時(shí)間:2008-08-23 閱讀數(shù): 次 來(lái)源:網(wǎng)樂(lè)原科技
在許多C程序設(shè)計(jì)中,要用到漢字進(jìn)行提示或人機(jī)交互,而現(xiàn)行的Turbo C集成開發(fā)環(huán)境不是漢化的,如何編制能顯示漢字的C程序呢?
下面的方法可以幫你在西文環(huán)境下顯示漢字。這種方法是調(diào)用中文漢字庫(kù)進(jìn)行漢字顯示。國(guó)家標(biāo)準(zhǔn)規(guī)定:漢字庫(kù)分94個(gè)區(qū),每個(gè)區(qū)有94個(gè)漢字(以位作區(qū)別),每個(gè)漢字在漢字庫(kù)中有確定的區(qū)和位編號(hào),這就是漢字的區(qū)位碼。每個(gè)漢字在庫(kù)中是以點(diǎn)陣字模形式存儲(chǔ)的,一般采用16×16點(diǎn)陣(32字節(jié))、24×24點(diǎn)陣(72字節(jié)),每個(gè)點(diǎn)用一個(gè)二進(jìn)制位(0或1)表示,對(duì)應(yīng)在屏幕上顯示出來(lái),就是相應(yīng)的漢字。
由于在中文環(huán)境下,輸入的是漢字的內(nèi)碼,我們必須將之轉(zhuǎn)換成區(qū)位碼,算出偏移量,從字庫(kù)中找到對(duì)應(yīng)的漢字,將其字模顯示即可。
內(nèi)碼轉(zhuǎn)換成區(qū)位碼方法如下:
qh=c1-0xa0 wh=c2-0xa0
其區(qū)位碼就是:
qw=qh*0xff+wh
該漢字在字庫(kù)中離起點(diǎn)的位置是:
offset=(94*(qh-1)+(wh-1))*32L
程序例:
?。nclude 〈graphics.h〉
?。nclude 〈stdio.h〉
?。nclude 〈fcntl.h〉
?。nclude 〈io.h〉
#include 〈stdlib.h〉
?。nclude 〈conio.h〉
?。efine ROW 1 //縱坐標(biāo)放大倍數(shù)
#define COL 2 //橫坐標(biāo)放大倍數(shù)
void main()
{
int x,y;
char *s=″漢字顯示程序″;
FILE *fp;
char buffer[32]; //buffer用來(lái)存儲(chǔ)一個(gè)漢字
register m,n,i,j,k;
unsigned char qh,wh;
unsigned long offset;
int gd=DETECT,gm; //圖形屏幕初始化
initgraph(&gd,&gm,″ ″);
if ((fp=fopen(″hzk16″,″rb″))==NULL)
//打開漢字庫(kù),該字庫(kù)可以在ucdos中找到
{ printf(″Can't open haz16,Please add it″);
getch(); closegraph(); exit(0);
}
x=20; y=100; //顯示位置設(shè)置
while(*s)
{ qh=*(s)-0xa0; //漢字區(qū)位碼
wh=*(s+1)-0xa0;
offset=(94*(qh-1)+(wh-1))*32L; //計(jì)算該漢字在字庫(kù)中偏移量
fseek(fp,offset,SEEK_SET);
fread(buffer,32,1,fp); //取出漢字32字節(jié)的點(diǎn)陣字模存入buffer中(一個(gè)漢字)
for (i=0;i〈16;i++) //將32位字節(jié)的點(diǎn)陣按位在屏幕上打印出來(lái)(1:打印,0:不打印),顯示漢字
for(n=0;n〈ROW;n++)
for(j=0;j〈2;j++)
for(k=0;k〈8;k++)
for(m=0;m〈COL;m++)
if (((buffer[i*2+j]〉〉(7-k))&0x1)!=NULL)
putpixel(x+8*j*COL+k*COL+m,y+i*ROW+n,GREEN);
s+=2; //因?yàn)橐粋€(gè)漢字內(nèi)碼占用兩個(gè)字節(jié),所以s必須加2
x+=30;
}
getch();
closegraph();
}
上述程序在Turbo C 2.0編譯系統(tǒng)下運(yùn)行成功,它可以將漢字放大顯示,讀者可以將它改成函數(shù)用在您的程序中顯示漢字。