

在一个普通到有点无聊的周末早晨,我打开 ChatGPT,敲下了一段现在看来很粗糙的话:
讨论一个产品构想:
目前网易云音乐的 mac 客户端极其难用,因为太重了,非常卡,我想做一个接网易云 API、重做前端 UI(非常轻)的一个个人电台,仅本地使用。
目前就是这点构想,你怎么看?给我点分析与建议。
这就是 Floe 的开端。
那时她还不叫 Floe,没有图标,没有窗口,没有播放按钮,也没有任何能运行的代码。严格说,这甚至不是一个像样的产品需求,最多是一句带着方向感的抱怨:我不想再忍受一个越来越重、越来越卡的音乐客户端了。
我不是程序员,代码也不是我的日常工作语言。过去如果一个软件不好用,我的选择其实很有限:忍着用,找替代品,或者等别人做一个更合适的版本。
网易云音乐的 Mac 客户端就是这种让我长期不太舒服的工具。对我来说它太重了。启动慢,界面复杂,很多功能我并不需要,还会卡顿。
我想它一定具备合理的产品逻辑,但作为用户我并不想为此买单。
我对网易云的使用非常单一,一般情况下我只听私人 FM,它最好像一个放在桌面角落里的小收音机,打开就能播,不要抢注意力,也不要把一个简单动作变成一次平台浏览。
它不是创业想法,不是产品规划,只是一个很具体的「不爽」。
「我不是在写代码,是在给 AI 踩刹车」
回头看,如果这件事真有什么做对的地方,大概是我没把她想得太大。
我并不需要一个完整的网易云替代品。那样的目标听起来很酷,但对我来说没有意义。我真正需要的是一个很轻的东西:能登录,能拉到私人 FM,能播放,能喜欢,能丢进垃圾桶,能下一首。窗口要小,反应要快,最好能够像一个便签一样存在在我屏幕的一角,安静到不需要我多想。
范围一旦缩到这个程度,事情就变了——不再是"做一个音乐客户端",而是"做一个够自己用的私人 FM 小工具"。
前者让人头皮发麻,后者至少可以试一试。
真正开始做以后,绝大部分工作都是 AI 辅助完成的。ChatGPT 负责整体规划和解释,Claude Code 写了大量代码,也帮我拆任务、改问题、做调试;Claude.ai 帮我看 UI 设计,会从挑剔的角度提出问题。
但在整个过程中,我也并不是坐在那里等 AI 自动生成一个 App。更多时候,我是在不同工具之间来回切换,把一个自己看不懂的东西,先变成一个相对能理解的问题。开发过程中,Claude Code 会不断给我一些内容:PRD、任务拆解、技术路线选择、报错分析。有时它还会问我 A 和 B 两种方案选哪一个。涉及到技术的部分,绝大多数情况我都看不懂。
我用了一个特别土的办法:把这些内容复制到 ChatGPT 里,让它解释给我听。A 方案到底是什么意思,B 方案会带来什么差异,哪个更接近我想要的"轻量、自用、别太复杂"。解释完以后,有些问题我可以判断,有些问题还是判断不了。判断不了的,如果不影响大方向,我就先让它继续;如果听起来会影响稳定性、后续维护或者界面体验,我就再追问,或者回到 Claude Code 那边要求它停一下、改一下、不要继续扩大范围。
我没有直接写代码,也没有真正审代码。我在两个 AI 之间来回搬运信息,把看不懂的技术语言翻译后,再决定自己要不要介入。

