PHP讀取漢字的點(diǎn)陣數(shù)據(jù)
項(xiàng)目中遇到的問(wèn)題:
PHP如何讀取漢字的點(diǎn)陣數(shù)據(jù)?想實(shí)現(xiàn)輸入一段文字,能得到這一段文字的所有點(diǎn)陣碼。
解決方法:
簡(jiǎn)體中文國(guó)標(biāo)字庫(kù)7445個(gè)字符,其中漢字6773個(gè),包括一級(jí)漢字3755個(gè),二級(jí)漢字3008個(gè)。采用2字節(jié)(16位二進(jìn)制)編碼。
區(qū)位碼:國(guó)標(biāo)GB2312規(guī)定,所有的國(guó)標(biāo)漢字與符號(hào)組成一個(gè)94×94的矩陣。在此方陣中,每一行稱為一個(gè)”區(qū)”,每一列稱為一個(gè)”位”,因此,這個(gè)方陣實(shí)際上組成了一個(gè)有94個(gè)區(qū)(區(qū)號(hào)分別為0 1到94)、每個(gè)區(qū)內(nèi)有94個(gè)位(位號(hào)分別為01到94)的漢字字符集。一個(gè)漢字所在的區(qū)號(hào)和位號(hào)簡(jiǎn)單地組合在一起就構(gòu)成了該漢字的”區(qū)位碼”。在漢字的區(qū)位碼中,高兩位為區(qū)號(hào),低兩位為位號(hào)。由此可見(jiàn),區(qū)位碼與漢字或符號(hào)之間是一一對(duì)應(yīng)的。
內(nèi)碼:漢字的內(nèi)碼是指在計(jì)算機(jī)中表示漢字的編碼。機(jī)內(nèi)碼與區(qū)位碼稍有區(qū)別。目前,對(duì)于國(guó)內(nèi)大多數(shù)的計(jì)算機(jī)系統(tǒng),一個(gè)漢字的內(nèi)碼占兩個(gè)字節(jié),分別稱為高位字節(jié)與低位字節(jié),且這兩位字節(jié)與區(qū)位碼的關(guān)系如下: 內(nèi)碼高位=區(qū)碼+A0H(H表示十六進(jìn)制) 內(nèi)碼低位=位碼+A0H 例如,漢字”啊”的區(qū)位碼為”1601″,區(qū)碼和位碼分別用十六進(jìn)制表示即為”1001H”,則它的內(nèi)碼為”B0A1H”。其中B0H為內(nèi)碼的高位字節(jié),A1H為內(nèi)碼的低位字節(jié)。
返回由0和1組成的字符串
<?php
/**
* 讀取漢字點(diǎn)陣數(shù)據(jù)
*
*/
$str = "中華人民共和國(guó)";
$font_file_name = "simsun12.fon"; // 點(diǎn)陣字庫(kù)文件名
$font_width = 12; // 單字寬度
$font_height = 12; // 單字高度
$start_offset = 0; // 偏移
$fp = fopen($font_file_name, "rb");
$offset_size = $font_width * $font_height / 8;
$string_size = $font_width * $font_height;
$dot_string = "";
for ($i = 0; $i < strlen($str); $i ++)
{
if (ord($str{$i}) > 160)
{
// 先求區(qū)位碼,然后再計(jì)算其在區(qū)位碼二維表中的位置,進(jìn)而得出此字符在文件中的偏移
$offset = ((ord($str{$i}) - 0xa1) * 94 + ord($str{$i + 1}) - 0xa1) * $offset_size;
$i ++;
}
else
{
$offset = (ord($str{$i}) + 156 - 1) * $offset_size;
}
// 讀取其點(diǎn)陣數(shù)據(jù)
fseek($fp, $start_offset + $offset, SEEK_SET);
$bindot = fread($fp, $offset_size);
for ($j = 0; $j < $offset_size; $j ++)
{
// 將二進(jìn)制點(diǎn)陣數(shù)據(jù)轉(zhuǎn)化為字符串
$dot_string .= sprintf("%08b", ord($bindot{$j}));
}
}
fclose($fp);
echo $dot_string;
?>
以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。
- php使用自定義函數(shù)實(shí)現(xiàn)漢字分割替換功能示例
- php自定義函數(shù)截取漢字長(zhǎng)度
- PHP截取漢字亂碼問(wèn)題解決方法mb_substr函數(shù)的應(yīng)用
- php判斷輸入是否是純數(shù)字,英文,漢字的方法
- 支持生僻字且自動(dòng)識(shí)別utf-8編碼的php漢字轉(zhuǎn)拼音類
- php中將漢字轉(zhuǎn)換成拼音的函數(shù)代碼
- PHP版 漢字轉(zhuǎn)碼的實(shí)現(xiàn)詳解
- PHP5中GD庫(kù)生成圖形驗(yàn)證碼(有漢字)
- php輸出全部gb2312編碼內(nèi)的漢字方法
- 在PHP的圖形函數(shù)中顯示漢字
- PHP切割漢字的常用方法實(shí)例總結(jié)
相關(guān)文章
在Laravel的Model層做數(shù)據(jù)緩存的實(shí)現(xiàn)
這篇文章主要介紹了在Laravel的Model層做數(shù)據(jù)緩存的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
Laravel框架執(zhí)行原生SQL語(yǔ)句及使用paginate分頁(yè)的方法
這篇文章主要介紹了Laravel框架執(zhí)行原生SQL語(yǔ)句及使用paginate分頁(yè)的方法,以類函數(shù)的形式給出了Laravel框架執(zhí)行原生SQL語(yǔ)句以及paginate分頁(yè)的相關(guān)操作技巧,需要的朋友可以參考下2018-08-08
Laravel框架實(shí)現(xiàn)利用中間件進(jìn)行操作日志記錄功能
這篇文章主要介紹了Laravel框架實(shí)現(xiàn)利用中間件進(jìn)行操作日志記錄功能,結(jié)合實(shí)例形式分析了Laravel框架中間件的創(chuàng)建、引入以及使用中間件進(jìn)行操作日志記錄功能的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-06-06
PHP實(shí)現(xiàn)繪制3D扇形統(tǒng)計(jì)圖及圖片縮放實(shí)例
這篇文章主要介紹了PHP實(shí)現(xiàn)繪制3D扇形統(tǒng)計(jì)圖及圖片縮放實(shí)例,本文給出代碼示例,代碼中包含一些說(shuō)明注釋,需要的朋友可以參考下2014-10-10
PHP框架Laravel中使用UUID實(shí)現(xiàn)數(shù)據(jù)分表操作示例
這篇文章主要介紹了PHP框架Laravel中使用UUID實(shí)現(xiàn)數(shù)據(jù)分表操作,結(jié)合實(shí)例形式較為詳細(xì)的分析了Laravel框架基于UUID進(jìn)行數(shù)據(jù)分表的相關(guān)操作步驟、實(shí)現(xiàn)技巧與操作注意事項(xiàng),需要的朋友可以參考下2018-05-05

