

























空是底,朱是点 —— 应用是空房间,AI 是页边那一笔朱批。
你有没有过这样的经历:读到一本厚厚的英文小说,想用 AI 帮忙"回顾一下前面讲了什么",结果它一句"主角最终和某某走到了一起"——直接剧透了结局。又或者你想让 AI 翻译某一段,它却把整章情节都给你概括了。
市面上的 AI 阅读工具,大多默认"读取整本书再总结"。对一个还没读完的读者来说,这种"全知视角"本身就是剧透。
Empty (空) 就是想解决这件事。它是一个开源、原生 SwiftUI 的 EPUB & PDF 阅读器,内置一个"朱"——一个只在你已经读过的文本范围内工作的 AI 伴读。
把 Empty 的设计目标拆开看,其实只有三句话:
这三点决定了 Empty 的很多细节:它用 utf16Offset 记录"你读到第几个字符",从而精确知道哪些内容已经被你读过;它默认走 Apple Foundation Models 的本地推理,云端是 BYOK (自带密钥)的可选模式;它在 Mac 上是一个完整的"深读工作台",在 iPhone / iPad 上是一个轻量口袋伴侣。
这是 Empty 和其他 AI 阅读工具最大的区别,值得单独说清楚。
很多产品会说"我们做了防剧透"——但仔细看实现,其实是在 prompt 里加了一句"请不要透露后面的情节"。这种做法很脆:换个模型、换个问法,就破了。
Empty 的做法是在数据层做硬过滤。它知道:
utf16Offset 精确到字符)。然后所有 AI 功能——章节回顾、解释、翻译、词汇推荐、思维链接、阅读 Agent 的工具调用——都只能看到"你已经读过的那部分内容"。没读到的内容,AI 根本看不到,prompt 写崩了也漏不出来。
这种"从源头堵住"的设计,让防剧透这件事从"模型自觉"变成了"系统保证"。
Empty 的 AI 名字叫"朱"(取自中文古典阅读里"朱批"的意象——书页空白处那一笔红色的批注)。它会做的事情不少:
这些功能背后,AI 提供商可以二选一:
| 模式 | 说明 |
|---|---|
| 本地(默认) | Apple Foundation Models ,免费、私密、离线可用 |
| 云端( BYOK ) | OpenAI 兼容( DeepSeek 预设)或 Anthropic 兼容( Kimi Code 预设);密钥存 Keychain |
在 AI 诊断面板里可以切换提供商、跑连通性测试。
很多 EPUB 阅读器会用一个 WebView 直接渲染 HTML ,省事但是牺牲了精度。Empty 走了一条更累的路:
PDF 则走 PDFKit ,支持分页和高亮标注。
好处是:所有交互都是原生的——选择、滚动、高亮、动画——没有 WebView 的"夹层"感。代价是工程量更大,但读起来是真的丝滑。
读得多的人会知道,光读没用,得消化。Empty 在 Mac 上提供了一整套学习工具:
.empty-notes 包可以导出 / 导入你的所有阅读笔记(高亮、笔记、词汇、卡片、记忆、书目元数据)。书内容本身不会被导出——这是 Empty 的隐私底线:备份只碰笔记,不碰书。
Empty 支持 macOS 、iOS 、iPadOS 、visionOS。Mac 是完整的四栏工作台(图书馆 / 阅读 / 笔记 / 词汇),iOS / iPad 是口袋伴侣(图书馆 / 阅读 / 卡片 + 朱 AI )。
整个项目 MIT 协议开源,237 个单元测试在 CI 上全绿。架构上遵循"本地深读优先、备份只碰笔记"的原则。
git clone https://github.com/DaviRain-Su/empty.git
cd Empty
open Empty.xcodeproj
选个目标平台,Cmd + R 运行,导入 .epub 或 .pdf 即可开始。最新 macOS .dmg 可以在 Releases 页面下载(当前未签名,首次打开在"系统设置 → 隐私与安全性"中允许即可)。
空是底,朱是点。
应用本身是空房间——一个安静的阅读空间,没有信息流的喧嚣、没有社交分享的催促。AI 是页边那一笔朱批——在你需要的时候,在你读过的文字旁边,给你一句话、一个链接、一个提醒。
不剧透、不越界、不喧宾夺主。这是 Empty 对所有 AI 阅读工具想提的一个反问:AI 应该做主角,还是做页边那一点朱?
good first issue如果这个项目对你有帮助,请给一颗 ⭐️,让更多人发现它。
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。