c语言字模
A. c语言如何运用字模点阵显示文字
具体电
B. 在c语言中16*16汉字如何调节大小
16*16汉字,是指的汉字字模的点阵数。
这是改变不了的。
但你可以对它进行放大或缩小处理,但这样做会产生失真,因为点阵不是矢量的。放大后会产生边缘有锯齿效果。
调节大小,你可以考虑换字模,24,48,都可以,在程序中调用,画出点阵,显示出汉字来。
C. c语言字库编程问题
scanf("%s",&code); 换成gets(code);把code改的大一点就可以了
D. c语言怎样才能输出中文(最简单的方法)
起初,C语言没有官方标准。1978年由美国电话电报公司(AT&T)贝尔实验室正式发表了C语言。布莱恩·柯林汉(Brian Kernighan) 和 丹尼斯·里奇(Dennis Ritchie) 出版了一本书,名叫《The C Programming Language》。
这本书被 C语言开发者们称为K&R,很多年来被当作 C语言的非正式的标准说明。人们称这个版本的 C语言为K&R C。
K&R C主要介绍了以下特色:
结构体(struct)类型
长整数(long int)类型
无符号整数(unsigned int)类型
把运算符=+和=-改为+=和-=。因为=+和=-会使得编译器不知道使用者要处理i = -10还是i =- 10,使得处理上产生混淆。
即使在后来ANSI C标准被提出的许多年后,K&R C仍然是许多编译器的最 准要求,许多老旧的编译器仍然运行K&R C的标准。
1970到80年代,C语言被广泛应用,从大型主机到小型微机,也衍生了C语言的很多不同版本。
1983年,美国国家标准协会(ANSI)成立了一个委员会X3J11,来制定 C语言标准。
1989年,美国国家标准协会(ANSI)通过了C语言标准,被称为ANSI X3.159-1989 "Programming Language C"。因为这个标准是1989年通过的,所以一般简称C89标准。有些人也简称ANSI C,因为这个标准是美国国家标准协会(ANSI)发布的。
1990年,国际标准化组织(ISO)和国际电工委员会(IEC)把C89标准定为C语言的国际标准,命名为ISO/IEC 9899:1990 - Programming languages -- C 。
因为此标准是在1990年发布的,所以有些人把简称作C90标准。不过大多数人依然称之为C89标准,因为此标准与ANSI C89标准完全等同。
1994年,国际标准化组织(ISO)和国际电工委员会(IEC)发布了C89标准修订版,名叫ISO/IEC 9899:1990/Cor 1:1994,有些人简称为C94标准。
1995年,国际标准化组织(ISO)和国际电工委员会(IEC)再次发布了C89标准修订版,名叫ISO/IEC 9899:1990/Amd 1:1995 - C Integrity [7] ,有些人简称为C95标准。
E. 急!c语言如何显示汉字
先说明一下:在TC下面显示汉字是比较麻烦的,实在想用,可以用VC。
DOS下的点阵汉字
你是否碰到过用启动盘启动系统后用DIR命令得到一串串莫名其妙的字符?有经验的朋友会告诉你:那是汉字。汉字?你不禁会问:怎么一个我一个也不认识。但那确确实实是汉字,如果你启动UCDOS或其他的汉字系统后,就会看到那是一个个熟悉的汉字。同样是汉字,为什么前后会看到不同的结果?呵呵,其实在电脑硬件中,根本没有汉字这个概念,也没有英文的概念,这铁玩意认识的概念只有——内码。
☆汉字的内码
点头表示什么?是“对”、“YES”,偏偏有的地方表示的意义却恰恰相反。一个动作,有不同的诠释;一个问题,有不同的答案;而一个符号,却有不同的意义,关键在于:你是如何地理解。在电脑中亦如此,所有的数据都是以0和1保存的,按不同的数据操作,可以得到不同的结果。对于显示英文操作,由于英文字母种类很少,只需要8位(一字节)即可。而对于中文,常用却有5000以上,于是我们的DOS前辈想了一个办法,就是将ASCII表的高128个很少用到的数值以两个为一组来表示汉字,即汉字的内码。而剩下的低128位则留给英文字符使用,即英文的内码。不信,你可以用记事本写一C文件:
main()
{
unsigned char *s,*e="ABcd",*c="你好";
clrscr();
printf("English char =");
s=e;
while(*s!=0) /*C的字符串以0为结束符*/
{
printf("%3d,",*s);
s++;
}
printf("\nChinease char=");
s=c;
while(*s!=0)
{
printf("%3d,",*s);
s++;
}
getch();
}
再用TC输入*.txt打开运行,看见了没有,那些数值即英文和汉字的各字节内码。
☆汉字字模
得到了汉字的内码后,还仅是一组数字,那又如何在屏幕上去显示呢?这就涉及到文字的字模,字模虽然也是一组数字,但它的意义却与数字的意义有了根本的变化,它是用数字的各位信息来记载英文或汉字的形状。在硬件系统内,英文的字模信息一般固化在ROM里,即使在没有进入系统的CMOS里,也可以让你看到英文字符。而在DOS下,中文的字模信息一般记录在汉字库文件HZK16里。
☆汉字库文件
了解字母和汉字是按字模位信息显示的原理后,那如何得到汉字的字模信息呢?难道要我们自己去做?NO。DOS前辈们经过艰辛的努力,将制作好的字模放到了一个个标准的库中以免去后辈的麻烦,这就是点阵字库文件。一般我们使用16*16的点阵宋体字库,所谓16*16,是每一个汉字在纵、横各16点的区域内显示的。不过后来又有了HZK12、HZK24,HZK32和HZK48字库及黑体、楷体和隶书字库。虽然汉字库种类繁多,但都是按照区位的顺序排列的。前一个字节为该汉字的区号,后一个字节为该字的位号。每一个区记录94个汉字,位号则为该字在该区中的位置。因此,汉字在汉字库中的具体位置计算公式为:94*(区号-1)+位号-1。减1是因为数组是以0为开始而区号位号是以1为开始的。这仅为以汉字为单位该汉字在汉字库中的位置,那么,如何得到以字节为单位得到该汉字在汉字库中的位置呢?只需乘上一个汉字字模占用的字节数即可,即:(94*(区号-1)+位号-1)*一个汉字字模占用字节数,而按每种汉字库的汉字大小不同又会得到不同的结果。以16*16点阵字库为例,计算公式则为:(94*(区号-1)+(位号-1))*32。汉字库文该从该位置起的32字节信息即记录了该字的字模信息。
☆点阵汉字的显示
了解点阵汉字及汉字库的构成原理后,显示汉字就变得简单。以16*16点阵字库为例,通常的方法是:将文件工作指针移到需要的汉字字模处、将汉字库文件读入一2*16数组再用for循环一位位地显示。以使用VGAHI模式显示“我”字为例,程序如下:
#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;j<16;j++)
for(i=0;i<2;i++)
for(k=0;k<8;k++)
if(mat[j][i]&(0x80>>k)) /*测试为1的位则显示*/
putpixel(i*8+k,j,WHITE);
getch();
closegraph();
fclose(HZK);
}
怎么样?只要掌握了正确的方法,显示汉字并不复杂。
☆打印字库文件和HZK12
如果你有UCDOS的HZK24S(宋体)、HZK24K(楷体)或HZK24H(黑体),你还可以使用不同字体的大字模汉字了。HZK24系列是24*24的点阵字库,每字模占用3*24字节。如果你按照HZK16的显示方法的话,你会看到......呵呵,字被放倒了。这是因为该类字库与一般的汉字库不同,这类大字模汉字库是专供打印的打印字库,为了打印的方便将字模都放倒了,你使用时,只要将字模的位信息纵横转置显示即可。例如你如果定义为mat[24][3]则应该这样输出:
for(i=0;i<24;i++)
for(j=0;j<24;j++)
if((0x80>>i%8)&mat[j][i/8]) /*转置显示*/
putpixel(j+x,y+i,color);
还有一类字库HZK12,虽然属于标准字库类型,但如果你将它的字模当作12*12位计算的话,根本无法正常显示汉字。因为字库设计者为了使用的方便,字摸每行的位数均补齐为8的整数倍,于是实际该字库的位长度是16*12,虽然每行都多出了4位,但这4位都是0(不显示),并不影响显示效果。
☆理论差不多了下面是我写的一个实践例子
/*
*TC下的汉字显示演示程序
*LO几又VE 22:58 2005-5-23
*将hzk16文件放至TC安装目录下
*hzk16文件下载地址
*下载字体文件
*/
#include <graphics.h>
#include <stdio.h>
#define MAXX 640 /*屏幕宽度 */
#define MAXY 480 /*屏幕高度 */
#define WIDTH 20 /*每一汉字宽度*/
#define HIGH 20 /*每一汉字高度*/
int priChi(unsigned char *); /*中文打印函数,传入参数:中文数组指针 返回值 -1 异常 0 正常*/
int X=0; /*全局变量X Y控制中文打印格式*/
int Y=0;
int main()
{
char chinese[][60]={/*TC编译器不支持长行 所以将中文字符串以二维形式存放*/
"我放弃清华计算机专业的保送资格而选择参加高考的消息震撼了全校",
"从校长到班主任到各科目任课老师都找我谈过话我有点惊异他们的变",
"化在我获得全国信息大赛一等奖外加特别奖以前我似乎是个可有可无",
"的人物突然间变的如此的炙手可热我觉得我的大脑前所未有的不够用",
"说起这个特别奖还真的挺有意思虽然叫全国决赛但也无非是出几个笔",
"试题再弄个上机程序编一下限时总共是三小时规定语言是西语言或者",
"派司卡在我花了半个小时分别用两种语言把该程序完成后我觉得坐在",
"那实在是浪费我的大好青春于是我决定用汇编语言把它再写一遍本来",
"我准备用微操作的十六进制码写的但考虑到时间问题只好放弃有人说",
"是金子总会发光此话诚不欺我啊正当我热火朝天全心投入编程的时候",
"却不知道自己已经被某人注意了很久了三小时之后我走出考场之后某",
"人赶紧抓住我很兴奋的叫了一声小朋友这声小朋友直接导致我在数年",
"后还经常从噩梦中惊醒同时也是我拒绝清华邀请的直接导火索我们把",
"话题回到事发现场我在吓了很大一跳后把头转了回来一个瘦干老头正",
"抓着我的手两眼放光的样子还似乎是略带深情的看着我我全身鸡皮疙",
"瘩顿时争先恐后的向外钻我浑身一个机灵赶紧抖手老头似乎感觉到了",
"异样送开我的手略带尴尬的道小朋友我自我介绍一下我是清华大学计",
"算机系的主任受邀到比赛的现场观看顺便看看有没有什么可挖掘的人",
"才那个你明白我的意思吧这句话很是影响清华学生理解力在我心目中",
"的地位你这意思不就是认为我是可挖掘的人才吗我点了点头老头看我",
"能理解显的很兴奋然后开始滔滔不决的向我介绍清华计算机专业的实",
"力如何如何的雄厚在国内甚至国际是如何如何的有影响力最后满怀深",
"情的看了我眼严肃的告诉我他将代表清华计算机专业欢迎我去他们那",
"念书我苦苦忍耐着他的飞溅唾沫委婉的表示这件事非同小可我必须回",
"家和父母商量一下然后逃也似的离开当然第一个去的地方是卫生间我",
"的脸啊谁知道老头的唾沫会不会让我的脸起老年斑回到学校的一个礼",
"拜后我就接到了清华正式邀请这个消息经我班主任的乌鸦嘴迅速在全",
"校蔓延而后又经过各种渠道迅速汇总到我父母耳朵"};
if(-1 == priChi(chinese))
{ /*打印异常*/
printf("Press any key to exit...");
fflush(stdin);
getch();
return 1;
}
return 0;
}
int priChi(unsigned char *chi)
{
unsigned char mat[16][2];
int i=VGA,j=VGAHI,k;
int sec,pot;
FILE *HZK;
if((HZK=fopen("hzk16","rb"))==NULL) /*打开字体库文件*/
{
printf("Open style file (hzk16) failed!\n");
return -1;
}
initgraph(&i,&j,"");
while(*chi)
{
sec = *chi-0xa0; /*获得区码*/
pot = *(chi+1)-0xa0; /*获得位码*/
fseek(HZK,(94*(sec-1)+(pot-1))*32l,SEEK_SET);
fread(mat,32,1,HZK);
for(j=0;j<16;j++)
for(i=0;i<2;i++)
for(k=0;k<8;k++)
if(mat[j][i] & (0x80 >> k)) /*测试为1的位则显示*/
putpixel(X+i*8+k,Y+j,WHITE);
X += WIDTH; /*下一字符的横坐标*/
if(X >= MAXX)
{
X = 0;
Y += HIGH; /*下一字符的纵坐标*/
if(Y >= MAXY) /*满一页*/
{
printf("press any key to print other words");
getch();
system("cls"); /*清屏*/
Y = 0;
}
}
chi += 2; /*指针指向下一中文字符*/
}
getchar();
closegraph();
fclose(HZK);
return 0;
}
F. C语言是如何用16点阵方法输出汉字的
我们做手机,经常做这个,显示16点阵的汉字
其实这个跟c语言,没有多大关系,不过我们的手机软件的开发,全部用的都是c
16点阵的数据,通常是16行,16列的,每个点,用1个bit位表示
通常0表示白,即不用描点,1表示黑,需要在此处描个点
因此,用两个for循环,就能把一个16点阵的字符给绘制出来
到底如何绘制,要看显示设备了,我们用的是LCD
不同的设备,会有不同的驱动,也会有不同的描点函数的
G. c语言字模取反
方法1:把你程序写LCD的顺序改一下,写字模的时候顺序该个方向
方法2:取字模的时候就设置为镜像取模
H. C语言,我在‘点阵字模工具’上查到“我”的点阵宋体字模如下请问应该怎么弄才能打印出个“我”来
char wo16S[]={
/* 以下是 '我' 的 16点阵宋体 字模,32 byte */
0x06,0x40,0x38,0x50,0x08,0x48,0x08,0x48,
0x08,0x40,0xFF,0xFE,0x08,0x40,0x08,0x48,
0x0E,0x28,0x38,0x30,0xC8,0x20,0x08,0x50,
0x09,0x92,0x08,0x0A,0x28,0x06,0x10,0x02,
};
for (int i = 0; i < 16; i++)
{
for (int j = 0; j < 2; j++)
{
char ch = wo16S[i * 2 + j];
for (int k = 0; k < 8; k++)
{
int x = j * 8 + k; //X坐标
int y = i; //Y坐标
if (ch & (1 << (7 - k)))
{
DrawPixel(x, y); //把这里DrawPixel换成C语言中的画点操作函数
}
}
}
}
I. c语言汉字点阵字库
这个问题,是很经典的。
存储方式 你就按 顺序存就可以了,暂时可以不用考虑压缩的问题。
我这有一些代码,可能能帮到你
J. c语言字模问题
void drawmat(char *mat,int matsize,int x,int y,int color)
/*依次:字模指针、点阵大小、起始坐标(x,y)、颜色*/
{int i,j,k,n;
n=(matsize-1)/8+1;//n是点阵的列数
for(j=0;j<matsize;j++)//j代表点阵中第j行的字符意思
for(i=0;i<n;i++)//i代表点阵中第i列字符的意思
for(k=0;k<8;k++)//k代表在当前字模中,第k位的值
if(mat[j*n+i]&(0x80>>k)) /*测试为1的位则显示*/
putpixel(x+i*8+k,y+j,color);
}
你把字模的每个矩阵元素用二进制展开就知道k的意思了:
char shan16[]={
/* 以下是 '山' 的 16点阵宋体 字模,32 byte */
0x00,0x00,0x01,0x00,0x01,0x00,0x01,0x00,
0x01,0x00,0x01,0x00,0x01,0x08,0x21,0x08,
0x21,0x08,0x21,0x08,0x21,0xF8,0x2E,0x08,
0x30,0x08,0x00,0x00,0x00,0x00,0x00,0x00,
};
相当于:
0000 0000 0000 0000 0000 0001 0000 0000
0000 0001 0000 0000 0000 0001 0000 0000
0000 0001 0000 0000 0000 0001 0000 0000
0000 0001 0000 1000 0010 0001 0000 1000
0010 0001 0000 1000 0010 0001 0000 1000
0010 0001 1111 1000 0010 1110 0000 1000
0011 0000 0000 1000 0000 0000 0000 0000
0000 0000 0000 0000 0000 0000 0000 0000
最后得到:
_______________8________________
___________8___8________________
___________8___8________________
______8____8___8________8___8___
__8___8____8___8________8___8___
__8___8____8888_8888____8___8___
__88____________________8_______
________________________________