这中间最常出现的判断是叫停。AI 会主动建议你扩功能、补状态、加设置、做优化——每个建议看起来都不荒唐,但全部接受的话,一个很轻的小工具很快就会重新长成一个重客户端。
整个过程里我最常有的感觉,是自己在做翻译工作,不是开发工作。
我确实不懂很多技术细节,比如登录态为什么会丢,或者 App 打包前后某些功能的表现为什么不一样。这些问题放在过去,大概率会直接把我挡在门外。现在我至少可以把现象描述出来,让 AI 先解释一轮,再根据解释继续问。
有时问完以后,我还是没有完全懂。但这已经足够让我多一点判断空间。以前是"看不懂,所以停住"。现在是"看不懂,先问清楚一点;问完以后,如果它关系到目标、风险或体验,再决定要不要介入"。
整个过程并不丝滑。最开始我以为难点会是"做一个播放器",后来发现真正烦人的地方往往藏在细节里——比如一首歌结束后下一首怎么保持连续,或者点了垃圾桶之后是不是应该立刻切歌。这些问题都不宏大,但每一个都会影响这个东西能不能真的被我用起来。
还有打包。开发环境里能跑,不代表她就是一个 App。真正打包成 macOS 应用以后,会冒出一堆小问题——名字怎么显示、图标怎么放、登录信息怎么保存,都得一个一个处理。
「一个小工具,也要有自己的脾气」
名字也是后来才定下来的。
开始开发时,我的文件夹名称叫 Project FM。这个名字很直白,像一个临时文件夹,不像一个我愿意长期放在电脑里的 App。App 打包完成后,她变成了 Floe。这个名字轻一些,也更接近我想要的感觉:不是一个庞大的音乐平台,而是一块漂浮的小东西,安静、轻、不会压迫人。
UI 这部分,我前后也让不同 AI 给过意见。有时 Claude.ai 会指出一些设计问题,我会把它的意见拿给 ChatGPT 做交叉分析,也会把改完的截图再拿回来反复看。最后决定权还是在我自己这里。

一个具体的例子是"喜欢"按钮。
一开始用的是实心的 ♥,点亮前是灰黑色,点亮后变成荧光绿亮色。但灰黑色的实心 ♥ 在点亮前本身就有重量,会让人产生"这个按钮已经被按过了"的错觉。我把它换成了空心的 ♡。
换完之后立刻又陷入纠结。Floe 的 UI 是暗色背景,空心 ♡ 的轮廓是很淡的灰色——它和旁边实心的暂停按钮 ⏸︎、下一首按钮 ⏭ 放在一起,气质有点偏弱,看起来缺乏存在感。
我反复看两个方案的效果,最后还是选了更淡的 ♡。这跟我想要的 Floe 气质一致——她本来就该像一块漂浮的小东西,不抢注意力。而且点亮前足够淡,点亮后那一下亮色实心的反差才出得来。
类似的取舍还有不少。"不喜欢"那个按钮一开始用的是垃圾桶的 emoji 图标 🗑。它非常直观、含义精确,但问题是图标本身面积大、跟旁边三个原生 unicode 按钮(⏸︎ ⏭ ♡)放在一起气质完全不搭,而且垃圾桶的意象过重,会破坏 Floe 的 UI 设计的冷淡气质。
反复权衡后,最终把 🗑 图标换成了 ⏏(推出)。同样是原生 unicode,大小、灰度、笔画粗细都跟其他三个按钮一致,放在一排里完全不会突兀。代价是它的标准语义其实是"推出磁盘"——拿来当"不喜欢/跳过"用,如果较真来讲是有些错位的。好在 Floe 是我自己用,我自己理解就行。
这种小事在 Floe 开发后期占据了相当多时间。
「从能用,到愿意每天点开」
名字定下来以后,图标也变得重要。Floe 的图标是我用 ChatGPT 的 Image2 生成的。整体效果非常棒,黑灰色背景 + 荧光绿电波图案,构筑了淡淡的电台感,我很喜欢。但有一个问题——生成出来的图本身是一个带有暗色背景的正方形图片,圆角图标内嵌其中。与 Mac 程序坞那一排原生圆角图标相比,Floe 显得格格不入——别人是圆角,她是"方框里的圆角"。
这种破坏感比我预想的影响大得多,程序坞那一排图标的整齐感被她一己之力拉掉了。那段时间我打开 Floe 的频率明显下降:一打开我的眼睛会不由自主盯着 Dock 里那个不和谐的方形图标,连听歌的心情都没有了。
我反复让 Claude Code 改了很多轮,核心目标只有一个:把圆角图标外的暗色背景裁掉,同时保留圆角边框那一圈亮光。听起来简单,但每次改完总有一处不对——要么亮光丢了,要么裁过头露出了底色,要么裁的边缘不平。
改到最后那一版的时候,我仔细看了几秒,有一种如释重负的感觉。从那时起,Floe 才算真的住进了我的程序坞。

某种意义上,最打动我的是她真的存在了。
现在 Floe 在我的程序坞里,从左数第三个。每天我大概会点开五六次。她启动很快,没有动画,没有引导,没有"今日推荐"。听到喜欢的,一个爱心按钮是发自内心的欣赏;听到不喜欢的,点垃圾桶按钮,直接换下一首。
这就够了。
夜雨聆风