RuliaReader / Rulia

This is a manga reader. It gives you different feeling. Give it a shot.
https://lancercomet.com/rulia
136 stars 0 forks source link

EPUB and Mobi format support #22

Closed LancerComet closed 1 year ago

LancerComet commented 1 year ago

For more information please read: https://github.com/RuliaReader/Rulia/wiki/EPUB-and-Mobi-support

LancerComet commented 1 year ago

It is difficult to support mobi file for current code structure. A rich content reader component is needed.

LancerComet commented 1 year ago

Both EPub and Mobi are HTML-based content formats, which can be tricky to render in Rulia, as Rulia is primarily designed as a manga reader that operates on bitmap images. There are two options:

About EPub

EN

There could be some issues with epub because epub is a zip file with a bunch of web pages, which means epub is not only designed for manga & comics but also for multimedia. So images could be displayed incorrectly, or even not displayed if it is not manga-content-based.

CHS

Epub 本质是一个包含很多网页的 zip 文件,因为内容存放在网页中,所以 epub 可以展示电子书、图片和富文本,因此不仅可以用来存储漫画,还可以存储小说和富文本等内容。您可能会发现您打开的 epub 文件不能正确展示,这是因为如果目标文件不是纯粹的漫画 epub 文件,可能会无法提取到正确的图片。

CHT

Epub 本質上是一個包含許多網頁的 zip 檔案,由於內容儲存在網頁中,所以 epub 可以展示電子書、圖片和富文本,因此不僅可以用來儲存漫畫,還可以儲存小說和富文本等內容。您可能會發現您開啟的 epub 檔案無法正確顯示,這是因為如果目標檔案不是純粹的漫畫 epub 檔案,可能會無法提取到正確的圖片。

JPN

Epub は、多くのウェブページを含む zip ファイルの本質です。内容がウェブページに保存されているため、Epub は電子書籍、画像、リッチテキストを表示することができます。そのため、漫画だけでなく、小説やリッチテキストなどのコンテンツも保存できます。Epub ファイルを開いたときに正しく表示されない場合がありますが、それは対象ファイルが純粹な漫画の Epub ファイルでない場合、正しい画像を抽出できない可能性があるためです。

About mobi

EN

I've noticed issues with certain mobi files. During decoding, checks for data correctness are essential. If incorrect data blocks are found, in theory they should be deprecated. However, doing so results in incomplete mobi content. While preserving the bad data might yield a complete output, I consider this practice to be inappropriate.

For the time being, I've chosen to retain all the "incorrect data blocks", and during validation, everything appears to function correctly. However, please note that at this stage, you should be cautious when using mobi files.

CHS

我发现一些 mobi 文件有问题。在 mobi 解码阶段,需要检查 mobi 的数据是否正确,如果发现了错误的数据,理论上,对应的数据段需要整段丢弃,但是我发现这么做会使得这些 mobi 文件的结果不完整。如果保留错误数据,则结果是正确的,但原则上讲这么做不合理。

目前我选择保留错误的数据,因为看起来这样做并不影响 mobi 文件的正常读取,不过还望您周知,mobi 文件依然可能出现一些问题。

CHT

我發現有些 mobi 檔案存在問題。在解碼 mobi 的階段,需要檢查其數據是否正確。若發現有錯誤的數據,理論上這部分數據應該被整段丟棄,但這樣做會導致該 mobi 檔案內容不完整。若保留這些錯誤數據,結果看起來是正確的,但從原則上講,這麼做是不合理的。

目前我選擇保留這些錯誤的數據,因為看起來不影響 mobi 檔案的正常讀取。但還是希望您知悉,閱讀 mobi 檔案時仍可能出現一些問題。

JPN

私はいくつかの mobi ファイルに問題があることに気付きました。mobi のデコード段階で、データが正しいかどうかを確認する必要があります。誤ったデータが見つかった場合、理論的にはそのデータセグメントを完全に破棄する必要があります。しかし、そのようにすると、mobi ファイルの内容が不完全になることがわかりました。誤ったデータを保持した場合、結果は正しそうですが、原則としてそのようにするのは不適切です。

現時点で、私は誤ったデータを保持する選択をしています。それは mobi ファイルの正常な読み取りに影響しないように見えるからです。しかし、mobi ファイルを読む際にまだいくつかの問題が発生する可能性があることをご理解ください。