@babylonjs/loaders
Version:
For usage documentation please visit https://doc.babylonjs.com/features/featuresDeepDive/importers/loadingFileTypes/.
39 lines • 1.72 kB
JavaScript
import { GLTFLoader } from "../glTFLoader.js";
import { registerGLTFExtension, unregisterGLTFExtension } from "../glTFLoaderExtensionRegistry.js";
const NAME = "MSFT_sRGBFactors";
/** @internal */
// eslint-disable-next-line @typescript-eslint/naming-convention
export class MSFT_sRGBFactors {
/** @internal */
constructor(loader) {
/** @internal */
this.name = NAME;
this._loader = loader;
this.enabled = this._loader.isExtensionUsed(NAME);
}
/** @internal */
dispose() {
this._loader = null;
}
/** @internal*/
// eslint-disable-next-line no-restricted-syntax
loadMaterialPropertiesAsync(context, material, babylonMaterial) {
return GLTFLoader.LoadExtraAsync(context, material, this.name, async (extraContext, extra) => {
if (extra) {
const adapter = this._loader._getOrCreateMaterialAdapter(babylonMaterial);
const promise = this._loader.loadMaterialPropertiesAsync(context, material, babylonMaterial);
const useExactSrgbConversions = babylonMaterial.getScene().getEngine().useExactSrgbConversions;
if (!adapter.baseColorTexture) {
adapter.baseColor.toLinearSpaceToRef(adapter.baseColor, useExactSrgbConversions);
}
if (!adapter.specularColorTexture) {
adapter.specularColor.toLinearSpaceToRef(adapter.specularColor, useExactSrgbConversions);
}
return await promise;
}
});
}
}
unregisterGLTFExtension(NAME);
registerGLTFExtension(NAME, true, (loader) => new MSFT_sRGBFactors(loader));
//# sourceMappingURL=MSFT_sRGBFactors.js.map