# [SpineViewer](https://github.com/ww-rm/SpineViewer) [![Build and Release](https://github.com/ww-rm/SpineViewer/actions/workflows/dotnet-desktop.yml/badge.svg)](https://github.com/ww-rm/SpineViewer/actions/workflows/dotnet-desktop.yml) [![GitHub Release](https://img.shields.io/github/v/release/ww-rm/SpineViewer?logo=github&logoColor=959da5&label=Release&labelColor=3f4850)](https://github.com/ww-rm/SpineViewer/releases) [![Downloads](https://img.shields.io/github/downloads/ww-rm/SpineViewer/total?logo=github&logoColor=959da5&label=Downloads&labelColor=3f4850)](https://github.com/ww-rm/SpineViewer/releases) ![Languages](https://img.shields.io/badge/Languages-中文%20%7C%20English%20%7C%20日本語-blue) [中文](README.md) | [English](README.en.md) Spine 文件查看&导出程序, 同时也是支持 Spine 的动态壁纸程序. ![previewer](https://github.com/user-attachments/assets/697ae86f-ddf0-445d-951c-cf04f5206e40) https://github.com/user-attachments/assets/37b6b730-088a-4352-827a-c338127a16f0 ## 功能 - 支持多版本 spine 文件 (`2.1.x; 3.4.x - 4.2.x`) - 支持列表式多骨骼查看和渲染层级管理 - 支持多轨道动画 - 支持皮肤/插槽/附件设置 - 支持调试渲染 - 支持画面/模型/轨道时间倍速设置 - 支持设置轨道 Alpha 混合参数 - 支持单帧/动图/视频文件导出 - 支持 FFmpeg 自定义导出 - 支持非 PNG 格式的纹理图片格式 - 支持开机自启常驻动态壁纸 - ...... ## 安装 前往 [Release](https://github.com/ww-rm/SpineViewer/releases) 界面下载压缩包. 软件需要安装依赖框架 [.NET 桌面运行时 8.0.x](https://dotnet.microsoft.com/zh-cn/download/dotnet/8.0). 也可以下载带有 `SelfContained` 后缀的压缩包, 可以独立运行. 导出 GIF/MP4 等动图/视频格式需要在本地安装 ffmpeg 命令行, 并且添加至环境变量, [点击前往 FFmpeg-Windows 下载页面](https://ffmpeg.org/download.html#build-windows), 也可以点这个下载最新版本 [ffmpeg-release-full.7z](https://www.gyan.dev/ffmpeg/builds/ffmpeg-release-full.7z). ## 修改显示语言 本项目目前支持以下界面显示语言: - `ZH` (中文) - `EN` (English) - `JA` (日本語) 可以通过窗口菜单的 "文件" -> "首选项..." -> "语言", 选择你需要的语言并确认修改. ## 使用方法 ### 基本介绍 程序大致是左右布局, 左侧是功能面板, 右侧是画面. 左侧有三个子面板, 分别是: - **模型**. 该面板记录导入并进行渲染的模型列表, 可以在这个面板设置与模型渲染相关的参数和渲染顺序, 以及一些与模型有关的功能. - **浏览**. 该面板用于预览指定文件夹的内容, 并没有真正导入文件到程序. 在该面板可以为模型生成 webp 格式的预览图, 或者导入选中的模型. - **画面**. 该面板用于设置右侧预览画面的参数. 绝大部分按钮或者标签或者输入框都可以通过鼠标指针悬停来获取帮助文本. ### 骨骼导入 可以直接拖放/粘贴需要导入的骨骼文件/目录到模型面板. 或者在浏览面板内右键菜单导入选中项. ### 内容调整 模型面板支持右键菜单以及部分快捷键, 并且可以多选进行模型参数的批量调整. 预览画面除了使用面板进行参数设置外, 支持部分鼠标动作: - 左键可以选择和拖拽模型, 按下 `Ctrl` 键可以实现多选, 与左侧列表选择是联动的. - 右键对整体画面进行拖动. - 滚轮进行画面缩放, 按住 `Ctrl` 可以对选中的模型进行批量缩放. - 仅渲染选中模式, 在该模式下, 预览画面仅包含被选中的模型, 并且只能通过左侧列表改变选中状态. 预览画面下方按钮支持对画面时间进行调整, 可以当作一个简易的播放器. ### 内容导出 在模型列表里, 右键单击选中的模型, 弹出菜单里可以对选中项执行导出操作. 导出有以下几个关键参数: - 输出文件夹. 这个参数某些时候可选, 当不提供时, 则将输出产物输出到每个模型各自的模型文件夹, 否则输出产物全部输出到提供的输出文件夹. - 导出单个. 默认是每个模型独立导出, 即对模型列表进行批量操作, 如果选择仅导出单个, 那么被导出的所有模型将在同一个画面上被渲染, 输出产物只有一份. - 自动分辨率. 该模式会忽略预览画面的分辨率和视区参数, 导出产物的分辨率与被导出内容的实际大小一致, 如果是动图或者视频则会与完整显示动画的必需大小一致. ### 动态壁纸 动态壁纸通过桌面投影实现, 可以将当前预览画面上的内容实时投影至桌面. 在程序首选项或者托盘图标右键菜单中可以进行桌面投影的启用与否, 模型和画面参数调整完成后, 可以将当前参数保存为工作区文件, 方便之后恢复该配置. 如果希望开机自启常驻壁纸, 也可以在首选项中启用开机自启, 并且设置启动后需要加载的工作区文件. ### 命令行工具 项目附带一个纯命令行工具 `SpineViewerCLI`, 目前支持对单个模型执行一些简单操作, 例如参数值查询以及导出等, 并且 Release 界面提供 Windows 和 Linux 多平台二进制文件. ```bash $ SpineViewerCLI -h Description: Root Command Usage: SpineViewerCLI [command] [options] Options: -q, --quiet Suppress console logging (quiet mode). -?, -h, --help Show help and usage information --version Show version information Commands: query Query information of single model preview Preview a model export Export single model ``` ### 更多 更为详细的使用方法和说明见 [Wiki](https://github.com/ww-rm/SpineViewer/wiki), 有使用上的问题或者 BUG 可以提个 [Issue](https://github.com/ww-rm/SpineViewer/issues). ## Acknowledgements - [spine-runtimes](https://github.com/EsotericSoftware/spine-runtimes) - [SFML.Net](https://github.com/SFML/SFML.Net) - [FFMpegCore](https://github.com/rosenbjerg/FFMpegCore) - [HandyControl](https://github.com/HandyOrg/HandyControl) - [NLog](https://github.com/NLog/NLog) - [SkiaSharp](https://github.com/mono/SkiaSharp) - [Spectre.Console](https://github.com/spectreconsole/spectre.console) --- *如果你觉得这个项目不错请给个 :star:, 并分享给更多人知道! :\)* [![Stargazers over time](https://starchart.cc/ww-rm/SpineViewer.svg?variant=adaptive)](https://starchart.cc/ww-rm/SpineViewer)