切换到宽版
  • 广告投放
  • 稿件投递
  • 繁體中文
    • 3680阅读
    • 0回复

    [分享]AutoCAD汉字与数字字母的协调 [复制链接]

    上一主题 下一主题
    离线CDCAD
     
    发帖
    95
    光币
    1974
    光券
    0
    只看楼主 正序阅读 楼主  发表于: 2009-09-15
    使用AutoCAD的用户都有这样的感受:所使用的仿宋体汉字与小字体的数字字母写在一起时大小不协调,数字字母显得比汉字大,汉字中的一些符号位置偏低,影响美观,因而希望通过修改汉字形文件来改变这种状况。但修改汉字形文件,需要ASCII码的源形文件(.shp),通常我们只有编译后的二进制汉字形文件(.shx),没有汉字的源形文件。汉字形文件是大字体形文件,笔者经过探索,弄清了编译后的大字体形文件的结构以及几个在参考资料上不见公布的形定义特殊码含义,据此编制了将二进制大字体形文件转换为源形文件的程序,并且对得到的源形文件进行修改,编译得到了令人满意的二进制仿宋体形文件。下面就是具体的实现步骤。 , 0X J|#%  
    ;uc3_J]  
    一、二进制大字体形文件的结构 o3Yb2Nw  
    _~tF2`,Y_p  
      ----二进制大字体形文件由3部分组成:文件头、索引部分和形定义部分。 kz}Bc F  
    X! 6dg.n5  
      ----1.文件头 =3% GLj  
    qYVeFSS  
      ----文件头包括大字体版本、索引项数、换码范围个数、始码1、终码1、始码2、终码2等等,例: }vx 46  
    POc<XLZB  
      ----“AutoCAD-86bigfont1.0”0D0A1A0800 vq9O|E3  
    Ki:t!vAO  
      ------------------大字体版本 uj\&-9gEi  
    {4SaS v^/  
      ----CD2B----0300----A100----A300----A600----A600 };}N1[D   
    sRBfLN2C  
      ---索引项数---换码数-----始码1----终码1------始码2----终码2 F@ |(  
    wPYeKOh'  
      ----2.索引部分 6)=;cc{Vr  
    h5@7@w%  
      ----每个索引项8个字节,包括编码、形定义字节数及形定义在形文件中的偏移位置,例: _7u&.l<;  
    nfZe"|d  
      ----0000----0E00----935E0100 b^<7a&  
    SJc*Rl>  
      ----编码-------长度---------偏移 !"/"Mqs3$  
    F@ pf._c  
      ----3.形定义部分 RWu< dY#ym  
    {C?$osrr  
      ----编码为0的形定义格式比较特殊,为字体名、0、字高、向下、方式、0,例: j p}.W  
    w(S&X"~  
      ----“HZ1/6/92”----00----7F----00----02----00 ukW L3  
    uF3{FYM{I  
      -------字体名---------------字高----向下----方式 Hsov0  
    I)jAdd  
      ----其他编码的形定义以1个字节00或2个字节3000开头,其后为有效形定义字节。 i&m6;>?`  
    l{?9R.L  
    二、大字体源形文件的格式 t]vv&vk>  
    }9B},  
      ----*BIGFONT字符数目,换码范围个数,始码1,终码1,…… IcqzMm b  
    >e.vUUQ{  
      ----*0,4,字体名 9' H\-  
    vKPLh   
      ----字高,向下,方式,0 FB,rQ9D  
    :.BjJ2[S  
      ----*编码1,定义字节数,形名称 WSU/Z[\`H  
    v^t oe  
      ----字节1,字节2,…,0 ??#EG{{  
    Yc)Dx3  
      ----…… ?qHQ#0 @y]  
    I_?R(V[9  
      ----字节可以采用十六进制表示,高4位表示矢量长度(从1至F,即最长为15),低4位表示矢量方向(见图1),并且必须前导一个0作为十六进制表示的标记。字节也可以采用十进制表示,此时不需前导任何0,但可带负号,它们通常用于表示特殊码、位移量或比例因子。 #jxPh!%9  
    l.;^w  
      ----下面给出特殊码及它们的含义: Je^ ;[^  
    Mw+ l>92  
      ----0形定义结束 %@aC5^Ovy+  
    'tQp&p j  
      ----1落笔 {pre|r\  
    E)p[^1WC  
      ----2抬笔 K'E)?NW69  
    wwR}h I(  
      ----3用下一字节除矢量长度 X$t!g`  
    A'u]z\&%c  
      ----4用下一字节乘矢量长度 XMI5j7C L  
    !)J$f _88D  
      ----5进栈 I+^iOa  
    ]H`pM9rC  
      ----6出栈 +uNMyVH  
    z~2;u 5S&  
      ----7引用下一字节编码的形定义 >wYmx4W>  
    By*YBZ  
      ----8由下两个字节给出X和Y位移量(可用圆括号括起来) KxhWZ3  
    s nNd7v.U6  
      ----9后跟有多个X和Y位移量,并需要(0,0)结束 ?vik2RW  
    PF)s>  
      ----10由下2个字节(半径,方向)定义一个圆,方向取值范围为010~070,高4位表示方向,低4位为0 BP&] t1p  
    Z)3oiLmD  
      ----11用下5个字节(字节1,字节2,字节3,半径,字节5)定义一个圆弧,字节1影响起始角,字节2影响终止角,字节3影响半径,字节5高4位表示方向,低4位决定弧度角 l\m7~  
    X$%W&:  
      ----12由下3个字节(X位移,Y位移,凸度)定义一个圆弧 6RSit  
    j@UE#I|h  
      ----13定义多段圆弧,并需用(0,0)结束 *|6vCR  
    g>b{hkIXg  
      ----14使后面的一个特殊码不起作用 \x\(36\u  
    va#].4_  
    三、编制转换程序的步骤 HB<>x  
    zqXDD; w3  
      ----1.读索引项数、换码范围个数及换码。 x>J(3I5_b  
    *xx)j:Sc2  
      ----2.将长度不为0的索引项全部读入内存,读入内存的项数即为字符数目。 _3g!_  
    $RC)e 7  
      ----3.写源形文件的第一行。 [ 'B u  
    7^#O{QYol  
      ----4.将读入内存的索引项按编码从小到大顺序排序。因排序时间较长,因此排序每完成一步在屏幕上显示计数,以表示排序正在进行。 11A$#\,  
    9A`^ (  
      ----5.处理编码为0的形定义。
     
    分享到