pixi.js
Version:
<p align="center"> <a href="https://pixijs.com" target="_blank" rel="noopener noreferrer"> <img height="150" src="https://files.pixijs.download/branding/pixijs-logo-transparent-dark.svg?v=1" alt="PixiJS logo"> </a> </p> <br/> <p align="center">
77 lines (73 loc) • 2.97 kB
JavaScript
;
var adapter = require('../../../../environment/adapter.js');
var Extensions = require('../../../../extensions/Extensions.js');
var ImageSource = require('../../../../rendering/renderers/shared/texture/sources/ImageSource.js');
var GraphicsContext = require('../../../../scene/graphics/shared/GraphicsContext.js');
var getResolutionOfUrl = require('../../../../utils/network/getResolutionOfUrl.js');
var checkDataUrl = require('../../../utils/checkDataUrl.js');
var checkExtension = require('../../../utils/checkExtension.js');
var LoaderParser = require('../LoaderParser.js');
var createTexture = require('./utils/createTexture.js');
;
const validSVGExtension = ".svg";
const validSVGMIME = "image/svg+xml";
const loadSvg = {
extension: {
type: Extensions.ExtensionType.LoadParser,
priority: LoaderParser.LoaderParserPriority.Low,
name: "loadSVG"
},
/** used for deprecation purposes */
name: "loadSVG",
id: "svg",
config: {
crossOrigin: "anonymous",
parseAsGraphicsContext: false
},
test(url) {
return checkDataUrl.checkDataUrl(url, validSVGMIME) || checkExtension.checkExtension(url, validSVGExtension);
},
async load(url, asset, loader) {
if (asset.data?.parseAsGraphicsContext ?? this.config.parseAsGraphicsContext) {
return loadAsGraphics(url);
}
return loadAsTexture(url, asset, loader, this.config.crossOrigin);
},
unload(asset) {
asset.destroy(true);
}
};
async function loadAsTexture(url, asset, loader, crossOrigin) {
const response = await adapter.DOMAdapter.get().fetch(url);
const image = adapter.DOMAdapter.get().createImage();
image.src = `data:image/svg+xml;charset=utf-8,${encodeURIComponent(await response.text())}`;
image.crossOrigin = crossOrigin;
await image.decode();
const width = asset.data?.width ?? image.width;
const height = asset.data?.height ?? image.height;
const resolution = asset.data?.resolution || getResolutionOfUrl.getResolutionOfUrl(url);
const canvasWidth = Math.ceil(width * resolution);
const canvasHeight = Math.ceil(height * resolution);
const canvas = adapter.DOMAdapter.get().createCanvas(canvasWidth, canvasHeight);
const context = canvas.getContext("2d");
context.imageSmoothingEnabled = true;
context.imageSmoothingQuality = "high";
context.drawImage(image, 0, 0, width * resolution, height * resolution);
const { parseAsGraphicsContext: _p, ...rest } = asset.data ?? {};
const base = new ImageSource.ImageSource({
resource: canvas,
alphaMode: "premultiply-alpha-on-upload",
resolution,
...rest
});
return createTexture.createTexture(base, loader, url);
}
async function loadAsGraphics(url) {
const response = await adapter.DOMAdapter.get().fetch(url);
const svgSource = await response.text();
const context = new GraphicsContext.GraphicsContext();
context.svg(svgSource);
return context;
}
exports.loadSvg = loadSvg;
//# sourceMappingURL=loadSVG.js.map