@galacean/effects-core 2.9.1-beta.0 → 2.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +197 -6
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +197 -6
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
* Description: Galacean Effects runtime core for the web
|
|
4
4
|
* Author: Ant Group CO., Ltd.
|
|
5
5
|
* Contributors: 燃然,飂兮,十弦,云垣,茂安,意绮
|
|
6
|
-
* Version: v2.9.1
|
|
6
|
+
* Version: v2.9.1
|
|
7
7
|
*/
|
|
8
8
|
|
|
9
9
|
'use strict';
|
|
@@ -32764,21 +32764,37 @@ function version36Migration(json) {
|
|
|
32764
32764
|
var itemWorldPerPixel = textItem.transform.scale.x / ((_textComponent_options_textWidth = (_textComponent_options = textComponent.options) == null ? void 0 : _textComponent_options.textWidth) != null ? _textComponent_options_textWidth : 1);
|
|
32765
32765
|
var defaultWorldPerPixel = 0.0123;
|
|
32766
32766
|
var scaleFactor = itemWorldPerPixel / defaultWorldPerPixel;
|
|
32767
|
+
var oldScaleX = textItem.transform.scale.x;
|
|
32768
|
+
var oldScaleY = textItem.transform.scale.y;
|
|
32769
|
+
var oldScaleZ = textItem.transform.scale.z;
|
|
32767
32770
|
for(var _iterator = _create_for_of_iterator_helper_loose(json.items), _step1; !(_step1 = _iterator()).done;){
|
|
32768
32771
|
var item = _step1.value;
|
|
32769
32772
|
if (item.parentId === textItem.id && item.transform) {
|
|
32770
|
-
item.transform.scale.x *=
|
|
32771
|
-
item.transform.scale.y *=
|
|
32772
|
-
item.transform.scale.z *=
|
|
32773
|
+
item.transform.scale.x *= oldScaleX / scaleFactor;
|
|
32774
|
+
item.transform.scale.y *= oldScaleY / scaleFactor;
|
|
32775
|
+
item.transform.scale.z *= oldScaleZ / scaleFactor;
|
|
32773
32776
|
}
|
|
32774
32777
|
}
|
|
32775
32778
|
textItem.transform.scale.x = scaleFactor;
|
|
32776
32779
|
textItem.transform.scale.y = scaleFactor;
|
|
32777
32780
|
textItem.transform.scale.z = scaleFactor;
|
|
32781
|
+
textItemScaleInfos.push({
|
|
32782
|
+
item: textItem,
|
|
32783
|
+
scaleFactor: scaleFactor,
|
|
32784
|
+
oldScaleX: oldScaleX,
|
|
32785
|
+
oldScaleY: oldScaleY,
|
|
32786
|
+
oldScaleZ: oldScaleZ
|
|
32787
|
+
});
|
|
32778
32788
|
}
|
|
32779
32789
|
};
|
|
32790
|
+
var _json_animations;
|
|
32780
32791
|
// 兼容老数据 text item 的 transform scale 问题,老版本 text item 的 scale 实际上是 size,新的版本中 scale 和 size 分离
|
|
32792
|
+
var textItemScaleInfos = [];
|
|
32781
32793
|
for(var _iterator = _create_for_of_iterator_helper_loose(json.items), _step; !(_step = _iterator()).done;)_loop();
|
|
32794
|
+
// 迁移 AnimationClip 中指向 text item 的 scaleCurves 关键帧
|
|
32795
|
+
if (textItemScaleInfos.length > 0 && ((_json_animations = json.animations) == null ? void 0 : _json_animations.length)) {
|
|
32796
|
+
migrateTextScaleCurves(json, textItemScaleInfos);
|
|
32797
|
+
}
|
|
32782
32798
|
// 生成 item 的 children 字段,CompositionComponent 的 children 字段
|
|
32783
32799
|
var itemMap = new Map();
|
|
32784
32800
|
var compositionMap = new Map();
|
|
@@ -33183,6 +33199,181 @@ function convertSpineData(resource, content, jsonScene) {
|
|
|
33183
33199
|
})
|
|
33184
33200
|
};
|
|
33185
33201
|
}
|
|
33202
|
+
/**
|
|
33203
|
+
* 批量迁移所有指向 textItem(或其子元素)的 scaleCurves 关键帧。
|
|
33204
|
+
* Animator 组件挂在 composition 上,path 从 composition 的顶层 item 开始解析。
|
|
33205
|
+
* 所有 Map 只构建一次,避免每个 text item 重复分配。
|
|
33206
|
+
*/ function migrateTextScaleCurves(json, textItemScaleInfos) {
|
|
33207
|
+
// 建立 id → item 和 id → children 映射
|
|
33208
|
+
var idToItem = new Map();
|
|
33209
|
+
var childrenMap = new Map();
|
|
33210
|
+
for(var _iterator = _create_for_of_iterator_helper_loose(json.items), _step; !(_step = _iterator()).done;){
|
|
33211
|
+
var item = _step.value;
|
|
33212
|
+
idToItem.set(item.id, item);
|
|
33213
|
+
if (item.parentId) {
|
|
33214
|
+
var children = childrenMap.get(item.parentId);
|
|
33215
|
+
if (!children) {
|
|
33216
|
+
children = [];
|
|
33217
|
+
childrenMap.set(item.parentId, children);
|
|
33218
|
+
}
|
|
33219
|
+
children.push(item);
|
|
33220
|
+
}
|
|
33221
|
+
}
|
|
33222
|
+
// 为每个 textItem 收集子孙 id 集合,并建立 targetId → scaleInfo 的快速查找
|
|
33223
|
+
var textItemIdToInfo = new Map();
|
|
33224
|
+
var textChildIdToInfo = new Map();
|
|
33225
|
+
for(var _iterator1 = _create_for_of_iterator_helper_loose(textItemScaleInfos), _step1; !(_step1 = _iterator1()).done;){
|
|
33226
|
+
var info = _step1.value;
|
|
33227
|
+
textItemIdToInfo.set(info.item.id, info);
|
|
33228
|
+
// 只收集直接子节点,深层后代已通过直接子节点的静态 scale 调整继承了正确的变换
|
|
33229
|
+
var children1 = childrenMap.get(info.item.id);
|
|
33230
|
+
if (children1) {
|
|
33231
|
+
for(var _iterator2 = _create_for_of_iterator_helper_loose(children1), _step2; !(_step2 = _iterator2()).done;){
|
|
33232
|
+
var child = _step2.value;
|
|
33233
|
+
textChildIdToInfo.set(child.id, info);
|
|
33234
|
+
}
|
|
33235
|
+
}
|
|
33236
|
+
}
|
|
33237
|
+
// 建立 component id → component 映射
|
|
33238
|
+
var componentMap = new Map();
|
|
33239
|
+
for(var _iterator3 = _create_for_of_iterator_helper_loose(json.components), _step3; !(_step3 = _iterator3()).done;){
|
|
33240
|
+
var comp = _step3.value;
|
|
33241
|
+
componentMap.set(comp.id, comp);
|
|
33242
|
+
}
|
|
33243
|
+
// 建立 animation id → data 映射
|
|
33244
|
+
var animationMap = new Map();
|
|
33245
|
+
for(var _iterator4 = _create_for_of_iterator_helper_loose(json.animations), _step4; !(_step4 = _iterator4()).done;){
|
|
33246
|
+
var anim = _step4.value;
|
|
33247
|
+
animationMap.set(anim.id, anim);
|
|
33248
|
+
}
|
|
33249
|
+
// 遍历所有 composition,找 Animator 组件并处理其 scaleCurves
|
|
33250
|
+
for(var _iterator5 = _create_for_of_iterator_helper_loose(json.compositions), _step5; !(_step5 = _iterator5()).done;){
|
|
33251
|
+
var composition = _step5.value;
|
|
33252
|
+
var _animatorData_graphAsset, _graphAsset_graphDataSet;
|
|
33253
|
+
var animatorComp = void 0;
|
|
33254
|
+
var compositionComp = void 0;
|
|
33255
|
+
for(var _iterator6 = _create_for_of_iterator_helper_loose(composition.components), _step6; !(_step6 = _iterator6()).done;){
|
|
33256
|
+
var compRef = _step6.value;
|
|
33257
|
+
var comp1 = componentMap.get(compRef.id);
|
|
33258
|
+
if ((comp1 == null ? void 0 : comp1.dataType) === DataType.Animator) {
|
|
33259
|
+
animatorComp = comp1;
|
|
33260
|
+
} else if ((comp1 == null ? void 0 : comp1.dataType) === DataType.CompositionComponent) {
|
|
33261
|
+
compositionComp = comp1;
|
|
33262
|
+
}
|
|
33263
|
+
if (animatorComp && compositionComp) {
|
|
33264
|
+
break;
|
|
33265
|
+
}
|
|
33266
|
+
}
|
|
33267
|
+
if (!animatorComp) {
|
|
33268
|
+
continue;
|
|
33269
|
+
}
|
|
33270
|
+
// 获取 composition 的顶层 items
|
|
33271
|
+
var topItems = void 0;
|
|
33272
|
+
if (compositionComp) {
|
|
33273
|
+
var ccData = compositionComp;
|
|
33274
|
+
var items = ccData.items;
|
|
33275
|
+
if (items) {
|
|
33276
|
+
topItems = [];
|
|
33277
|
+
for(var _iterator7 = _create_for_of_iterator_helper_loose(items), _step7; !(_step7 = _iterator7()).done;){
|
|
33278
|
+
var ref = _step7.value;
|
|
33279
|
+
var item1 = idToItem.get(ref.id);
|
|
33280
|
+
if (item1 && !item1.parentId) {
|
|
33281
|
+
topItems.push(item1);
|
|
33282
|
+
}
|
|
33283
|
+
}
|
|
33284
|
+
}
|
|
33285
|
+
}
|
|
33286
|
+
if ((!topItems || topItems.length === 0) && composition.children) {
|
|
33287
|
+
topItems = [];
|
|
33288
|
+
for(var _iterator8 = _create_for_of_iterator_helper_loose(composition.children), _step8; !(_step8 = _iterator8()).done;){
|
|
33289
|
+
var ref1 = _step8.value;
|
|
33290
|
+
var item2 = idToItem.get(ref1.id);
|
|
33291
|
+
if (item2) {
|
|
33292
|
+
topItems.push(item2);
|
|
33293
|
+
}
|
|
33294
|
+
}
|
|
33295
|
+
}
|
|
33296
|
+
if (!topItems || topItems.length === 0) {
|
|
33297
|
+
continue;
|
|
33298
|
+
}
|
|
33299
|
+
// 获取 Animator 关联的 AnimationClip
|
|
33300
|
+
var animatorData = animatorComp;
|
|
33301
|
+
var graphAsset = animationMap.get((_animatorData_graphAsset = animatorData.graphAsset) == null ? void 0 : _animatorData_graphAsset.id);
|
|
33302
|
+
if (!(graphAsset == null ? void 0 : (_graphAsset_graphDataSet = graphAsset.graphDataSet) == null ? void 0 : _graphAsset_graphDataSet.resources)) {
|
|
33303
|
+
continue;
|
|
33304
|
+
}
|
|
33305
|
+
for(var _iterator9 = _create_for_of_iterator_helper_loose(graphAsset.graphDataSet.resources), _step9; !(_step9 = _iterator9()).done;){
|
|
33306
|
+
var clipRef = _step9.value;
|
|
33307
|
+
var clip = animationMap.get(clipRef.id);
|
|
33308
|
+
if (!(clip == null ? void 0 : clip.scaleCurves)) {
|
|
33309
|
+
continue;
|
|
33310
|
+
}
|
|
33311
|
+
for(var _iterator10 = _create_for_of_iterator_helper_loose(clip.scaleCurves), _step10; !(_step10 = _iterator10()).done;){
|
|
33312
|
+
var scaleCurve = _step10.value;
|
|
33313
|
+
var target = resolveTargetFromTopItems(topItems, scaleCurve.path, childrenMap);
|
|
33314
|
+
if (!target) {
|
|
33315
|
+
continue;
|
|
33316
|
+
}
|
|
33317
|
+
var selfInfo = textItemIdToInfo.get(target.id);
|
|
33318
|
+
if (selfInfo) {
|
|
33319
|
+
// 曲线指向 textItem 自身:从旧 scale 空间转换到新 scale 空间
|
|
33320
|
+
scaleVector3CurveKeyFrames(scaleCurve.keyFrames, selfInfo.scaleFactor / selfInfo.oldScaleX, selfInfo.scaleFactor / selfInfo.oldScaleY, selfInfo.scaleFactor / selfInfo.oldScaleZ);
|
|
33321
|
+
continue;
|
|
33322
|
+
}
|
|
33323
|
+
var childInfo = textChildIdToInfo.get(target.id);
|
|
33324
|
+
if (childInfo) {
|
|
33325
|
+
// 曲线指向 textItem 的子元素:补偿父元素 scale 变化
|
|
33326
|
+
scaleVector3CurveKeyFrames(scaleCurve.keyFrames, childInfo.oldScaleX / childInfo.scaleFactor, childInfo.oldScaleY / childInfo.scaleFactor, childInfo.oldScaleZ / childInfo.scaleFactor);
|
|
33327
|
+
}
|
|
33328
|
+
}
|
|
33329
|
+
}
|
|
33330
|
+
}
|
|
33331
|
+
}
|
|
33332
|
+
function resolveTargetFromTopItems(topItems, path, childrenMap) {
|
|
33333
|
+
var _loop = function(i) {
|
|
33334
|
+
var _childrenMap_get;
|
|
33335
|
+
current = (_childrenMap_get = childrenMap.get(current.id)) == null ? void 0 : _childrenMap_get.find(function(c) {
|
|
33336
|
+
return c.name === segments[i];
|
|
33337
|
+
});
|
|
33338
|
+
};
|
|
33339
|
+
if (!path) {
|
|
33340
|
+
return undefined;
|
|
33341
|
+
}
|
|
33342
|
+
var segments = path.split("/");
|
|
33343
|
+
var current = topItems.find(function(item) {
|
|
33344
|
+
return item.name === segments[0];
|
|
33345
|
+
});
|
|
33346
|
+
for(var i = 1; i < segments.length && current; i++)_loop(i);
|
|
33347
|
+
return current;
|
|
33348
|
+
}
|
|
33349
|
+
function scaleVector3CurveKeyFrames(keyFrames, factorX, factorY, factorZ) {
|
|
33350
|
+
if (!Array.isArray(keyFrames) || keyFrames[0] !== ValueType.VECTOR3_CURVE) {
|
|
33351
|
+
return;
|
|
33352
|
+
}
|
|
33353
|
+
var value = keyFrames[1];
|
|
33354
|
+
if (!Array.isArray(value) || value.length !== 3) {
|
|
33355
|
+
return;
|
|
33356
|
+
}
|
|
33357
|
+
scaleBezierValue(value[0], factorX);
|
|
33358
|
+
scaleBezierValue(value[1], factorY);
|
|
33359
|
+
scaleBezierValue(value[2], factorZ);
|
|
33360
|
+
}
|
|
33361
|
+
function scaleBezierValue(bezier, factor) {
|
|
33362
|
+
if (!Array.isArray(bezier) || bezier[0] !== ValueType.BEZIER_CURVE || !Array.isArray(bezier[1])) {
|
|
33363
|
+
return;
|
|
33364
|
+
}
|
|
33365
|
+
var keyframes = bezier[1];
|
|
33366
|
+
for(var _iterator = _create_for_of_iterator_helper_loose(keyframes), _step; !(_step = _iterator()).done;){
|
|
33367
|
+
var kf = _step.value;
|
|
33368
|
+
if (!Array.isArray(kf) || kf.length < 2 || !Array.isArray(kf[1])) {
|
|
33369
|
+
continue;
|
|
33370
|
+
}
|
|
33371
|
+
var values = kf[1];
|
|
33372
|
+
for(var i = 1; i < values.length; i += 2){
|
|
33373
|
+
values[i] *= factor;
|
|
33374
|
+
}
|
|
33375
|
+
}
|
|
33376
|
+
}
|
|
33186
33377
|
|
|
33187
33378
|
function getStandardParticleContent(particle) {
|
|
33188
33379
|
var options = particle.options;
|
|
@@ -33459,7 +33650,7 @@ function getStandardSpriteContent(sprite, transform) {
|
|
|
33459
33650
|
return ret;
|
|
33460
33651
|
}
|
|
33461
33652
|
|
|
33462
|
-
var version$1 = "2.9.1
|
|
33653
|
+
var version$1 = "2.9.1";
|
|
33463
33654
|
var v0 = /^(\d+)\.(\d+)\.(\d+)(-(\w+)\.\d+)?$/;
|
|
33464
33655
|
var standardVersion = /^(\d+)\.(\d+)$/;
|
|
33465
33656
|
var reverseParticle = false;
|
|
@@ -38513,7 +38704,7 @@ registerPlugin("text", TextLoader);
|
|
|
38513
38704
|
registerPlugin("sprite", SpriteLoader);
|
|
38514
38705
|
registerPlugin("particle", ParticleLoader);
|
|
38515
38706
|
registerPlugin("interact", InteractLoader);
|
|
38516
|
-
var version = "2.9.1
|
|
38707
|
+
var version = "2.9.1";
|
|
38517
38708
|
logger.info("Core version: " + version + ".");
|
|
38518
38709
|
|
|
38519
38710
|
exports.ActivationMixerPlayable = ActivationMixerPlayable;
|