200 lines
6.8 KiB
Markdown
200 lines
6.8 KiB
Markdown
# 大屏媒体轮播系统 (DPM)
|
||
|
||
**Digital Playback Media** — 基于 Tauri + React 的全屏媒体轮播控制系统,专为昆明市大学生创业园展播大屏设计。
|
||
|
||
## 概述
|
||
|
||
DPM 是一套完整的数字标牌(Digital Signage)解决方案,包含两大界面:
|
||
|
||
- **大屏展示页** (`/screen`) — 全屏自动轮播,支持视频与图片,具备沉浸式空间视觉背景
|
||
- **管理后台** (`/admin`) — 登录保护的管理面板,用于媒体上传、播放列表编排、播放控制与系统设置
|
||
|
||
系统通过 **SSE(Server-Sent Events)** 实现管理端与展示端的实时状态同步,支持局域网内远程管理。
|
||
|
||
## 技术栈
|
||
|
||
| 层级 | 技术 |
|
||
|------|------|
|
||
| 前端框架 | React 19 + React Router 7 |
|
||
| 构建工具 | Vite 7 |
|
||
| 桌面框架 | Tauri 2 (Rust) |
|
||
| HTTP 服务 | Axum 0.8 (嵌入式 HTTP 服务器) |
|
||
| 数据持久化 | JSON 文件存储 |
|
||
| 实时通信 | Server-Sent Events (SSE) |
|
||
| 内网穿透 | nps 客户端嵌入式集成 |
|
||
|
||
## 功能特性
|
||
|
||
### 媒体管理
|
||
- **本地上传** — 支持 .mp4、.mkv、.avi、.jpg、.jpeg、.png 格式
|
||
- **远程 URL** — 添加网络媒体资源链接
|
||
- **媒体预览** — 图片与视频的模态框预览
|
||
- **文件删除** — 从媒体库移除文件
|
||
|
||
### 播放控制
|
||
- **播放/暂停** — 实时控制展示端的播放状态
|
||
- **上一曲/下一曲** — 切换播放内容
|
||
- **顺序/随机播放** — 两种播放模式
|
||
- **图片时长可调** — 1~300 秒
|
||
- **音量控制** — 实时同步调节
|
||
|
||
### 展示端体验
|
||
- **沉浸式空间背景** — 深邃星空背景 + 透视网格 + 动态环境光晕
|
||
- **自动播放** — 启动后自动加载播放列表
|
||
- **视频/图片自适应** — 全屏覆盖显示
|
||
- **声音管理** — 浏览器自动播放策略处理
|
||
- **点击暂停/恢复** — 现场快速控制
|
||
|
||
### 系统功能
|
||
- **全屏/窗口模式切换** — 自由切换展示形态
|
||
- **最小化窗口** — 后台运行
|
||
- **开机自启动** — 系统级自启(Tauri autostart 插件)
|
||
- **关闭 → 最小化** — 防止误关闭
|
||
- **内网穿透** — 内置 nps 客户端,支持外网远程访问
|
||
|
||
### 管理后台
|
||
- **登录保护** — 账号密码验证
|
||
- **实时状态显示** — 当前播放内容、状态
|
||
- **上传进度条** — 文件上传实时反馈
|
||
- **响应式设计** — 桌面/移动端自适应
|
||
- **Toast 通知** — 操作即时反馈
|
||
|
||
## 快速开始
|
||
|
||
### 环境要求
|
||
|
||
- **Rust** (edition 2021)
|
||
- **Node.js** >= 18
|
||
- **Yarn** 或 npm
|
||
- **Tauri CLI** (`cargo install tauri-cli`)
|
||
|
||
### 安装
|
||
|
||
```bash
|
||
# 安装前端依赖
|
||
yarn install
|
||
|
||
# 开发模式运行(同时启动 Vite 开发服务器和 Tauri 应用)
|
||
yarn tauri dev
|
||
|
||
# 仅启动 Web 开发服务器(浏览器中预览)
|
||
yarn dev
|
||
```
|
||
|
||
### 构建生产版本
|
||
|
||
```bash
|
||
yarn tauri build
|
||
```
|
||
|
||
构建产物位于 `src-tauri/target/release/` 目录。
|
||
|
||
## 项目结构
|
||
|
||
```
|
||
dpm/
|
||
├── index.html # HTML 入口
|
||
├── package.json # 前端依赖配置
|
||
├── vite.config.js # Vite 构建配置(API 代理到 :10801)
|
||
├── public/
|
||
│ └── npc.zip # 内网穿透客户端(嵌入二进制)
|
||
├── src/ # 前端源代码
|
||
│ ├── main.jsx # React 入口
|
||
│ ├── App.jsx # 路由配置(/admin, /screen)
|
||
│ ├── pages/
|
||
│ │ ├── Admin.jsx # 管理后台页面
|
||
│ │ └── Screen.jsx # 大屏展示页面
|
||
│ ├── utils/
|
||
│ │ └── api.js # API 封装(REST + SSE)
|
||
│ └── styles/
|
||
│ ├── tokens.css # CSS 基础重置
|
||
│ ├── admin.css # 管理后台样式
|
||
│ └── screen.css # 大屏展示样式
|
||
└── src-tauri/ # Rust 后端源代码
|
||
├── Cargo.toml # Rust 依赖配置
|
||
├── tauri.conf.json # Tauri 应用配置
|
||
├── capabilities/
|
||
│ └── default.json # Tauri 权限配置
|
||
└── src/
|
||
├── main.rs # 程序入口
|
||
├── lib.rs # 模块导出 + 启动逻辑
|
||
├── server.rs # Axum HTTP 服务器(路由 + 处理器)
|
||
├── models.rs # 数据模型(Settings, PlaybackState, etc.)
|
||
├── storage.rs # JSON 文件持久化存储
|
||
└── events.rs # SSE 事件广播管理器
|
||
```
|
||
|
||
## API 参考
|
||
|
||
系统内置 HTTP 服务器监听 `0.0.0.0:10801`,提供以下 REST API:
|
||
|
||
| 方法 | 路径 | 说明 |
|
||
|------|------|------|
|
||
| POST | `/api/login` | 管理员登录 |
|
||
| GET | `/api/settings` | 获取系统设置 |
|
||
| POST | `/api/settings` | 更新系统设置 |
|
||
| GET | `/api/playlist` | 获取播放列表(含音量/模式/时长) |
|
||
| POST | `/api/playlist/add` | 添加到播放列表 |
|
||
| POST | `/api/playlist/remove` | 从播放列表移除 |
|
||
| GET | `/media` | 获取所有媒体文件列表 |
|
||
| POST | `/upload` | 上传媒体文件(multipart) |
|
||
| POST | `/api/media/add-url` | 添加 URL 媒体 |
|
||
| POST | `/api/delete` | 删除媒体文件 |
|
||
| POST | `/api/control` | 播放控制(play/pause/next/prev) |
|
||
| GET | `/api/state` | 获取当前播放状态 |
|
||
| POST | `/api/state` | 更新播放状态 |
|
||
| GET | `/api/events` | SSE 实时事件流 |
|
||
| POST | `/api/display-command` | 显示命令(minimize 等) |
|
||
| GET | `/file/*` | 静态媒体文件服务 |
|
||
|
||
### 默认登录凭据
|
||
|
||
- **账号**: `admin`
|
||
- **密码**: `**********`
|
||
|
||
> 可通过编辑系统数据目录下的 `dpm/data.json` 修改。
|
||
|
||
### 数据存储位置
|
||
|
||
系统数据存储在操作系统标准数据目录下的 `dpm/` 文件夹中:
|
||
|
||
- **macOS**: `~/Library/Application Support/dpm/data.json`
|
||
- **Linux**: `~/.local/share/dpm/data.json`
|
||
- **Windows**: `C:\Users\<用户>\AppData\Roaming\dpm/data.json`
|
||
|
||
媒体文件存储在用户 `~/Downloads/Media/` 目录。
|
||
|
||
## 内网穿透
|
||
|
||
系统内置 [nps](https://github.com/ehang-io/nps) 客户端,自动从嵌入的 `public/npc.zip` 解压并启动,实现外网远程访问管理后台。
|
||
|
||
- 启动参数在 `server.rs` 中配置
|
||
- *仅支持 Windows*
|
||
- 自动设置 Unix 可执行权限
|
||
- 解压到系统数据目录 `dpm/npc/`
|
||
|
||
## 开发说明
|
||
|
||
### 端口
|
||
|
||
| 端口 | 用途 |
|
||
|------|------|
|
||
| 10801 | 后端 HTTP API 服务器 |
|
||
| 1420 | Vite 前端开发服务器 |
|
||
|
||
### Vite 开发代理
|
||
|
||
开发模式下,Vite 自动将 `/api`、`/file`、`/media`、`/upload` 路径代理到 `localhost:10801`,前端无需关心跨域问题。
|
||
|
||
### 构建
|
||
|
||
前端构建产物(`dist/`)通过 `RustEmbed` 编译到 Rust 二进制中,发布时只需分发单个可执行文件。
|
||
|
||
## 许可
|
||
|
||
本项目为昆明市大学生创业园公益定制开发。
|
||
|
||
---
|
||
|
||
*云南派音人工智能科技提供技术支持*
|