xiaomusic/README.md

83 lines
2.1 KiB
Markdown
Raw Normal View History

2023-10-14 11:50:32 +00:00
# xiaomusic
使用小爱同学播放音乐,音乐使用 yt-dlp 下载。
## 运行
2023-10-14 14:27:50 +00:00
- 使用 install_dependencies.sh 下载依赖
- 使用 pdm 安装环境
- 参考 [xiaogpt](https://github.com/yihong0618/xiaogpt) 设置好环境变量
2023-10-14 11:50:32 +00:00
```shell
export MI_USER="xxxxx"
export MI_PASS="xxxx"
export MI_DID=00000
```
然后启动即可。默认监听了端口 8090 , 使用其他端口自行修改。
```shell
pdm run xiaomusic.py
````
### 支持口令
- **播放歌曲**
- **播放歌曲**+歌名 比如:播放歌曲周杰伦晴天
- 下一首
- 单曲循环
- 全部循环
## 已测试设备
```txt
"L07A": ("5-1", "5-5"), # Redmi小爱音箱Play(l7a)
````
2024-01-27 15:09:30 +00:00
## 支持音乐格式
- mp3
- flac
> 本地音乐会搜索 mp3 和 flac 格式的文件,下载的歌曲是 mp3 格式的。
2023-10-14 11:50:32 +00:00
2023-10-15 02:58:53 +00:00
## 在 Docker 里使用
```shell
2023-10-16 10:07:07 +00:00
docker run -e MI_USER=<your-xiaomi-account> -e MI_PASS=<your-xiaomi-password> -e MI_DID=<your-xiaomi-speaker-mid> -e MI_HARDWARE='L07A' -e XIAOMUSIC_PROXY=<proxy-for-yt-dlp> -e XIAOMUSIC_HOSTNAME=192.168.2.5 -p 8090:8090 -v ./music:/app/music hanxi/xiaomusic
2023-10-15 02:58:53 +00:00
```
2023-10-16 10:13:09 +00:00
- XIAOMUSIC_PROXY 用于配置代理默认为空yt-dlp 工具下载歌曲会用到。
2023-10-16 10:07:07 +00:00
- MI_HARDWARE 是小米音箱的型号,默认为'L07A'
2023-10-15 02:58:53 +00:00
- 注意端口必须映射为与容器内一致XIAOMUSIC_HOSTNAME 需要设置为宿主机的 IP 地址,否则小爱无法正常播放。
- 可以把 /app/music 目录映射到本地,用于保存下载的歌曲。
2024-01-31 01:03:38 +00:00
XIAOMUSIC_PROXY参数格式参考 yt-dlp 文档说明:
```
Use the specified HTTP/HTTPS/SOCKS proxy. To
enable SOCKS proxy, specify a proper scheme,
e.g. socks5://user:pass@127.0.0.1:1080/.
Pass in an empty string (--proxy "") for
direct connection
```
2023-10-15 02:58:53 +00:00
### 本地编译Docker Image
```shell
docker build -t xiaomusic .
```
2024-01-28 10:29:14 +00:00
## 简易的控制面板
浏览器进入 <http://192.168.2.5:8090>
- ip 是 XIAOMUSIC_HOSTNAME 设置的
- 8090 是默认端口
2023-10-14 11:50:32 +00:00
## 感谢
- [xiaomi](https://www.mi.com/)
- [PDM](https://pdm.fming.dev/latest/)
- [xiaogpt](https://github.com/yihong0618/xiaogpt)
2023-10-14 15:42:33 +00:00
- [yt-dlp](https://github.com/yt-dlp/yt-dlp)
2023-10-14 11:50:32 +00:00