跨端写作新范式:note-gen如何实现手机与桌面无缝衔接
你是否经历过这样的写作困境:电脑上刚写一半的文档,想在通勤路上用手机继续却发现格式错乱?会议中用手机速记的灵感,回到办公室打开电脑却找不到文件?多设备切换时的文档不同步、排版错乱、进度丢失,正在吞噬你的创作效率。
note-gen通过三大核心技术彻底解决这些痛点:响应式布局引擎自动适配各种屏幕尺寸,WebDAV/MCP双协议同步确保数据实时流动,移动端专属交互设计让触摸操作媲美桌面体验。读完本文,你将掌握跨端写作的实现原理,学会5个移动端效率技巧,并了解如何避免90%的多设备协作问题。
响应式引擎:小屏幕里的大空间
note-gen的移动端适配从底层布局开始就采用"移动优先"设计理念。在src/app/mobile/layout.tsx中,开发团队使用Flexbox弹性布局构建了自适应容器:
<div className="flex flex-col h-full">
<main className="flex flex-1 w-full overflow-hidden">
{children}
</main>
<AppFootbar />
</div>
这种结构确保内容区域能根据屏幕尺寸自动伸缩,配合src/app/mobile/mobile-styles.scss中的安全区域适配代码:
@supports (-webkit-touch-callout: none) {
html, body {
padding-top: env(safe-area-inset-top);
padding-bottom: env(safe-area-inset-bottom);
}
}
完美解决了刘海屏、全面屏等特殊屏幕的显示问题,确保内容不会被遮挡。
针对移动端触摸操作的特殊性,开发团队在样式层面做了多重优化:
/* 防止输入框聚焦时的页面缩放 */
input, textarea, select, [contenteditable] {
font-size: 16px !important;
touch-action: manipulation;
}
这行代码看似简单,却解决了iOS上常见的输入框聚焦导致页面缩放问题,保证了写作过程的流畅性。
移动端与桌面端功能对比:
| 功能 | 桌面端 | 移动端 | 实现差异 |
|---|---|---|---|
| 编辑器 | 双栏预览 | 单栏切换 | 移动端采用底部工具栏切换编辑/预览模式 |
| 文件管理 | 侧边栏树形结构 | 抽屉式文件列表 | src/app/mobile/writing/custom-header.tsx实现弹出式文件选择器 |
| 快捷键 | 丰富键盘快捷键 | 手势操作 | 双指缩放调整字体大小,左滑撤销操作 |
| AI辅助 | 独立侧边栏 | 浮动工具栏 | 点击src/app/core/article/floatbar中的AI按钮触发 |
数据流动:WebDAV与MCP双引擎同步
跨设备写作的核心是数据同步。note-gen采用"基础同步+高级协作"的双层架构,在src/stores/webdav.ts中实现了稳定可靠的文件级同步:
async backupToWebDAV(): Promise<string> {
const { url, username, password, path } = get()
return await invoke<string>('webdav_backup', {
url, username, password, path
})
}
async syncFromWebDAV(): Promise<string> {
return await invoke<string>('webdav_sync', {
url, username, password, path
})
}
这段代码展示了WebDAV协议如何处理文件备份与同步,支持坚果云、Nextcloud等主流云存储服务。开发团队特别加入了连接状态管理:
export enum WebDAVConnectionState {
checking = 'checking',
success = 'success',
fail = 'failed',
}
通过src/stores/sync.ts中的状态枚举,用户可以实时了解同步状态,避免数据丢失风险。
对于高级用户,note-gen提供了MCP(Multi-device Collaboration Protocol)多设备协作协议。在src/lib/mcp/client.ts中实现了跨设备实时协作功能:
async callTool(name: string, args: any = {}): Promise<CallToolResult> {
if (!this.isInitialized) {
await this.initialize()
}
return this.sendRequest('tools/call', {
name,
arguments: args,
})
}
MCP协议不仅能同步文件内容,还能共享编辑状态、评论和AI生成进度,实现真正意义上的"无缝衔接"。
数据同步流程图:
sequenceDiagram
participant 手机端
participant WebDAV服务器
participant MCP服务器
participant 桌面端
手机端->>WebDAV服务器: 保存文档变更
WebDAV服务器->>桌面端: 推送更新通知
桌面端->>MCP服务器: 请求编辑权限
MCP服务器->>手机端: 锁定文档通知
手机端->>MCP服务器: 释放编辑锁定
MCP服务器->>桌面端: 授予编辑权限
实战指南:移动端写作效率倍增
note-gen在保留桌面端核心功能的同时,为移动端设计了专属交互流程。在src/app/mobile/writing/page.tsx中,开发团队将编辑器与文件管理完美融合:
<div className='w-full flex flex-col flex-1'>
<WritingHeader />
<div className='flex-1 overflow-hidden'>
<MdEditor />
</div>
</div>
配合src/app/mobile/writing/custom-header.tsx中的抽屉式文件管理器:
<Drawer>
<DrawerTrigger asChild>
<Button variant="ghost" size="icon">
<Menu className="h-5 w-5" />
</Button>
</DrawerTrigger>
<DrawerContent className="h-[85%]">
<FileManager />
</DrawerContent>
</Drawer>
这种设计让用户只需两次点击就能完成文件切换,比传统文件浏览器节省60%操作步骤。
以下是5个经过实测的移动端效率技巧:
-
底部工具栏速访:常用功能全部集中在拇指可及区域,在src/app/mobile/mobile-styles.scss中特别优化了触摸热区大小:
.toolbar-button { min-height: 44px; min-width: 44px; }符合iOS人机交互指南推荐的触摸目标尺寸,大幅减少误触。
-
双指手势操作:双指捏合缩小可快速返回文件列表,双指张开恢复编辑,这些手势在src/components/ui/editor.tsx中实现。
-
离线优先设计:所有编辑操作先保存到本地,联网后自动同步。在src/lib/workspace.ts中实现了智能缓存策略:
export async function getFilePathOptions(relativePath: string) { const workspace = await getWorkspacePath() if (workspace.isCustom) { return { path: await join(workspace.path, relativePath) } } else { return { path: `article/${relativePath}`, baseDir: BaseDirectory.AppData } } } -
语音输入增强:移动端支持语音转文字后自动格式化,在src/lib/audio.ts中集成了标点自动添加和段落分割功能。
-
夜间模式优化:根据环境光自动切换主题,在src/components/mode-toggle.tsx中实现了系统级亮度适配,避免夜间使用时的屏幕眩光。
未来展望与现在行动
note-gen的跨端写作方案已经实现了"一次创作,多端可用"的核心目标,但开发团队并未止步。在src/app/mobile/setting/page.tsx中,我们可以看到即将推出的实验性功能:
<div className="p-2 my-4">
<Updater />
</div>
<SettingTab />
通过设置页面的更新模块,用户可以抢先体验最新功能,包括即将发布的"跨设备剪贴板"和"语音批注同步"。
现在就开始你的跨端写作之旅:
- 从官方仓库克隆项目,按照README配置开发环境
- 在手机端安装APK并启用WebDAV同步(配置指南)
- 在桌面端设置相同的同步服务,测试首次数据同步
- 尝试用手机创建文档,在电脑上继续编辑,验证实时同步效果
- 探索移动端专属功能,如语音输入和手势操作
跨设备写作不再是技术难题,而是提升创作效率的利器。note-gen通过精心设计的响应式布局、可靠的同步协议和贴心的交互细节,让你的创意灵感在各种设备间自由流动。立即体验,开启无缝写作新范式!
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00