字模在c语言运行后出现乱码,C语言字模问题
C語言字模問題
來源:互聯網??2010-05-11 04:05:47??評論
分類: 電腦/網絡 >> 程序設計 >> 其他編程語言
問題描述:
哪位大俠幫我解釋下下面代碼,越詳細越好,急!!!!!
#include
#include
#include
#include
#include
#include
#define COL 2
#define ROW 2
int main(void)
{
int x,y;
char *s="崔錚";
FILE *fp;
char buffer[32];
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)
{ printf("Can’t open HZK16,Please add it");
getch(); closegraph(); exit(0);
}
x=280; y=220;
while(*s)
{ qh=*(s)-0xa0;
wh=*(s+1)-0xa0;
offset=(94*(qh-1)+(wh-1))*32L;
fseek(fp,offset,SEEK_SET);
fread(buffer,32,1,fp);
for (i=0;i<16;i++)
for(n=0;n
for(j=0;j<2;j++)
for(k=0;k<8;k++)
for(m=0;m
if (((buffer[i*2+j]>>(7-k))&0x1)!=NULL)
putpixel(x+8*j*COL+k*COL+m,y+i*ROW+n,BLUE);
s+=2;
x+=30;
}
getch();
closegraph();
}
參考答案:
這是個ucdos里面的字庫HZK16
,你分析一下他的存放點陣和對應漢字的關系.你先要知道這個點陣字庫組成方式:
while(*s)
{
qh=*(s)-0xa0;
wh=*(s+1)-0xa0;
/*將那每一個漢字的區位號算出來,一個漢字兩個字節,分別-a0和成他的區別碼*/
offset=(94*(qh-1)+(wh-1))*32L;
/*94表達漢字有94個區得到對應的在字庫的位置*32L表一個漢字點32字節,16*16除8=32/
fseek(fp,offset,SEEK_SET);
fread(buffer,32,1,fp);
/*讀取字庫到數據組*/
for (i=0;i<16;i++)
for(n=0;n
for(j=0;j<2;j++)
for(k=0;k<8;k++)
for(m=0;m
if (((buffer[i*2+j]>>(7-k))&0x1)!=NULL)
putpixel(x+8*j*COL+k*COL+m,y+i*ROW+n,BLUE);
/*按字節分解,相加對應的坐標,將對應的0和1過行畫點,1畫點,0不畫*就可以顯陽形漢字,如果相反則可以看到陰形的字/
s+=2;
x+=30;
/*進行相應的放大,和偏移*/
}
getch();
closegraph();
參考:
void ReadCCLIB(unsigned char high,unsigned char low,unsigned char *buf)
{
long p;
high=high-0xa0; /* 將內碼高字節轉換成區位碼 */
low=low-0xa0; /* 將內碼低字節轉換成區位碼 */
/* if(high>=15) high-=6; 對壓縮了10-15區的字庫,要此句.如王碼系統 */
p=(long)((high-1)*94+low-1)*32; /* 計算出漢字在漢字庫中的起始位置 */
fseek(cclibfp,p,SEEK_SET); /* 字庫定位 */
fread(buf,sizeof(unsigned char),32,cclibfp); /* 讀字庫32個字節 */
}
[b]分類:[/b] 電腦/網絡 >> 程序設計 >> 其他編程語言[br][b]問題描述:[/b][br]哪位大俠幫我解釋下下面代碼,越詳細越好,急!!!!!
#include
#include
#include
#include
#include
#include
#define COL 2
#define ROW 2
int main(void)
{
int x,y;
char *s="崔錚";
FILE *fp;
char buffer[32];
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)
{ printf("Can’t open HZK16,Please add it");
getch(); closegraph(); exit(0);
}
x=280; y=220;
while(*s)
{ qh=*(s)-0xa0;
wh=*(s+1)-0xa0;
offset=(94*(qh-1)+(wh-1))*32L;
fseek(fp,offset,SEEK_SET);
fread(buffer,32,1,fp);
for (i=0;i<16;i++)
for(n=0;n
for(j=0;j<2;j++)
for(k=0;k<8;k++)
for(m=0;m
if (((buffer[i*2+j]>>(7-k))&0x1)!=NULL)
putpixel(x+8*j*COL+k*COL+m,y+i*ROW+n,BLUE);
s+=2;
x+=30;
}
getch();
closegraph();
}[br][b]參考答案:[/b][br]這是個ucdos里面的字庫HZK16
,你分析一下他的存放點陣和對應漢字的關系.你先要知道這個點陣字庫組成方式:
while(*s)
{
qh=*(s)-0xa0;
wh=*(s+1)-0xa0;
/*將那每一個漢字的區位號算出來,一個漢字兩個字節,分別-a0和成他的區別碼*/
offset=(94*(qh-1)+(wh-1))*32L;
/*94表達漢字有94個區得到對應的在字庫的位置*32L表一個漢字點32字節,16*16除8=32/
fseek(fp,offset,SEEK_SET);
fread(buffer,32,1,fp);
/*讀取字庫到數據組*/
for (i=0;i<16;i++)
for(n=0;n
for(j=0;j<2;j++)
for(k=0;k<8;k++)
for(m=0;m
if (((buffer[i*2+j]>>(7-k))&0x1)!=NULL)
putpixel(x+8*j*COL+k*COL+m,y+i*ROW+n,BLUE);
/*按字節分解,相加對應的坐標,將對應的0和1過行畫點,1畫點,0不畫*就可以顯陽形漢字,如果相反則可以看到陰形的字/
s+=2;
x+=30;
/*進行相應的放大,和偏移*/
}
getch();
closegraph();
參考:
void ReadCCLIB(unsigned char high,unsigned char low,unsigned char *buf)
{
long p;
high=high-0xa0; /* 將內碼高字節轉換成區位碼 */
low=low-0xa0; /* 將內碼低字節轉換成區位碼 */
/* if(high>=15) high-=6; 對壓縮了10-15區的字庫,要此句.如王碼系統 */
p=(long)((high-1)*94+low-1)*32; /* 計算出漢字在漢字庫中的起始位置 */
fseek(cclibfp,p,SEEK_SET); /* 字庫定位 */
fread(buf,sizeof(unsigned char),32,cclibfp); /* 讀字庫32個字節 */
}
總結
以上是生活随笔為你收集整理的字模在c语言运行后出现乱码,C语言字模问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java适合初学者的编写软件分享
- 下一篇: pl/sql 中关于exception的