给 Claude Code 装一只状态栏桌宠:cc-statistics 新版本更新

最近给 cc-statistics 加了一个新功能------状态栏 Clawd 像素桌宠,能实时感知 Claude Code 的工作状态。写这篇文章分享一下实现思路,以及顺带介绍一下社区里一个很棒的桌面宠物项目。


一、状态栏动画:让 Claude 的工作状态可见

cc-statistics 是一个统计 AI coding 用量的本地工具,支持 Claude Code / Gemini CLI / Codex / Cursor。之前版本的状态栏只显示 Token 用量和费用,这次新增了 Clawd 像素宠物动画,能跟着 Claude Code 的实际状态切换动作。

状态栏左侧的小人就是 Clawd,右边显示当日费用(今天 $180,有点肉疼)。


二、动画状态是怎么来的?

核心机制是 Claude Code Hook 事件驱动。Claude Code 支持在工具调用前后注入 Hook,cc-statistics 通过监听这些事件来判断当前状态:

vbnet 复制代码
PreToolUse  → Claude 正在执行工具调用  → active 动画
PostToolUse → 工具调用完成,等待下一步 → idle 动画
Stop        → 会话结束                 → sleeping 动画

Hook 配置写在 ~/.claude/settings.json 里:

json 复制代码
{
  "hooks": {
    "PreToolUse": [{
      "matcher": "",
      "hooks": [{ "type": "command", "command": "node /path/to/ccstats-hook.js PreToolUse" }]
    }],
    "PostToolUse": [{
      "matcher": "",
      "hooks": [{ "type": "command", "command": "node /path/to/ccstats-hook.js PostToolUse" }]
    }],
    "Stop": [{
      "matcher": "",
      "hooks": [{ "type": "command", "command": "node /path/to/ccstats-hook.js Stop" }]
    }]
  }
}

ccstats-hook.js 是一个轻量脚本,把当前事件写入 ~/.cc-stats/activity-state.json。状态栏 Swift App 每 3 秒轮询这个文件,根据状态切换对应帧动画。整个链路完全本地,零延迟、零网络。

动画状态一共 3 种:

  • active:敲键盘,Claude 正在干活
  • idle:等待输入,左右摇摆
  • sleeping:会话结束,趴下睡觉

三、Clawd on Desk:感谢鹿鹿的开源项目

像素动画素材来自 clawd-on-desk,这是作者鹿鹿开发的一个 Electron 桌面宠物应用,专门为 AI coding agent 设计。

功能很齐全:

  • 12 种动画状态,覆盖 AI coding 全流程
  • 支持多 Agent:Claude Code / Codex / GitHub Copilot
  • 迷你模式:缩成一个小点趴在角落,不打扰
  • 权限审批气泡:Claude 请求高危权限时,桌宠会弹气泡提示
  • 多 Agent 并发感知:同时跑多个 Agent 时,桌宠会切换到"加班"状态

cc-statistics 直接复用了 clawd-on-desk 的动画素材(MIT 协议),通过 Hook 事件驱动状态切换,把桌宠能力嵌入到了 macOS 状态栏。


四、Skill 调用统计

这次版本还新增了 Skill 调用统计 ,专门针对 Claude Code 的 slash command(/commit/review 这类自定义命令)。

实现原理是解析 ~/.claude/projects/ 下的 JSONL 会话文件,找其中 tool_use 类型且 name == "Skill" 的调用记录,统计汇总后展示:

  • 每个 Skill 的调用频次
  • 成功率分布
  • 一天内各时段的使用热力

五、安装

bash 复制代码
# pipx(隔离环境,推荐)
pipx install cc-statistics

# Homebrew(macOS / Linux)
brew install androidZzT/tap/cc-statistics

安装后启动状态栏:

bash 复制代码
cc-stats-app

首次启动会提示配置 Hook,按提示操作即可。


六、总结

这次更新的核心思路是:把 Claude Code 的内部状态外显出来,让人在专注写代码的时候,也能一眼感知 AI 在干什么。

状态栏桌宠是个小功能,但用起来还挺有意思的------看着小人敲键盘,莫名觉得它真的在帮你干活。

项目地址:

欢迎 Star、Issue、PR。

相关推荐
子兮曰2 小时前
llama.cpp Windows 免编译部署实测:Releases 下载、模型检索与参数详解
人工智能·架构·开源
IvorySQL3 小时前
速抢!HOW 2026 早鸟票最后 1 天,解锁开源数据库盛会全亮点
数据库·postgresql·开源
IvorySQL3 小时前
PostgreSQL 技术日报 (3月30日)|内核补丁密集更新,REPACK 并发与索引预读取进展
数据库·postgresql·开源
IvorySQL3 小时前
PostgreSQL 技术日报 (3月29日)|内核工具增强 + 安全能力升级
数据库·postgresql·开源
电源海盗船6 小时前
第一讲 单相逆变器原理与硬件设计
stm32·单片机·嵌入式硬件·开源·dsp开发
小妖同学学AI6 小时前
微软开源多智能体协作框架AutoGen:像组建公司一样,打造会“开会”的AI团队
人工智能·microsoft·开源
IvorySQL7 小时前
PostgreSQL 技术日报 (3月28日)|零停机补丁、约束新特性、性能避坑全收录
数据库·postgresql·开源
darkb1rd7 小时前
awesome-opensource-ai:真开源
开源·github·好物分享
冬奇Lab8 小时前
一天一个开源项目(第58篇):BillionMail - 开源自建邮件服务器与邮件营销平台
开源