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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

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

發(fā)布時(shí)間:2023/12/9 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 字模在c语言运行后出现乱码,C语言字模问题 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

C語(yǔ)言字模問(wèn)題

來(lái)源:互聯(lián)網(wǎng)??2010-05-11 04:05:47??評(píng)論

分類: 電腦/網(wǎng)絡(luò) >> 程序設(shè)計(jì) >> 其他編程語(yǔ)言

問(wèn)題描述:

哪位大俠幫我解釋下下面代碼,越詳細(xì)越好,急!!!!!

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

}

參考答案:

這是個(gè)ucdos里面的字庫(kù)HZK16

,你分析一下他的存放點(diǎn)陣和對(duì)應(yīng)漢字的關(guān)系.你先要知道這個(gè)點(diǎn)陣字庫(kù)組成方式:

while(*s)

{

qh=*(s)-0xa0;

wh=*(s+1)-0xa0;

/*將那每一個(gè)漢字的區(qū)位號(hào)算出來(lái),一個(gè)漢字兩個(gè)字節(jié),分別-a0和成他的區(qū)別碼*/

offset=(94*(qh-1)+(wh-1))*32L;

/*94表達(dá)漢字有94個(gè)區(qū)得到對(duì)應(yīng)的在字庫(kù)的位置*32L表一個(gè)漢字點(diǎn)32字節(jié),16*16除8=32/

fseek(fp,offset,SEEK_SET);

fread(buffer,32,1,fp);

/*讀取字庫(kù)到數(shù)據(jù)組*/

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

/*按字節(jié)分解,相加對(duì)應(yīng)的坐標(biāo),將對(duì)應(yīng)的0和1過(guò)行畫(huà)點(diǎn),1畫(huà)點(diǎn),0不畫(huà)*就可以顯陽(yáng)形漢字,如果相反則可以看到陰形的字/

s+=2;

x+=30;

/*進(jìn)行相應(yīng)的放大,和偏移*/

}

getch();

closegraph();

參考:

void ReadCCLIB(unsigned char high,unsigned char low,unsigned char *buf)

{

long p;

high=high-0xa0; /* 將內(nèi)碼高字節(jié)轉(zhuǎn)換成區(qū)位碼 */

low=low-0xa0; /* 將內(nèi)碼低字節(jié)轉(zhuǎn)換成區(qū)位碼 */

/* if(high>=15) high-=6; 對(duì)壓縮了10-15區(qū)的字庫(kù),要此句.如王碼系統(tǒng) */

p=(long)((high-1)*94+low-1)*32; /* 計(jì)算出漢字在漢字庫(kù)中的起始位置 */

fseek(cclibfp,p,SEEK_SET); /* 字庫(kù)定位 */

fread(buf,sizeof(unsigned char),32,cclibfp); /* 讀字庫(kù)32個(gè)字節(jié) */

}

[b]分類:[/b] 電腦/網(wǎng)絡(luò) >> 程序設(shè)計(jì) >> 其他編程語(yǔ)言[br][b]問(wèn)題描述:[/b][br]哪位大俠幫我解釋下下面代碼,越詳細(xì)越好,急!!!!!

#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]這是個(gè)ucdos里面的字庫(kù)HZK16

,你分析一下他的存放點(diǎn)陣和對(duì)應(yīng)漢字的關(guān)系.你先要知道這個(gè)點(diǎn)陣字庫(kù)組成方式:

while(*s)

{

qh=*(s)-0xa0;

wh=*(s+1)-0xa0;

/*將那每一個(gè)漢字的區(qū)位號(hào)算出來(lái),一個(gè)漢字兩個(gè)字節(jié),分別-a0和成他的區(qū)別碼*/

offset=(94*(qh-1)+(wh-1))*32L;

/*94表達(dá)漢字有94個(gè)區(qū)得到對(duì)應(yīng)的在字庫(kù)的位置*32L表一個(gè)漢字點(diǎn)32字節(jié),16*16除8=32/

fseek(fp,offset,SEEK_SET);

fread(buffer,32,1,fp);

/*讀取字庫(kù)到數(shù)據(jù)組*/

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

/*按字節(jié)分解,相加對(duì)應(yīng)的坐標(biāo),將對(duì)應(yīng)的0和1過(guò)行畫(huà)點(diǎn),1畫(huà)點(diǎn),0不畫(huà)*就可以顯陽(yáng)形漢字,如果相反則可以看到陰形的字/

s+=2;

x+=30;

/*進(jìn)行相應(yīng)的放大,和偏移*/

}

getch();

closegraph();

參考:

void ReadCCLIB(unsigned char high,unsigned char low,unsigned char *buf)

{

long p;

high=high-0xa0; /* 將內(nèi)碼高字節(jié)轉(zhuǎn)換成區(qū)位碼 */

low=low-0xa0; /* 將內(nèi)碼低字節(jié)轉(zhuǎn)換成區(qū)位碼 */

/* if(high>=15) high-=6; 對(duì)壓縮了10-15區(qū)的字庫(kù),要此句.如王碼系統(tǒng) */

p=(long)((high-1)*94+low-1)*32; /* 計(jì)算出漢字在漢字庫(kù)中的起始位置 */

fseek(cclibfp,p,SEEK_SET); /* 字庫(kù)定位 */

fread(buf,sizeof(unsigned char),32,cclibfp); /* 讀字庫(kù)32個(gè)字節(jié) */

}

總結(jié)

以上是生活随笔為你收集整理的字模在c语言运行后出现乱码,C语言字模问题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。