《30天自制操作系统》实现中文显示
2014-07-21 15:27
197 查看
《30天自制操作系统》最近一直再看,最近已经看到后面了,看到第28天,里面讲到可以实现对全角字符的支持,而原操作系统代码里面只是支持了日语显示,而中文版的这本书也只是讲了一个思路,具体的实现也是没有的。网上也好像没有人实现过这个吧,我是找不到。(由于书中每一章每一小节都有代码,我看书的时候就懒得去实际写代码,就简单看看。不过这次就可以写一下了,加深对这个系统的了解)反正没事做,就准备实现对这个系统的汉字全角支持。
一、了解HZK编码
在改造之前,我们先了解一下符合GB2312标准的中文点阵字库文件的HZK16。百度搜索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个汉字,位号为该字在该区中的位置。
区码和区号,其实是一个东西
区码:区号(汉字的第一个字节)- 0xa0 (因为汉字编码是从0xa0区开始的,所以文件最前面就是从0xa0区开始,要算出相对区码)
位码:位号(汉字的第二个字节)- 0xa0
这样我们就可以得到汉字在HZK16中的绝对偏移位置:
offset=(94*(区码-1)+(位码-1))*32
注解: 1、区码减1是因为数组是以0为开始而区号位号是以1为开始的
2、(94*(区号-1)+位号-1)是一个汉字字模占用的字节数
3、最后乘以32是因为汉字库文应从该位置起的32字节信息记录该字的字模信息(前面提到一个汉字要有32个字节显示)
二、添加代码
首先查看一下c语言里面的中文编码是否真的跟书上讲的是否一样。我们先修改iroha/iroha.c这个文件,代码如下
View Code
修改putfonts8_asc函数里if (task->langmode == 3)语句块里这两句
为
终于改完了,应该可以了,有点小激动了,赶快make run一下
艾玛总算可以实现中文了。
参考资料
HZK编码 链接
所用到的工具和可以显示中文的代码:http://files.cnblogs.com/wunaozai/OS-in-30-days.zip
本文地址:/article/6193115.html
一、了解HZK编码
在改造之前,我们先了解一下符合GB2312标准的中文点阵字库文件的HZK16。百度搜索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个汉字,位号为该字在该区中的位置。
区码和区号,其实是一个东西
区码:区号(汉字的第一个字节)- 0xa0 (因为汉字编码是从0xa0区开始的,所以文件最前面就是从0xa0区开始,要算出相对区码)
位码:位号(汉字的第二个字节)- 0xa0
这样我们就可以得到汉字在HZK16中的绝对偏移位置:
offset=(94*(区码-1)+(位码-1))*32
注解: 1、区码减1是因为数组是以0为开始而区号位号是以1为开始的
2、(94*(区号-1)+位号-1)是一个汉字字模占用的字节数
3、最后乘以32是因为汉字库文应从该位置起的32字节信息记录该字的字模信息(前面提到一个汉字要有32个字节显示)
二、添加代码
首先查看一下c语言里面的中文编码是否真的跟书上讲的是否一样。我们先修改iroha/iroha.c这个文件,代码如下
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; } } 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; } } 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; }
View Code
修改putfonts8_asc函数里if (task->langmode == 3)语句块里这两句
putfont8(vram, xsize, x - 8, y, c, font ); putfont8(vram, xsize, x , y, c, font + 16);
为
putfont32(vram,xsize,x-8,y,c,font,font+16);
终于改完了,应该可以了,有点小激动了,赶快make run一下
艾玛总算可以实现中文了。
参考资料
HZK编码 链接
所用到的工具和可以显示中文的代码:http://files.cnblogs.com/wunaozai/OS-in-30-days.zip
本文地址:/article/6193115.html
相关文章推荐
- 30天自制操作系统之第11天 制作窗口
- 30天自制操作系统之第15天 多任务(1)
- 30天自制操作系统第一周(二)
- 30天自制操作系统第八天学习笔记(u盘软盘双启动版本)
- 《30天自制操作系统》之——第05天
- 30天自制操作系统第九天
- 《30天自制操作系统》学习笔记--第13天
- <30天自制操作系统>第三天
- <30天自制操作系统>第五天
- 《30天自制操作系统》前言、目录、样章欢迎阅读!
- 30天自制操作系统笔记第4天
- 《30天自制操作系统》12_day_学习笔记
- 《30天自制操作系统》学习笔记——第十五天
- 30天自制操作系统day13
- 30天自制操作系统day14
- 《30天自制操作系统》 day01
- 30天自制操作系统day18&day19
- 30天自制操作系统(一)从计算机结构到汇编程序入门
- 30天自制操作系统days1代码
- 30天自制操作系统学习笔记