go-musicfox是用Go写的又一款网易云音乐命令行客户端,支持UnblockNeteaseMusic、各种音质级别、lastfm、MPRIS、MacOS交互响应(睡眠暂停、蓝牙耳机连接断开响应、菜单栏控制等)...
UI基于 charmbracelet/bubbletea ,做了一些定制
(The icon is based on kitty-icon)
请务必使用等宽字体,或将配置doubleColumn设为false,否则双列显示很乱
Mac原生Terminal及Windows的cmd不做兼容处理
Mac推荐使用Iterm2或Kitty
Linux推荐Kitty
Windows推荐使用Windows Terminal,UI及体验好很多
brew install anhoder/go-musicfox/go-musicfox
如果你之前安装过musicfox,需要使用下列命令重新链接:
brew unlink musicfox && brew link --overwrite go-musicfox
下载Mac可执行文件: https://github.com/go-musicfox/go-musicfox/releases/latest
brew install anhoder/go-musicfox/go-musicfox
如果你之前安装过musicfox,需要使用下列命令重新链接:
brew unlink musicfox && brew link --overwrite go-musicfox
#编译
paru -S go-musicfox
#二进制包
paru -S go-musicfox-bin
eselect repository enable gentoo-zh
emerge --sync
emerge -a media-sound/go-musicfox
NUR路径为nur.repos.aleksana.go-musicfox。关于如何使用NUR,请参阅NUR#how-to-use。
具体安装请看这里。
下载Linux可执行文件: https://github.com/go-musicfox/go-musicfox/releases/latest
下载Windows可执行文件: https://github.com/go-musicfox/go-musicfox/releases/latest
> git clone https://github.com/go-musicfox/go-musicfox
> go mod download
(Linux编译前需要安装flac)
> go build cmd/musicfox.go
$ musicfox
按键 | 作用 | 备注 |
---|---|---|
h/H/LEFT | 左 | |
l/L/RIGHT | 右 | |
k/K/UP | 上 | |
j/J/DOWN | 下 | |
g | 上移到顶部 | |
G | 下移到底部 | |
q/Q | 退出 | |
space | 暂停/播放 | |
[ | 上一曲 | |
] | 下一曲 | |
- | 减小音量 | |
= | 加大音量 | |
n/N/ENTER | 进入选中的菜单 | |
b/B/ESC | 返回上级菜单 | |
w/W | 退出并退出登录 | |
p | 切换播放方式 | |
P | 心动模式(仅在歌单中时有效) | |
r/R | 重新渲染UI | 如果UI界面因为某种原因出现错乱,可以使用这个重新渲染 |
c/C | 当前播放列表 | |
, | 喜欢当前播放歌曲 | |
< | 喜欢当前选中歌曲 | |
. | 当前播放歌曲移除出喜欢 | |
> | 当前选中歌曲移除出喜欢 | |
t | 标记当前播放歌曲为不喜欢 | |
T | 标记当前选中歌曲为不喜欢 | |
d | 下载当前播放歌曲 | |
D | 下载当前选中歌曲 | |
/ | 搜索当前列表 | |
? | 帮助信息 | |
a | 播放中歌曲的所属专辑 | |
A | 选中歌曲的所属专辑 | |
s | 播放中歌曲的所属歌手 | |
S | 选中歌曲的所属歌手 | |
o | 网页打开播放中歌曲 | |
O | 网页打开选中歌曲/专辑... | |
;/: | 收藏选中歌单 | |
'/" | 取消收藏选中歌单 |
配置文件路径为用户目录下的.go-musicfox/go-musicfox.ini,相关配置有:
# 启动页配置
[startup]
# 是否显示启动页
show=true
# 启动页进度条是否有回弹效果
progressOutBounce=true
# 启动页时长
loadingSeconds=2
# 启动页欢迎语
welcome=musicfox
# 启动时自动签到
signin=true
# 进度条配置
[progress]
# 进度条已加载字符
fullChar=#
# 进度条未加载字符
emptyChar=
# 主页面配置
[main]
# 是否显示标题
showTitle=true
# 加载中提示
loadingText=[加载中...]
# 歌曲音质,standard,higher,exhigh,lossless,hires
songLevel=higher
# 主题颜色
# 随机
# primaryColor=random
# 经典网易云音乐红
primaryColor="#ea403f"
# 是否显示歌词
showLyric=true
# 歌词偏移 ms
lyricOffset=0
# 显示歌词翻译
showLyricTrans=true
# 是否显示通知信息
showNotify=true
# 开启pprof, --pprof时会开启
pprofPort=9876
# altScreen显示模式
altScreen=true
# 双列显示,开启务必使用等宽字体
doubleColumn=true
# 下载目录,默认为$HOME/.go-musicfox/download
downloadDir=
# 是否显示歌单下所有歌曲,默认不开启,仅获取歌单前1000首,开启后可能会占用更多内存(大量歌曲数据)和带宽(会同时发送多个请求获取歌单下歌曲数据)
showAllSongsOfPlaylist=false
[player]
# 播放引擎 beep / mpd(需要安装配置mpd) / osx(Mac才可用)
# 不填Mac默认使用osx,其他系统默认使用beep
#engine=beep
# beep使用的mp3解码器,可选:go-mp3, minimp3
beepMp3Decoder=go-mp3
# mpd配置
mpdBin=/usr/local/bin/mpd
# !!!注意!!! 一定要在配置文件中设置pid_file,否则在退出时不会kill掉mpd进程
mpdConfigFile=/Users/anhoder/.mpd/mpd.conf
mpdNetwork=unix
mpdAddr=
[unm]
# UNM开关
switch=true
# UNM源: kuwo,kugou,migu,qq
sources=kuwo
# UNM搜索其他平台限制 0-3
searchLimit=0
# 解除会员限制
enableLocalVip=true
# 解除音质限制
unlockSoundEffects=true
# QQ音乐cookie文件
qqCookieFile=
- anhoder/bubbletea: 基于 bubbletea 进行部分定制
- anhoder/bubbles: 基于 bubbles 进行部分定制
- anhoder/netease-music: fork自 NeteaseCloudMusicApiWithGo ,在原项目的基础上去除API功能,只保留service、util作为一个独立的包,方便在其他go项目中调用
感谢以下项目及其贡献者们(但不限于):
感谢JetBrains Open Source为项目提供免费的 IDE 授权