當前位置:編程學習大全網 - 編程語言 - 用C語言編程16點陣字庫

用C語言編程16點陣字庫

#include <stdio.h>

#include <alloc.h>

#include <ctype.h>

#include <dos.h>

#include <dir.h>

#include <io.h>

#include <graphics.h>

#define GETADR(n,str) (str *) calloc (n,sizeof(str)) // 申請N個指定字符串長度的地址

#define W16 16

#define C16 32

unsigned char bit[8]={0x80,0x40,0x20,0x10,0x08,0x04,0x02,0x01};

FILE *fi;

char *dot,str[20];

main(int argc,char *argv[])

{

int i,j,nn,xc,yc,MaxX,MaxY,menul[1000];

int graphdriver=DETECT,graphmode;

if(argc!=2){ //檢測是否輸入了2個參數

puts("LT16<.N4>");

exit(0);

}

dot=GETADR(C16,char); //獲取16個char長度的內存地址

fnmerge(str,"","",argv[1],".N4"); //建立str 為路徑 ,文件名是 第壹個參數.N4 的文件(這裏可能有bug,str沒初始化)

if((fi=fopen(str,"r"))==NULL){ //打開這個文件用於輸入

puts("Can't open DATA.");

exit(0);

}

fscanf(fi,"%d",&nn); //讀取壹個整數

if(nn<=0||nn>1000) //這個數字必須在 0~1000之間

exit(0);

for (i=0;i<nn;i++)

fscanf(fi,"%d",&menul[i]); //根據這個數字來決定繼續讀取的數字數量

fclose(fi);

if((fi=fopen("CLIB16.DOT","rb"))==NULL){ //打開 CLIB16.DOT 這個文件

puts("Can't open CLIB16.DOT");

exit(0);

}

initgraph(&graphdriver,&graphmode,""); // 初始化圖形模式

MaxX=getmaxx(); // 獲得屏幕最大坐標範圍

MaxY=getmaxy();

xc=0;

yc=20;

for(j=0;j<nn;j++){

i=readlibdot(menul[j]); //讀取點陣數據

putchar16(xc,yc); //顯示到對應的坐標系

xc+=20;

if(xc>MaxX-20){

yc+=20;

xc=0;

if(yc>MaxY-20){

getch();

clearviewport();

yc=0;

}

}

}

getch(); //按任意鍵繼續

closegraph(); //關閉圖形模式

}

readlibdot(int j)

{

int i0,j1,j2;

long order,k1;

j1=j/100;

j2=j-j1*100;

if(j1>=9)

j1=j1-6;

k1=94*j1+j2-95;

order=C16*k1;

fseek(fi,order,SEEK_SET);

i0=fread(dot,C16,1,fi);

return(i0);

}

putchar16(int bx,int by) //顯示readlibdot 得到的漢字(保存在dot 裏面)的每個象素點陣

{

int i,j,kk,k,x1,y1;

unsigned char marker;

kk=0;

y1=by;

for(i=0;i<16;i++,y1++){

for(j=0;j<2;j++){

x1=bx+j*8;

marker=*(dot+kk);

kk++;

for(k=0;k<8;k++){

if(!(marker&bit[k]))

continue;

putpixel(x1+k,y1,YELLOW);

}

}

}

return;

}

點陣字庫

壹般我們使用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循環壹位位地顯示。

#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);

}

  • 上一篇:武漢成人高考報名點在哪裏?有正規的嗎?
  • 下一篇:二叉樹的遍歷
  • copyright 2024編程學習大全網