我以前一直觉得,在手机上读漫画这件事有点别扭。
不是不能读。恰恰相反,手机可能是我们最常拿起来的阅读设备。
地铁上、睡前、等咖啡的时候,手边通常不是 iPad,也不是电脑,而是手机。
但漫画页一旦被塞进这块小屏幕里,问题就来了。
整页看,字小。放大看,又要来回拖。分格密一点的页尤其难受,眼睛刚跟上剧情,手指就要开始找下一格。横跨两页的大场面更麻烦,缩小后看不清,放大后只剩局部。看着看着,注意力从故事里被拽出来,变成了缩放、拖动、定位。
这不是漫画的问题,也不是手机的问题。只是它们原本就不是为彼此设计的。

还有另一个问题更隐蔽:老漫画不一定是不好看,只是很多图源真的老了。
早年的扫图、压缩过的合集、从硬盘里翻出来的 ZIP 和 RAR,在今天的手机屏幕上会露出很多瑕疵。线条发糊,网点发脏,小字边缘像被水泡过。内容还是那个内容,但读起来总差一口气。
MMReader 最开始想解决的,就是这两个很具体的尴尬。
先让画面清楚一点
AI 增强画质 是我放在前面的功能。
这里的「增强」不是给漫画加一层锐化滤镜,也不是把所有东西都处理成塑料感很重的壁纸。我的目标更朴素:让那些本来还能看的老图,在手机屏幕上少一点吃力。
比如一页老漫画,原图分辨率不高,压缩痕迹也明显。普通阅读器能做的事情通常到缩放为止,再往后就交给用户的眼睛。
MMReader 会尝试把这类页面重新处理一遍,让线条更稳,文字边缘更清楚。
它不保证每一页都脱胎换骨,也不应该这样承诺。漫画的质感很微妙,处理过头反而会坏掉。
我更希望它像一副合适的眼镜。你不会一直想着眼镜本身,但戴上以后,读起来没那么费劲。
再把阅读路径交给镜头
AI 分镜 解决的是另一个问题:小屏幕如何读一整页漫画。
传统做法是把整页展示出来,然后让用户自己缩放。这个逻辑很合理,也足够通用。
但漫画不是普通图片。它有分格,有阅读顺序,有留白,有跨页,有时候还有很故意的视线引导。
所以我给 MMReader 做了 AI 分镜。
它会尝试识别页面里的分格,把整页漫画拆成一个个适合手机屏幕的阅读镜头。你可以像翻页一样在分镜之间前进,而不是每看一格都手动调整位置。
这个体验有点像有人在旁边替你扶着镜头。它不改漫画内容,也不替你决定节奏,只是尽量把下一格放到舒服的位置。
我自己第一次把这个功能跑顺的时候,感觉挺微妙。以前看一页复杂分格的漫画,我会下意识先缩小看布局,再放大看第一格,然后拖到第二格。动作不难,但很烦。AI 分镜之后,手指只需要往前点。注意力终于可以回到画面里。再配合APP中的自动播放功能,可以做到完全释放双手。
它仍然得是一个正经漫画书架
如果只有 AI,MMReader 还不够成为一个长期使用的阅读器。
漫画收藏这件事,麻烦的地方往往不在「打开一个文件」。真正麻烦的是:这一卷属于哪套书?合集和单卷怎么放?读到哪里了?哪些内容不想放在首页?换设备之后还能不能继续整理?
很多阅读器按文件夹管理,这没有错,但我一直觉得漫画更像纸质书架。读者心里想的通常不是某个路径下的某个文件,而是「这一套」「第几卷」「外传」「合集」。
所以 MMReader 的管理逻辑更接近纸质漫画:可以按漫画集和卷来组织,阅读进度跟着作品走,而不是只跟着文件名走。

我还做了私密书架。
原因很简单:漫画收藏有时就是很私人。
不是所有东西都适合摆在首页,也不是每次把手机递给别人时都想解释自己的书架。

至于 NAS、网盘、Wi-Fi 传输、本地导入、多格式支持,这些 MMReader 也有。它们很重要,但我不想把它们写成文章的主角。现在的漫画阅读器已经卷到这个程度了,大家都知道这些能力应该存在。对 MMReader 来说,它们更像地基。地基要稳,但没人会因为地基本身搬进一间屋子。
我想做的是少一点打扰
如果一定要给 MMReader 找一个方向,我希望它是:让手机读漫画时少一点别扭,多一点沉进去的时间。
我做它不是因为手机是最完美的漫画设备。恰恰相反,它有很多天然限制:屏幕小,比例窄,手指一挡就遮住画面。但手机又是最常陪在我们身边的设备。很多人真正能留给漫画的时间,可能就是通勤的一站路、睡前的十分钟、排队时忽然空出来的一小段缝隙。
我希望能够不断让自己能够体会到钻进漫画世界时的心流状态。
也希望那些从旧硬盘、旧压缩包、旧回忆里翻出来的漫画,不要因为画质和屏幕尺寸,在今天变得难以靠近。小屏幕不是敌人,老图源也不是垃圾。很多时候,它们只是需要被重新擦亮,再放到合适的镜头里。
MMReader 还不完美。有些无边框页面,AI 分镜会判断得不够聪明;有些图源太差,AI 增强画质也救不回来。做阅读器很容易陷入一种冲动,想把每个角落都塞满按钮。我现在反而越来越相信,漫画阅读器最好的状态是安静。
它应该把书架整理好,把页面摆正,把字变清楚,把下一格递到眼前。它应该让技术往后退一点,让漫画、角色、台词和那些突然被击中的瞬间往前走。
然后就别打扰我看漫画了。

