• <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時,中文會顯示成亂碼,閱讀txt時,根本就無法顯示中文,
            這確實很讓人不爽。
            過年前閑著沒事,順便解決了bookr中文問題,本文記錄了那段時間的工作:如何從官方版bookr修改,解決pdf中文亂碼問題,支持txt中文、中文目錄顯示的問題,拋磚引玉和大家分享下整個的思路
            和問題的解決方式,解決過程比較丑陋,希望高手多多指點。
            貌似這里不能貼超過2M的附件,這里就不貼出修改后的bookr的發布文件了,在PSP2000測試通過,最近也一直在用,需要的同學可以email問我要。
            注:已經上傳到csdn:http://download.csdn.net/source/2578241
            內置了少量字體,大家可以自行擴展字體。


            準備工作

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

            解決PDF中文問題

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

               1、如何調試

                   PSP開發首先遇到的問題是調試,PSP并不能實時調試,這確實是個問題。好在Bookr源碼級支持了跨平臺,在windows下,使用Makefile.cygwin 就可以編譯一個windows版本
            的Bookr了。一般來說,在windows下bookr運行正常,大致在PSP上的版本也是正常的,當然,在細節上其實是有差別的。另外,還可以通過日志來實現跟蹤。

               2、解決字體問題

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

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

               3、編碼問題

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

             txt中文問題

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

            目錄中文問題

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

             


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

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

            qmgs@hotmail.com  回復  更多評論
              
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            文章轉載請注明出處

            常用鏈接

            留言簿(11)

            隨筆分類

            隨筆檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            国产精品久久久久AV福利动漫| 亚洲精品WWW久久久久久| 亚洲国产精品无码久久久不卡| 中文字幕无码免费久久| 久久夜色精品国产噜噜噜亚洲AV| avtt天堂网久久精品| 久久婷婷五月综合色99啪ak| 亚洲中文字幕无码一久久区| 久久国产一区二区| 狠狠色婷婷久久综合频道日韩| 久久香蕉国产线看观看精品yw| 一级做a爰片久久毛片16| 超级97碰碰碰碰久久久久最新| 国产一区二区三区久久| 色狠狠久久综合网| 国产成人综合久久久久久| 国内精品久久久久影院薰衣草| 久久这里只有精品首页| 无遮挡粉嫩小泬久久久久久久| 久久久久久久综合综合狠狠| 精品久久久久久亚洲精品| 国产毛片欧美毛片久久久| 久久综合久久伊人| 久久99精品久久久久久9蜜桃| 2021精品国产综合久久| 久久天天躁狠狠躁夜夜不卡| 亚洲а∨天堂久久精品9966| 99久久久久| 99久久国产综合精品五月天喷水| 久久99国产乱子伦精品免费| 亚洲午夜久久久影院| 国产精品久久新婚兰兰| 久久久久亚洲?V成人无码| 国产视频久久| 久久久这里有精品中文字幕| 国产成人综合久久精品尤物| 久久亚洲高清观看| 久久精品国产福利国产琪琪| 久久影院亚洲一区| 超级97碰碰碰碰久久久久最新| 青青久久精品国产免费看|