Spine降版本兼容问题处理

2023-11-21 21:48

本文主要是介绍Spine降版本兼容问题处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

版本相关知识

首先了解一下与Spine版本相关的东西。一个是Spine的软件版本,一个是Spine的工程版本(.spine),一个是Spine导出的文件版本(.atlas png bytes/json),最后一个就是Unity使用的Spine runtime版本,这几个除了Spine的软件可以对Spine工程向下兼容,其他基本均不兼容,需要版本一致才能正常使用。其中runtime是开源工程,这里是git工程地址

Spine软件版本可以在启动的时候选择,如下图所示

高版本的Spine软件是可以打开低版本的工程文件的(4.0软件打开3.6工程),但是注意如果修改后进行保存,会导致工程文件升级到高版本,导致无法回退。所以在进行这个操作的时候,建议先备份低版本工程。

高版本的Spine软件是可以导出低版本的导出文件,可以在导出时选择版本,但是会存在一些信息丢失和兼容性问题。

Spine软件不能导入低版本的导出文件,Spine的导出文件和SpineRuntime版本是一一对应的,如果导出的Spine动画文件和Runtime版本是不一致的时候,可能会出现不兼容的问题。并且SpineRuntime和Unity也有一定的对应关系。下图是截止至2022.1.24时官网显示的对应关系,如有变化,可以点击查看官网信息

Spine runtime版本

支持的Unity版本

spine-unity 4.0.00+

Unity 2017.1-2021.1

spine-unity 3.8

Unity 2017.1-2020.3

spine-unity 3.7

Unity 5.6-2018.4

spine-unity 3.6

Unity 5.6-2018.2

spine-unity 3.5

Unity 5.4-2017.1

spine-unity 3.0

Unity 4.6

降版本操作步骤

操作环境:Unity目标版本是2020,spine runtime 3.6,spine工程和软件均为4.0

1.导出spine动画文件

打开工程,在导出文件的时候选择3.6版本,生成.atlas.txt .png .json文件

生成文件如下

这里需要注意一个问题,导出文件的spine版本字段需要修改,虽然选择的版本是3.6,但是导出时,版本字段显示为 "spine": "3.7-from-3.8-from-4.0.58",需要把spine版本字段改成3.6

修改前:

{"skeleton": { "hash": "/iWACBJx9C0", "spine": "3.7-from-3.8-from-4.0.58", "x": -1075.55, "y": -637.13, "width": 2041.4, "height": 1498.37 }}

修改后:

{"skeleton": { "hash": "/iWACBJx9C0", "spine": "3.6", "x": -1075.55, "y": -637.13, "width": 2041.4, "height": 1498.37 }}

2.生成材质和.asset文件

这里如果直接将生成的.atlas.txt .png .json文件导入到unity 2020工程中,会导致无法正确地生成SkeletonData.asset文件的情况。所以需要借助低版本的unity。

所以先将导出文件拖到已经加入spine 3.6 runtime的unity 2019工程中,正确生成.asset文件和材质。

3.导入spine导出文件和生成的材质和.asset文件

在unity2019中选中导出文件和生成的材质和.asset文件等,用导出资源的方式导出到.unitypackage文件中,最后回到unity 2020工程,再import .unitypackage文件。动画就可以正常使用了。(注意这里如果直接用拖文件的方式,直接拖到2020工程中同样会出错)

降版本导致的问题

1.丢失curve信息

用spine 4.0的软件分别导出3.6和4.0版本带curve属性的动画

下面是4.0版本,可以看到"curve"信息是正常导出的

"zhuzi4": {"translate": [{"time": 0.125,"x": -84.08,"y": -10.78,"curve": [0.307, -74.64, 0.477, -67.23, 0.307, -10.78, 0.477, -10.78]},{"time": 0.625,"x": -62.73,"y": -10.78,"curve": [1.055, -51.65, 1.457, -43.65, 1.055, -10.78, 1.457, -10.78]},{"time": 1.825,"x": -39.13,"y": -10.78,"curve": [1.884, -38.39, 1.942, -37.72, 1.884, -10.78, 1.942, -10.78]},{ "time": 2, "x": -37.15, "y": -10.78 }],"scale": [{ "x": 0.5, "y": 0.5, "curve": "stepped" },{ "time": 0.125, "x": 0.5, "y": 0.5 },{ "time": 0.3, "x": 1.04, "y": 1.04, "curve": "stepped" },{ "time": 1.825, "x": 1.04, "y": 1.04 }]}

下面是3.6版本,可以看到translate的所有curve信息都丢失了。

"zhuzi4": {"translate": [{ "time": 0.125, "x": -84.08, "y": -10.78 },{ "time": 0.625, "x": -62.73, "y": -10.78 },{ "time": 1.825, "x": -39.13, "y": -10.78 },{ "time": 2, "x": -37.15, "y": -10.78 }],"scale": [{ "x": 0.5, "y": 0.5, "curve": "stepped", "time": 0.0 },{ "time": 0.125, "x": 0.5, "y": 0.5 },{ "time": 0.3, "x": 1.04, "y": 1.04, "curve": "stepped" },{ "time": 1.825, "x": 1.04, "y": 1.04 }]}

去官网反馈了这个问题,官方回复是,高版本导出低版本文件的时候就是会丢失一些信息,这里可以查看帖子

不过经过尝试发现,其实3.6本身是支持curve操作的,所以可以手动将4.0导出文件的curve属性添加到3.6的导出文件中。

2.Path动画丢失

导入动画发现原先设置的路径动画丢失。对比了一下用4.0版本工程导出的3.6版本json,和用3.6版本工程导出的3.6版本json文件发现。3.6导出的json文件中路径动画的关键字是"paths",而4.0导出的json文件路径动画是"path",导致json解析的时候无法识别。查看spine runtime相关代码发现json解析的逻辑是在SkeletonJson.cs中 // Path constraint timelines. 下方的代码

