Android 點陣字庫解析(16*16,8*16)

漢字,Ascii碼,根據(jù)字庫解析成點陣

首先來了解兩個概念,
什么是點陣,若干個虛實的點組成的一個矩陣;
什么是字庫,點陣字庫是把每一個漢字都分成16×16或24×24個點,然后用每個點的虛實來表示漢字的輪廓;

先看效果:


image1.png

image2.png

看到這里,相信大家都不陌生,什么用品店面頭頂掛個LED顯示屏,顯示文字跑馬燈; 那個就是將文字解析成點陣的一個實例;

好了,知道要實現(xiàn)的效果,接下來就看代碼實現(xiàn):

 /**
  * Created by jary on 2016/11/21. * 解析16*16的點陣字庫 
  */
public  class Font16 { 
    private final static String ENCODE = "GB2312";
    private final static String ZK16 = "HZK16";//assets下的路徑
    private final static String ASC16 = "ASC16";//assets下的路徑        
    private byte[][] arr;//返回的二位數(shù)組
    private int all_16_32 = 16;//16*16
    private int all_2_4 = 2;//一個漢字等于兩個字節(jié)
    private int all_32_128 = 32;//漢字解析成16*16 所占字節(jié)數(shù)
    private int font_width = 8;//ascii碼 8*16
    private int font_height = 16;//ascii碼 8*16
    private int all_16 = 16;//ascii碼解析成8*16 所占字節(jié)數(shù)
    
    /**
 * 解析成點陣
 * @param str
 * @return
 */
public byte[][] resolveString(String str) {
    byte[] data = null;
    int[] code = null;
    int byteCount;
    int lCount;

    if (str.charAt(0) < 0x80) {
        // 字母
        arr = new byte[font_height][font_width];
        data = read_a(str.charAt(0));
        byteCount = 0;
        for (int line = 0; line < 16; line++) {
            lCount = 0;
            for (int k = 0; k < 1; k++) {
                for (int j = 0; j < 8; j++) {
                    if (((data[byteCount] >> (7 - j)) & 0x1) == 1) {
                        arr[line][lCount] = 1;
                        System.out.print("●");
                    } else {
                        System.out.print("○");
                        arr[line][lCount] = 0;
                    }
                    lCount++;
                }
                byteCount++;
            }
            System.out.println();
        }

    } else {
        arr = new byte[all_16_32][all_16_32];
        code = getByteCode(str.substring(0, 0 + 1));
        data = read(code[0], code[1]);
        byteCount = 0;
        for (int line = 0; line < all_16_32; line++) {
            lCount = 0;
            for (int k = 0; k < all_2_4; k++) {
                for (int j = 0; j < 8; j++) {
                    if (((data[byteCount] >> (7 - j)) & 0x1) == 1) {
                        arr[line][lCount] = 1;
                        System.out.print("●");
                    } else {
                        System.out.print("○");
                        arr[line][lCount] = 0;
                    }
                    lCount++;
                }
                byteCount++;
            }
            System.out.println();
        }
    }
    return arr;
}

 /**
 * 讀取字庫中的ASCII 碼  
 */
protected byte[] read_a(char char_num) {
    byte[] data = null;
    int ascii = (int) char_num;
    try {
        data = new byte[all_16];//定義緩存區(qū)的大小
        InputStream inputStream = mContext.getResources().getAssets()
                .open(ASC16);//打開ascii字庫的流
        int offset = ascii * 16;//ascii碼在字庫里的偏移量
        inputStream.skip(offset);
        inputStream.read(data, 0, all_16);//讀取字庫中ascii碼點陣數(shù)據(jù)
        inputStream.close();
        return data;
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    return data;
  }
/**
 * 讀取字庫中的漢字
 * @param areaCode
 * @param posCode
 * @return
 */
protected byte[] read(int areaCode, int posCode) {
    byte[] data = null;
    try {
        int area = areaCode - 0xa0;//區(qū)碼
        int pos = posCode - 0xa0;//位碼

        InputStream in = mContext.getResources().getAssets().open(ZK16);//打開中文字庫的流
        long offset = all_32_128 * ((area - 1) * 94 + pos - 1);//漢字在字庫里的偏移量
        in.skip(offset);//跳過偏移量
        data = new byte[all_32_128];//定義緩存區(qū)的大小
        in.read(data, 0, all_32_128);//讀取該漢字的點陣數(shù)據(jù)
        in.close();
    } catch (Exception ex) {
    }
    return data;
}
/**
 * 獲取漢字的區(qū),位(ascii碼不需要區(qū)碼,位碼)
 * @param str
 * @return
 */
protected int[] getByteCode(String str) {
    int[] byteCode = new int[2];
    try {
        byte[] data = str.getBytes(ENCODE);
        byteCode[0] = data[0] < 0 ? 256 + data[0] : data[0];
        byteCode[1] = data[1] < 0 ? 256 + data[1] : data[1];
    } catch (Exception ex) {
        ex.printStackTrace();
    }
    return byteCode;
}
}

解析出來字體風格由字庫決定,代碼中用到的兩個字庫文件:
ASC16(8x16 ASCII點陣 一個字符16Byte)
HZK16 (16x16 宋體漢字點陣 一個漢字32Byte)
網(wǎng)上直接搜索就可以下載;

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • 概述 看過演唱會的同學應該都看到過粉絲舉著LED點陣屏幕的牌子來支持自己心目中的男神或者女神,感覺這種點陣屏幕的效...
    小蕓論閱讀 3,463評論 2 7
  • 1.在計算機內(nèi)部用來傳送、存儲、加工處理的數(shù)據(jù)或指令都是以二進制碼形式進行的。 2.數(shù)制也稱計數(shù)制,是指用同一組固...
    霧熏閱讀 2,398評論 0 37
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,893評論 25 709
  • 累 最近這段時期只能用這個字來詮釋 工作壓力巨大,奈何豬一樣的隊友同事讓我無奈。 生活壓力巨大,無他,囊中羞澀,與...
    HowieGao閱讀 123評論 0 1
  • 1. 關于xml格式定義 xml格式定義分為兩部分: 申明 內(nèi)容大概格式定義如下: <?xml 表示這是一個xml...
    _palm閱讀 479評論 0 1

友情鏈接更多精彩內(nèi)容