macOS 配套应用

菜单栏图标

菜单栏图标状态

作者:steipete · 更新:2025-12-06 · 范围:macOS 应用(apps/macos

  • 空闲: 正常图标动画(眨眼、偶尔摆动)。
  • 已暂停: Status 项使用 appearsDisabled;无动作。
  • 语音触发(大耳朵): 听到唤醒词时,语音唤醒检测器会调用 AppState.triggerVoiceEars(ttl: nil),在采集话语期间保持 earBoostActive=true。耳朵会放大(1.9x),并出现圆形耳孔以提高可读性,然后在静默 1 秒后通过 stopVoiceEars() 复位。仅由应用内语音流水线触发。
  • 工作中(智能体运行中): AppState.isWorking=true 会驱动一个“尾巴/腿部疾跑”微动效:工作进行中时腿部摆动更快,并带有轻微偏移。目前会在 WebChat 智能体运行期间切换;在接入其他长任务时,也请在其周围添加相同切换。

接入点

  • 语音唤醒:运行时/测试器在触发时调用 AppState.triggerVoiceEars(ttl: nil),并在静默 1 秒后调用 stopVoiceEars(),以匹配采集窗口。
  • 智能体活动:在工作区间周围设置 AppStateStore.shared.setWorking(true/false)(WebChat 智能体调用中已完成)。保持区间简短,并在 defer 块中重置,避免动画卡住。

形状和尺寸

  • 基础图标绘制于 CritterIconRenderer.makeIcon(blink:legWiggle:earWiggle:earScale:earHoles:)
  • 耳朵缩放默认值为 1.0;语音增强会设置 earScale=1.9 并切换 earHoles=true,且不改变整体画框(18×18 pt 模板图像渲染到 36×36 px Retina 后备存储)。
  • 疾跑效果使用最高约 ~1.0 的腿部摆动,并带有小幅水平抖动;它会叠加到任何现有的空闲摆动之上。

行为说明

  • 耳朵/工作中没有外部 CLI/broker 开关;保持为应用自身信号的内部行为,以避免意外反复切换。
  • 保持 TTL 较短(<10s),这样如果任务挂起,图标也能快速回到基线状态。

相关内容