日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

字模在c语言运行后出现乱码,C语言字模问题

發布時間:2023/12/9 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 字模在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语言字模问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。