2023-02-17 11:06:01 +01:00

49 lines
1.9 KiB
JavaScript

import { executeOnSingleOrMultiple, isInArray, itemFromSingleOrMultiple, loadFont } from "tsparticles-engine";
export const validTypes = ["text", "character", "char"];
export class TextDrawer {
draw(context, particle, radius, opacity) {
var _a, _b, _c;
const character = particle.shapeData;
if (character === undefined) {
return;
}
const textData = character.value;
if (textData === undefined) {
return;
}
const textParticle = particle;
if (textParticle.text === undefined) {
textParticle.text = itemFromSingleOrMultiple(textData, particle.randomIndexData);
}
const text = textParticle.text, style = (_a = character.style) !== null && _a !== void 0 ? _a : "", weight = (_b = character.weight) !== null && _b !== void 0 ? _b : "400", size = Math.round(radius) * 2, font = (_c = character.font) !== null && _c !== void 0 ? _c : "Verdana", fill = particle.fill, offsetX = (text.length * radius) / 2;
context.font = `${style} ${weight} ${size}px "${font}"`;
const pos = {
x: -offsetX,
y: radius / 2,
};
context.globalAlpha = opacity;
if (fill) {
context.fillText(text, pos.x, pos.y);
}
else {
context.strokeText(text, pos.x, pos.y);
}
context.globalAlpha = 1;
}
getSidesCount() {
return 12;
}
async init(container) {
const options = container.actualOptions;
if (validTypes.find((t) => isInArray(t, options.particles.shape.type))) {
const shapeOptions = validTypes
.map((t) => options.particles.shape.options[t])
.find((t) => !!t), promises = [];
executeOnSingleOrMultiple(shapeOptions, (shape) => {
promises.push(loadFont(shape.font, shape.weight));
});
await Promise.all(promises);
}
}
}