c语言点阵函数 c语言点阵图( 二 )


通常的方法是:将文件工作指针移到需要的汉字字模处、将汉字库文件读入一2*16数组再用for循环一位位地显示 。
#include "graphics.h"
#include "stdio.h"
main()
{ int i=VGA,j=VGAHI,k;
unsigned char mat[16][2],chinease[3]="我";
FILE *HZK;
if((HZK=fopen("hzk16","rb"))==NULL)exit(0);
initgraph(i,j,"");
i=chinease[0]-0xa0;j=chinease[1]-0xa0; /*获得区码与位码*/
fseek(HZK,(94*(i-1)+(j-1))*32l,SEEK_SET);
fread(mat,32,1,HZK);
for(j=0;j16;j++)
for(i=0;i2;i++)
for(k=0;k8;k++)
if(mat[j][i](0x80k)) /*测试为1的位则显示*/
putpixel(i*8+k,j,WHITE);
getch();
closegraph();
fclose(HZK);
}
c语言数组输出点阵的问题 , 具体问题如图可以将这个功能封装为一个函数 。
传入数组首地址,以及数组长度 。
以循环方式 , 对数组逆序遍历即可 。
代码:
void revers_print(int *a, int l)
{
int i;
for( i = l-1; i =0; i -- )
printf("%d,",a[i]);
return 0;
}
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 , 以表示该两字节为汉字,称为内码 。以“大”字为例子:
国标码3473H: 0 0 1 1 0 1 0 0 0 1 1 1 0 0 1 1
内码B4F3H: 1 0 1 1 0 1 0 0 1 1 1 1 0 0 1 1
国标码与内码有一定的转换公式,即16 进制的区位码 , 两个字节各加80H,就成为了
国标码 。
汉字字模在字库中存放的位置根据汉字的区位码来确定,内码是汉字在机内的表示 。由
于区位码和内码存在固定的转换关系,所以当在支持汉字输入的系统中,键盘输入的汉字内
码即在程序中存在,将其转换为区位码,再从字库中找到对应的汉字字模 , 然后再用有关的

推荐阅读