@galacean/engine-loader 0.0.0-experimental-double11.6 → 0.0.0-experimental-double11.7

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/main.js CHANGED
@@ -2553,6 +2553,10 @@ function transcode(buffer, targetFormat, KTX2File) {
2553
2553
  cleanup();
2554
2554
  throw new Error("Invalid or unsupported .ktx2 file");
2555
2555
  }
2556
+ if (!ktx2File.startTranscoding()) {
2557
+ cleanup();
2558
+ throw new Error("KTX2 startTranscoding failed");
2559
+ }
2556
2560
  var width = ktx2File.getWidth();
2557
2561
  var height = ktx2File.getHeight();
2558
2562
  var layerCount = ktx2File.getLayers() || 1;
@@ -5519,32 +5523,28 @@ var SceneLoader = /*#__PURE__*/ function(Loader1) {
5519
5523
  // parse ambient light
5520
5524
  var ambient = data.scene.ambient;
5521
5525
  var useCustomAmbient = ambient.specularMode === "Custom";
5526
+ var useSH = ambient.diffuseMode === engineCore.DiffuseMode.SphericalHarmonics;
5527
+ scene.ambientLight.diffuseIntensity = ambient.diffuseIntensity;
5528
+ scene.ambientLight.specularIntensity = ambient.specularIntensity;
5529
+ scene.ambientLight.diffuseMode = ambient.diffuseMode;
5530
+ scene.ambientLight.diffuseSolidColor.copyFrom(ambient.diffuseSolidColor);
5531
+ scene.ambientLight.specularTextureDecodeRGBM = true;
5522
5532
  if (useCustomAmbient && ambient.customAmbientLight) {
5523
- // @ts-ignore
5524
- // prettier-ignore
5525
- var customAmbientPromise = resourceManager.getResourceByRef(ambient.customAmbientLight).then(function(ambientLight) {
5526
- scene.ambientLight = ambientLight;
5527
- scene.ambientLight.diffuseIntensity = ambient.diffuseIntensity;
5528
- scene.ambientLight.specularIntensity = ambient.specularIntensity;
5529
- scene.ambientLight.diffuseMode = ambient.diffuseMode;
5530
- scene.ambientLight.diffuseSolidColor.copyFrom(ambient.diffuseSolidColor);
5531
- });
5532
- promises.push(customAmbientPromise);
5533
- } else if (!useCustomAmbient && ambient.ambientLight) {
5534
- // @ts-ignore
5535
- // prettier-ignore
5536
- var ambientLightPromise = resourceManager.getResourceByRef(ambient.ambientLight).then(function(ambientLight) {
5537
- scene.ambientLight = ambientLight;
5538
- scene.ambientLight.diffuseIntensity = ambient.diffuseIntensity;
5539
- scene.ambientLight.specularIntensity = ambient.specularIntensity;
5540
- scene.ambientLight.diffuseMode = ambient.diffuseMode;
5541
- scene.ambientLight.diffuseSolidColor.copyFrom(ambient.diffuseSolidColor);
5542
- });
5543
- promises.push(ambientLightPromise);
5544
- } else {
5545
- scene.ambientLight.diffuseIntensity = ambient.diffuseIntensity;
5546
- scene.ambientLight.specularIntensity = ambient.specularIntensity;
5547
- scene.ambientLight.diffuseSolidColor.copyFrom(ambient.diffuseSolidColor);
5533
+ promises.push(// @ts-ignore
5534
+ resourceManager.getResourceByRef(ambient.customAmbientLight).then(function(ambientLight) {
5535
+ scene.ambientLight.specularTexture = ambientLight.specularTexture;
5536
+ }));
5537
+ }
5538
+ if (ambient.ambientLight && (!useCustomAmbient || useSH)) {
5539
+ promises.push(// @ts-ignore
5540
+ resourceManager.getResourceByRef(ambient.ambientLight).then(function(ambientLight) {
5541
+ if (!useCustomAmbient) {
5542
+ scene.ambientLight.specularTexture = ambientLight.specularTexture;
5543
+ }
5544
+ if (useSH) {
5545
+ scene.ambientLight.diffuseSphericalHarmonics = ambientLight.diffuseSphericalHarmonics;
5546
+ }
5547
+ }));
5548
5548
  }
5549
5549
  var background = data.scene.background;
5550
5550
  scene.background.mode = background.mode;
@@ -5601,13 +5601,13 @@ SceneLoader = __decorate([
5601
5601
  "scene"
5602
5602
  ], true)
5603
5603
  ], SceneLoader);
5604
- ReflectionParser.registerCustomParseComponent("TextRenderer", /*#__PURE__*/ _async_to_generator(function(instance, item, engine) {
5604
+ ReflectionParser.registerCustomParseComponent("TextRenderer", /*#__PURE__*/ _async_to_generator(function(instance, item) {
5605
5605
  var props;
5606
5606
  return __generator(this, function(_state) {
5607
5607
  props = item.props;
5608
5608
  if (!props.font) {
5609
5609
  // @ts-ignore
5610
- instance.font = engineCore.Font.createFromOS(engine, props.fontFamily || "Arial");
5610
+ instance.font = engineCore.Font.createFromOS(instance.engine, props.fontFamily || "Arial");
5611
5611
  }
5612
5612
  return [
5613
5613
  2,