C语言是如何用16点阵方法输出汉字的三篇
篇一:C语言是如何用16点阵方法输出汉字的
到目前为止,我们编写的C程序,其用于人机交互的提示或菜单都是英文的,那么如何在没有的Turbo C集成开发环境下编制显示汉字的程序呢?
解决这一编程问题,我们首先必须了解有关汉字编码及字库的知识。根据对汉字使
用频率的研究,可把汉字分成高频字(100),常用字(3000),次常用字(4000),罕见字(8000)和死字(45000),即正常使用的汉字达15000个。我国1981年公布了《通讯用汉字字符集(基本集)及其交换码标准》GB2312-80方案,把高频字、常用字、和次常用字集合成汉字基本字符集(6763),在该集中按汉字使用的频度,又将其分为一级汉字3755(按拼音排序)、二级汉字3008(按部首排序),再加上西文字母、数字、图形符号等700个。
国家标准的汉字字符集(GB2312—80)在汉字操作系统中是以汉字库的形式提供的。汉字库结构作了统一规定,即将字库分成94个区,每个区有94个汉字(以位作区别)每一个汉字在汉字库中有确定的区和位编号(用两个字节),这就是所谓的区位码(区位码的第一个字节表示区号,第二个字节表示位号,因而只要知道了区位码,就可知道该汉字在字库中的地址,每个汉字在字库中是以点阵字模形式存储的,如一般采用16×16点阵形式,每个点用一个二进位表示,存1
的点,当显示时,可以在屏上显示一个亮点,存0的点,则在屏上不显示,这样把存某字的16×16点阵信息直接用来在显示器上按上述原则显示,则将出现对应的汉字。
内码
汉字使用两字节表示,国家制定了统一标准,称为国标码。国标码规定,每个字节使用
后面7位,第一位为0。为了区别于英文的ASCII码,国标码在计算机上使用的时候,规定汉字每个字节第一位设置为1,以表示该两字节为汉字,称为内码。以“大”字为例子:国标码3473H0 0 1 1 0 1 0 0 0 1 1 1 0 0 1 1内码B4F3H1 0 1 1 0 1 0 0 1 1 1 1 0 0 1 1
国标码与内码有一定的转换公式,即16进制的区位码,两个字节各加80H,就成为了国标码。
汉字字模在字库中存放的位置根据汉字的区位码来确定,内码是汉字在机内的表示。由于区位码和内码存在固定的转换关系,所以当在支持汉字输入的系统中,键盘输入的汉字内码即在程序中存在,将其转换为区位码,再从字库中到对应的汉字字模,然后再用有关的位操作和循环语句,对每个字节的每一位进行判断,如同过滤一样,如果某位是1,则按设置的颜在屏幕的相应位置画点(用graphics.h中的显示象素点的函数putpixel()),若某位为0,则不画点,这样就可按预先设置的颜在相应位置显示出该汉字来。
内码到区位码的转换
若汉字内码为十六进制数h2h1l2l1,则区号qh相位号wh分别为:qh=h2h1-0xa0;wh=l2l1-0xa0
若用十进制表示内码为dld2,则qh=dl-l60
wh=d2-160;即区位码qw为:
qw=100*(d1-160)(d2-160);
反过来,若已经知道了区位码qw。则也可求得区号和位号:qh=qw/100
wh=qw-100*qh;
因而该汉字在汉字库中离起点的偏移位置(以字节为单位),可计算为:
offset=(94*(qh-1)+(wh-1))*32;
注意:字库中每1区有94个字符。
这样,就可以寻到文件的偏移量,读出一个char bytes[32]数组。这样bytes数组中则存了要显示汉字的16×16点阵字模,然后将字模按行扫描的办法,通过循环用putpixel()函数在屏幕设定位置显示出象点,因而组合成一个显示的汉字。
Cc语言怎么用printf语言中显示汉字
在许多C程序设计中,要用到汉字进行提示或人机交互,而现行的Turbo C集成开发环境不是的,如何编制能显示汉字的C程序呢?
下面的方法可以帮你在西文环境下显示汉字。这种方法是调用中文汉字库进行汉字显示。国家标准规定:汉字库分94个区,每个区有94个汉字(以位作区别),每个汉字在汉字库中有确定的区和位编号,这就是汉字的区位码。每个汉字在库中是以点阵字模形式存储的,一般采用16×16点阵(32字节)、24×24点阵(72字节),每个点用一个二进制位(01)表示,对应在屏幕上显示出来,就是相应的汉字。
由于在中文环境下,输入的是汉字的内码,我们必须将之转换成区位码,算出偏移量,从字库中到对应的汉字,将其字模显示即可。
内码转换成区位码方法如下:
qh=c10xa0 wh=c20xa0
其区位码就是:
qw=qh0xffwh
该汉字在字库中离起点的位置是:
offset=(94(qh1)+(wh1))32L
程序例:
includegraphics.h
includestdio.h
includefcntl.h
includeio.h
includestdlib.h
includeconio.h
define ROW 1//纵坐标放大倍数
define COL 2//横坐标放大倍数
void main(){
int x,y;
chars=″汉字显示程序″;
FILEfp;
char buffer[32];//buffer用来存储一个汉字
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)
//打开汉字库,该字库可以在ucdos中到
{printf(Cant open haz16,Please add it);
getch();closegraph();exit(0);
}
x=20;y=100;//显示位置设置
while(s)
{qh=(s)0xa0;//汉字区位码
wh=(s1)0xa0;
offset=(94(qh1)(wh1))32L;//计算该汉字在字库中偏移量
fseek(fp,offset,SEEK_SET);
fread(buffer,32,1,fp);//取出汉字32字节的点阵字模存入buffer中(一个汉字)
for(i=0;i16;i++)//32位字节的点阵按位在屏幕上打印出来(1:打印,0:不打印),显示汉字
for(n=0;nROW;n++)
for(j=0;j2;j++)
for(k=0;k8;k++)
for(m=0;mCOL;m++)
if(((buffer[i2j]〉〉(7k))0x1)!=NULL)
putpixel(x8jCOLkCOLm,yiROWn,GREEN);
s=2;//因为一个汉字内码占用两个字节,所以s必须加2
x=30;
}
getch();
closegraph();
}
上述程序在Turbo C 2.0编译系统下运行成功,它可以将汉字放大显示,读者可以将它改成函数用在您的程序中显示汉字。

篇二:C语言是如何用16点阵方法输出汉字的
//电路连接为:P1.0-P1.3连接4线-16线译码器控制每一列的扫描,
//P2P0口分别控制从上至下的16
//汉字取码方式为从上之下从左到右
#include<reg52.h>
void delayms(unsigned int xms);
void main()
{
int a,ab;        //用于半屏扫描
unsigned int c=0;//c作为ziku数组的计数器
int d=0,e=0;//d作为0~15竖屏扫描变量,一个字扫描e
int f=0;//汉字计数器
////////////////////////////////////////////////////////////////////////汉字字模库
unsigned char code hzdot[1632]={
/*C2020*/
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
/*we C7765*/
0x80,0x0F,0x80,0x30,0x00,0x0C,0x80,0x03,0x00,0x0C,0x80,0x30,0x80,0x0F,0x80,0x00,
0x00,0x00,0x00,0x1F,0x80,0x22,0x80,0x22,0x80,0x22,0x80,0x22,0x00,0x13,0x00,0x00,
/*d C2064*/
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x00,0x0E,0x00,0x11,0x80,0x20,0x80,0x20,0x88,0x10,0xF8,0x3F,0x00,0x20,

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。