添加华语字库

要求:原操作系统代码里只是支撑了希伯来语呈现,需要做的是实现对这多少个系列的方块字全角帮忙。

hzk16的牵线以及简单的行使方法

HZK16字库是吻合GB2312标准的16×16点阵字库,HZK16的GB2312-80帮助的汉字有6763个,符号682个。其中顶尖汉字有3755个,按声序排列,二级汉字有3008个,按偏旁部首排列。大家在部分拔取场所根本用不到那般多汉字字模,所以在运用时就可以只领到部分字体作为己用。

HZK16字库里的16×16汉字一共需要256个点来呈现,也就是说需要32个字节才能达到突显一个熟视无睹汉字的目标。

我们知晓一个GB2312汉字是由三个字节编码的,范围为A1A1~FEFE。A1-A9为符号区,B0到F7为汉字区。每一个区有94个字符(注意:这只是编码的批准范围,不自然都有字型对应,比如符号区就有成千上万编码空白区域)。下面以汉字“我”为例,介绍如何在HZK16文本中找到它对应的32个字节的字样数据。

前面说到一个中国字占几个字节,这多少个中前一个字节为该汉字的区号,后一个字节为该字的位号。其中,每个区记录94个汉字,位号为该字在该区中的地方。所以要找到“我”在hzk16库中的地方就必须取得它的区码和位码。(为了区别使用了区码和区号,其实是一个事物,别被自己误导了)

区码:区号(汉字的首先个字节)-0xa0
(因为汉字编码是从0xa0区起初的,所以文件最前头就是从0xa0区先导,要算出相对区码)

位码:位号(汉字的第二个字节)-0xa0

如此这般我们就足以拿到汉字在HZK16中的相对偏移地方:

offset=(94*(区码-1)+(位码-1))*32

注脚:1、区码减1是因为数组是以0为始发而区号位号是以1为起初的

2、(94*(区号-1)+位号-1)是一个中国字字模占用的字节数

3、最终乘以32是因为汉字库文应从该职位起的32字节音信记录该字的字样信息(前面提到一个中国字要有32个字节突显)

 有了摇头地址就足以从HZK16中读取汉字编码了

落实思路:

  1. 刺探HZK编码,掌握一下适合GB2312标准的中文点阵字库文件HZK16;
  2. 下载中文GB2312的二进制点阵文件;
  3. 将HZK16.fnt文件放入nihongo文件夹中;
  4. 修改主makefile文件和app_make.txt文件,将原来装载nihongo.fnt的言辞替换成装载HZK16.fnt即可;
  5. 修改bootpack.c文件,将此前分配的装载西班牙语字体的内存扩充,载入字库的文件名;
  6. 在haribote/graphic.c中添加扶助汉字的代码,扩大一个函数用于显示汉字;
  7. 修改putfonts8_asc函数里if (task->langmode == 3)语句块;
  8. 测试程序。
  9. 专注:日文的编码是分为左半有的和右半部分,而我们运用的HZK16是分为上半部分和下半部分的。

此地其他的地点相比弄,第5步将大小修改一下,我的是nihongo = (unsigned
char *) memman_alloc_4k(memman, 55*94*32);

第6步,要小心,HZK16是左右两局部,不同于日文的左右两片段的布局。

代码如下:

void putfont32(char *vram, int xsize, int x, int y, char c, char *font1, char *font2)
{
    int i,k,j,f;
    char *p, d ;
    j=0;
    p=vram+(y+j)*xsize+x;
    j++;
    //上半部分
    for(i=0;i<16;i++)
    {
        for(k=0;k<8;k++)
        {
            if(font1[i]&(0x80>>k))
            {
                p[k+(i%2)*8]=c;
            }
        }
        if(i%2==0){
            for(k=0;k<4;k++){
                f=p[k];
                p[k]=p[7-k];
                p[7-k]=f;
            }
        }else{
            for(k=0;k<4;k++){
                f=p[k+8];
                p[k+8]=p[15-k];
                p[15-k]=f;
            }
        }
       /* for(k=0;k<8/2;k++)
        {
            f=p[k+(i%2)*8];
            p[k+(i%2)*8]=p[8-1-k+(i%2)*8];
            p[8-1-k+(i%2)*8]=f;
        }*/
        if(i%2)
        {
            p=vram+(y+j)*xsize+x;
            j++;
        }
    }
    //下半部分
    for(i=0;i<16;i++)
    {
        for(k=0;k<8;k++)
        {
            if(font2[i]&(0x80>>k))
            {
                p[k+(i%2)*8]=c;
            }
        }
        if(i%2==0){
            for(k=0;k<4;k++){
                f=p[k];
                p[k]=p[7-k];
                p[7-k]=f;
            }
        }else{
            for(k=0;k<4;k++){
                f=p[k+8];
                p[k+8]=p[15-k];
                p[15-k]=f;
            }
        }
        /*for(k=0;k<8/2;k++)
        {
            f=p[k+(i%2)*8];
            p[k+(i%2)*8]=p[8-1-k+(i%2)*8];
            p[8-1-k+(i%2)*8]=f;
        }*/
        if(i%2)
        {
            p=vram+(y+j)*xsize+x;
            j++;
        }
    }
    return;
}

 

运行结果,大家在euc.txt中出席一些中国字。

图片 1

参考资料:

1.https://www.cnblogs.com/wunaozai/p/3858473.html 30天操作系统协助中文。

相关文章