原代码是

// Path constraint timelines.
if (map.ContainsKey("paths")) 
{foreach (KeyValuePair<String, Object> constraintMap in (Dictionary<String, Object>)map["paths"]) {//这里的逻辑无需修改,就不贴了}
} 

修改后的代码是

// Path constraint timelines.
// 3.6版本默认导出的key是paths,4.0降版本之后导出的key是path,为了兼容,同事判断两个key
string[] pathKeys = { "paths", "path" };
string finalKey = null;
for (int i = 0; i < pathKeys.Length; i++)
{if (map.ContainsKey(pathKeys[i])){finalKey = pathKeys[i];break;}
}
if (finalKey != null) 
{foreach (KeyValuePair<String, Object> constraintMap in (Dictionary<String, Object>)map[finalKey]) {//这里的逻辑无需修改,就不贴了}
}

修改之后路径动画就可以正常播放了.

这篇关于Spine降版本兼容问题处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/405314

相关文章

ONLYOFFICE 8.1 版本桌面编辑器测评

在现代办公环境中,办公软件的重要性不言而喻。从文档处理到电子表格分析,再到演示文稿制作,强大且高效的办公软件工具能够极大提升工作效率。ONLYOFFICE 作为一个功能全面且开源的办公软件套件,一直以来都受到广大用户的关注与喜爱。而其最新发布的 ONLYOFFICE 8.1 版本桌面编辑器,更是带来了诸多改进和新特性。本文将详细评测 ONLYOFFICE 8.1 版本桌面编辑器,探讨其在功能、用户

17.用300行代码手写初体验Spring V1.0版本

1.1.课程目标 1、了解看源码最有效的方式,先猜测后验证,不要一开始就去调试代码。 2、浓缩就是精华,用 300行最简洁的代码 提炼Spring的基本设计思想。 3、掌握Spring框架的基本脉络。 1.2.内容定位 1、 具有1年以上的SpringMVC使用经验。 2、 希望深入了解Spring源码的人群,对 Spring有一个整体的宏观感受。 3、 全程手写实现SpringM

Visual Studio中,MSBUild版本问题

假如项目规定了MSBUild版本,那么在安装完Visual Studio后,假如带的MSBUild版本与项目要求的版本不符合要求,那么可以把需要的MSBUild添加到系统中,然后即可使用。步骤如下:            假如项目需要使用V12的MSBUild,而安装的Visual Studio带的MSBUild版本为V14。 ①到MSDN下载V12 MSBUild包,把V12包解压到目录(

百度OCR识别结构结构化处理视频

https://edu.csdn.net/course/detail/10506

如何在Java中处理JSON数据?

如何在Java中处理JSON数据? 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我们将探讨在Java中如何处理JSON数据。JSON(JavaScript Object Notation)作为一种轻量级的数据交换格式,在现代应用程序中被广泛使用。Java通过多种库和API提供了处理JSON的能力,我们将深入了解其用法和最佳

Pycharm配置conda环境(解决新版本无法识别可执行文件问题)

引言: 很多小伙伴在下载最新版本的pycharm或者更新到最新版本后为项目配置conda环境的时候,发现文件夹目录中无法显示可执行文件(一般为python.exe),以下就是本人遇到该问题后试验和解决该问题的一些方法和思路。 一般遇到该问题的人群有两种,一种是刚入门对pycharm进行conda环境配置的小白(例如我),不熟悉相关环境配置的操作和过程,还有一种是入坑pycharm有段时间的老手

AI学习指南机器学习篇-朴素贝叶斯处理连续特征和离散特征

AI学习指南机器学习篇-朴素贝叶斯处理连续特征和离散特征 在机器学习领域,朴素贝叶斯是一种常用的分类算法,它的简单性和高效性使得它在实际应用中得到了广泛的应用。然而,在使用朴素贝叶斯算法进行分类时,我们通常会面临一个重要的问题,就是如何处理连续特征和离散特征。因为朴素贝叶斯算法基于特征的条件独立性假设,所以对于不同类型的特征,我们需要采取不同的处理方式。 在本篇博客中,我们将探讨如何有效地处理

神经网络第四篇:推理处理之手写数字识别

到目前为止,我们已经介绍完了神经网络的基本结构,现在用一个图像识别示例对前面的知识作整体的总结。本专题知识点如下: MNIST数据集图像数据转图像神经网络的推理处理批处理  MNIST数据集          mnist数据图像 MNIST数据集由0到9的数字图像构成。像素取值在0到255之间。每个图像数据都相应地标有“7”、“2”、“1”等数字标签。MNIST数据集中,

vue怎么处理跨域

Vue.js 本身并不直接解决跨域问题,因为跨域问题主要是浏览器基于同源策略(Same-origin policy)的一种安全限制。然而,在Vue.js项目中,我们可以采取一些策略来绕过或处理跨域问题。 解决跨域问题的常用方法: 代理服务器:在开发环境中,我们可以配置一个代理服务器来转发API请求,从而绕过浏览器的同源策略。Vue CLI 提供了内置的代理功能,可以在 vue.config.j

【机器学习】自然语言处理的新前沿:GPT-4与Beyond

📝个人主页:哈__ 期待您的关注  目录 🔥引言 背景介绍 文章目的 一、GPT-4简介 GPT-4概述 主要特性 局限性和挑战 二、自监督学习的新进展 自监督学习的原理 代表性模型和技术 三、少样本学习和零样本学习 少样本学习的挑战 先进方法 四、跨模态学习 跨模态学习的概念 代表性技术 应用场景 第五部分:可解释性和透明性 AI的可解释