@galacean/effects-core 2.9.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 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.0
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 *= textItem.transform.scale.x / scaleFactor;
32771
- item.transform.scale.y *= textItem.transform.scale.y / scaleFactor;
32772
- item.transform.scale.z *= textItem.transform.scale.z / scaleFactor;
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.0";
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.0";
38707
+ var version = "2.9.1";
38517
38708
  logger.info("Core version: " + version + ".");
38518
38709
 
38519
38710
  exports.ActivationMixerPlayable = ActivationMixerPlayable;