• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 14,  comments - 57,  trackbacks - 0
              PSP上的閱讀軟件我所知道的有bookr和XReader(沒用過)等,我比較喜歡bookr,不過bookr在閱讀很多pdf時(shí),中文會(huì)顯示成亂碼,閱讀txt時(shí),根本就無法顯示中文,
            這確實(shí)很讓人不爽。
            過年前閑著沒事,順便解決了bookr中文問題,本文記錄了那段時(shí)間的工作:如何從官方版bookr修改,解決pdf中文亂碼問題,支持txt中文、中文目錄顯示的問題,拋磚引玉和大家分享下整個(gè)的思路
            和問題的解決方式,解決過程比較丑陋,希望高手多多指點(diǎn)。
            貌似這里不能貼超過2M的附件,這里就不貼出修改后的bookr的發(fā)布文件了,在PSP2000測試通過,最近也一直在用,需要的同學(xué)可以email問我要。
            注:已經(jīng)上傳到csdn:http://download.csdn.net/source/2578241
            內(nèi)置了少量字體,大家可以自行擴(kuò)展字體。


            準(zhǔn)備工作

              1、搭建PSP開發(fā)環(huán)境。sourceforge上集成的安裝包,下載下來直接安裝即可,這里不多說了。
              2、下載bookr源碼,我下載的是0.7.1版本。可以用SVN下載最新的,也可以在sourceForge下載打包的源碼包。

            解決PDF中文問題

              bookr的代碼結(jié)果很清晰,由于是用c++開發(fā)的,所以代碼很好理解,BKLayer 是基礎(chǔ)的顯示類,BKDocument是基礎(chǔ)的文檔處理類。
            bookr支持pdf、txt、html和 PalmDoc(我沒用過這種),分別由從BKDocument的派生類來處理。
            pdf是由BKPDF來處理的。解決pdf中文問題的關(guān)鍵就在BKPDF類了。

               1、如何調(diào)試

                   PSP開發(fā)首先遇到的問題是調(diào)試,PSP并不能實(shí)時(shí)調(diào)試,這確實(shí)是個(gè)問題。好在Bookr源碼級(jí)支持了跨平臺(tái),在windows下,使用Makefile.cygwin 就可以編譯一個(gè)windows版本
            的Bookr了。一般來說,在windows下bookr運(yùn)行正常,大致在PSP上的版本也是正常的,當(dāng)然,在細(xì)節(jié)上其實(shí)是有差別的。另外,還可以通過日志來實(shí)現(xiàn)跟蹤。

               2、解決字體問題

                  實(shí)際上,有些中文pdf用bookr打開時(shí)是正常的,比如Programming_In_Lua.pdf,但是在打開經(jīng)常溫習(xí)的金庸全集的時(shí)候,就出現(xiàn)亂碼了。
            注意到Bookr的pdf顯示其實(shí)是主要是mudpf來實(shí)現(xiàn)的。那么bookr中文顯示問題到底是bookr自身的還是mupdf的呢?
            為了確認(rèn)這個(gè)問題,先從sourceforge下載mupdf,建立一個(gè)vs2005的項(xiàng)目,編譯,OK,可以運(yùn)行了,打開金庸全集一看,還是亂碼,這下基本可以確認(rèn),這個(gè)
            問題是從mupdf就存在了。要定位中文顯示亂碼的問題,自然需要了解pdf的內(nèi)部格式,從adobe的官網(wǎng)下載了最新的pdf手冊,打開一看,一共700多頁。。。
            好在我們不需要從頭開始閱讀,只要挑關(guān)鍵的地方看就可以了,中文問題一般是因?yàn)樽煮w引起的。

            所以我們可以直接挑Text的字體相關(guān)部分看。
            mupdf的字體加載在pdf_loadfont里,從pdf手冊可知,pdf支持了若干種字體,反正我是沒什么耐心看下去,直接打開金庸全集單步調(diào)試了下,
            發(fā)現(xiàn)問題在TrueType字體的加載里,TrueType字體的加載是loadsimplefont來處理的,通過跟蹤可知,在獲取字體的FontDescriptor的時(shí)候失敗了,然后就是用內(nèi)置的默認(rèn)字體來處理了。
            默認(rèn)字體都不支持中文,所以自然就顯示成亂碼了。
            最簡單的辦法就是只要是TrueType字體,不管具體是什么字體,都強(qiáng)制從硬盤加載一種指定字體(例如黑體),當(dāng)然,這樣會(huì)導(dǎo)致我們看到的pdf和實(shí)際應(yīng)該顯示的樣子有差別,只有一種字體了。
            讓我們先這樣試試吧:在發(fā)現(xiàn)pdf_loadfontdescriptor 加載失敗后,強(qiáng)制用loadCustomFont 加載硬盤指定字體"font/simhei.ttf",這樣字體加載的問題貌似解決了。
            編譯,運(yùn)行,發(fā)現(xiàn)還是有問題,這次的問題在文字編碼了。

               3、編碼問題

                一般顯示不正常的中文pdf都是GBK編碼的,mupdf的顯示是通過如下兩個(gè)步驟來做的:
               首先解碼,將文字內(nèi)容全部轉(zhuǎn)化成cid,然后將要顯示的cid全部push到一個(gè)隊(duì)列,然后遍歷cid,將cid轉(zhuǎn)化成gid(對(duì)trueType就是轉(zhuǎn)成unicode),接著顯示。
            mupdf本身有一個(gè)比較優(yōu)雅的辦法來解碼,通過pdf_lookupcmap來得到unicode,我用了比較笨的辦法:自己暴力做GBK到unicode的轉(zhuǎn)換。
            一般在windows和linux下都有庫或者API來完成編碼轉(zhuǎn)換問題。不過在PSP下卻沒有這樣的API,只好自己做一個(gè)編碼轉(zhuǎn)換了,
            在http://unicode.org/Public/MAPPINGS/VENDORS/MICSFT/WINDOWS/CP936.TXT 找到了轉(zhuǎn)換表,復(fù)制粘貼到txt文本,用lua腳本處理下,生成一個(gè).c文件,分別將GBK和unicode值存儲(chǔ)到2個(gè)數(shù)組里,
            現(xiàn)在你一定知道怎么轉(zhuǎn)換了:二分查找到指定GBK值在GBK數(shù)組的下標(biāo),然后直接在unicode數(shù)組用這個(gè)下標(biāo),可以得到對(duì)應(yīng)的unicode值。
            編譯測試,OK了,終于能正常顯示中文了。
            不過到現(xiàn)在為止,整個(gè)頁面只有一種字體,要解決這個(gè)問題,我們可以根據(jù)名字匹配來找到指定的字體,名字匹配不到的,使用默認(rèn)的字體(我是用的simsun.ttf)。

             txt中文問題

               相對(duì)來說txt的中文問題比較好解決了,基本都是些常規(guī)開發(fā),從FzFont.cpp代碼可知,txt顯示不了中文主要是字體加載的時(shí)候,只加載了前面的256個(gè)字形。那么我們只要做2件事情就可以顯示中文了:
              1、文字解碼,現(xiàn)在大部分的txt電子書都是gbk編碼的,這樣比較省空間,解碼算法前面已經(jīng)提過了。
              2、中文文字紋理管理和效率問題。一般在PC游戲中,中文字體一般都是將多個(gè)連續(xù)的漢字按照存儲(chǔ)到一張64X64的紋理中,這樣可以節(jié)省顯存,降低渲染批次(3D菜鳥的簡單推測)。
            不過如果在psp也這樣做,會(huì)發(fā)現(xiàn)顯示頁面是在太慢,最后發(fā)現(xiàn),最簡單的辦法居然是每個(gè)漢字一個(gè)紋理,當(dāng)然要實(shí)際用到的時(shí)候才生成該漢字紋理。
              3、顯示頁分割。bookr閱讀txt的時(shí)候,會(huì)自己將電子書分割成若干頁面,并且支持書簽功能,因此,不可避免的涉及到頁面分割問題,引入中文顯示后,這里稍微有點(diǎn)不同,要注意不能拆分一個(gè)漢字,
            當(dāng)然,還有其他細(xì)節(jié)需要處理,這里不多說了。

            目錄中文問題

              必須承認(rèn),這是我遇到的最痛苦的問題了,原因是從API上就有問題了,讀取出來的目錄名居然是Shift-jis編碼的,誰讓PSP是索尼產(chǎn)的呢,我嘗試過將PSP的語言設(shè)置、時(shí)間等本地化設(shè)置改成中文、中國等。
            發(fā)現(xiàn)讀取到的目錄名還是shift-jis編碼。我先將目錄名從shift-jis轉(zhuǎn)回gb2312,然后顯示,結(jié)果發(fā)現(xiàn)很多漢字丟失,因?yàn)閺膅b2312轉(zhuǎn)到shift-jis的時(shí)候已經(jīng)失真了,轉(zhuǎn)回來顯示很多字體就顯示不了了。
            看上去這個(gè)問題無法解決了,其實(shí)不然,PSP的API提供了打開記憶卡設(shè)備的功能,這樣,我們自己做一個(gè)FAT32驅(qū)動(dòng)(叫驅(qū)動(dòng)不合適,其實(shí)就是自己讀取FAT32文件系統(tǒng)管理文件)就可以了,F(xiàn)AT32的文檔
            到處都是,linux下也有vfat文件系統(tǒng)的實(shí)現(xiàn),不過我偷懶了,我直接從PMP Player的代碼里拷貝了FAT32相關(guān)文件,直接移植過來,修改了FzScreenPsp.cpp文件里目錄相關(guān)的目錄讀取函數(shù),
            然后修改目錄相關(guān)顯示代碼后,編碼顯示,一切終于解決了。。。

             


            posted on 2010-07-26 21:41 feixuwu 閱讀(7010) 評(píng)論(5)  編輯 收藏 引用 所屬分類: PSP開發(fā)

            FeedBack:
            # re: PSP版本Bookr修改支持中文
            2010-08-01 23:20 | ls
            博主將開發(fā)應(yīng)用到實(shí)際生活中去,探索精神很值得學(xué)習(xí)。支持。  回復(fù)  更多評(píng)論
              
            # re: PSP版本Bookr修改支持中文
            2011-06-18 10:32 | sg
            現(xiàn)在用的就是樓主的修改版,Thanks 、  回復(fù)  更多評(píng)論
              
            # re: PSP版本Bookr修改支持中文[未登錄]
            2011-09-20 21:10 | jason
            我沒有在CSDN上找到下載鏈接能傳到我的信箱里嗎。。不勝感謝
            jason_zsj@yahoo.cn  回復(fù)  更多評(píng)論
              
            # re: PSP版本Bookr修改支持中文
            2012-10-11 10:40 | ALAN QI
            特別想用BOOKR 看中文,我在國外,樓主可否將您的修改版本發(fā)到我的郵箱,qmgs@hotmai.com .您上傳的附件連接我無法下載。 我可能是你的第一個(gè)PS VITA 中文BOOKR 測試者  回復(fù)  更多評(píng)論
              
            # re: PSP版本Bookr修改支持中文
            2012-10-11 10:44 | ALAN QI
            @ALAN QI

            qmgs@hotmail.com  回復(fù)  更多評(píng)論
              
            <2012年10月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            文章轉(zhuǎn)載請(qǐng)注明出處

            常用鏈接

            留言簿(11)

            隨筆分類

            隨筆檔案

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            日韩精品久久久肉伦网站| 久久国产乱子伦精品免费午夜| 手机看片久久高清国产日韩| 久久精品一区二区三区中文字幕| 激情久久久久久久久久| 日韩人妻无码一区二区三区久久99| 久久人人爽人人人人爽AV| 国内精品久久久久伊人av| 91精品国产综合久久四虎久久无码一级 | 无遮挡粉嫩小泬久久久久久久| 久久精品亚洲精品国产色婷| 久久国产高清一区二区三区| 超级97碰碰碰碰久久久久最新| 久久电影网2021| 久久人人爽人人爽人人片av麻烦| 国产成人久久精品区一区二区| 日本久久中文字幕| 国产福利电影一区二区三区久久老子无码午夜伦不 | 狠狠色婷婷久久一区二区三区| 精品无码久久久久久国产| 国产日产久久高清欧美一区| 久久久久久国产精品无码下载| 国产精品久久久久一区二区三区| 性欧美丰满熟妇XXXX性久久久 | 国产综合精品久久亚洲| 久久久久亚洲AV无码麻豆| 久久这里只精品99re66| 国产精品伊人久久伊人电影 | 无码精品久久一区二区三区 | 大伊人青草狠狠久久| 久久久久人妻一区二区三区| 午夜视频久久久久一区| 国产精品免费看久久久香蕉| 亚洲国产天堂久久综合网站| 久久国产热精品波多野结衣AV| 亚洲精品高清国产一线久久| 2021久久精品免费观看| 久久精品国产亚洲av麻豆图片| 女人高潮久久久叫人喷水| 中文字幕精品无码久久久久久3D日动漫| 国产成人久久精品麻豆一区 |