@tsparticles/shape-emoji 3.0.0-beta.5 → 3.0.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/browser/EmojiDrawer.js +27 -10
- package/cjs/EmojiDrawer.js +27 -10
- package/esm/EmojiDrawer.js +27 -10
- package/package.json +2 -2
- package/report.html +2 -2
- package/tsparticles.shape.emoji.js +28 -12
- package/tsparticles.shape.emoji.min.js +1 -1
- package/tsparticles.shape.emoji.min.js.LICENSE.txt +1 -1
- package/types/EmojiParticle.d.ts +1 -1
- package/umd/EmojiDrawer.js +27 -10
package/browser/EmojiDrawer.js
CHANGED
|
@@ -7,7 +7,7 @@ export class EmojiDrawer {
|
|
|
7
7
|
}
|
|
8
8
|
destroy() {
|
|
9
9
|
for (const [, emojiData] of this._emojiShapeDict) {
|
|
10
|
-
emojiData?.close();
|
|
10
|
+
emojiData instanceof ImageBitmap && emojiData?.close();
|
|
11
11
|
}
|
|
12
12
|
}
|
|
13
13
|
draw(data) {
|
|
@@ -51,16 +51,33 @@ export class EmojiDrawer {
|
|
|
51
51
|
particle.emojiData = existingData;
|
|
52
52
|
return;
|
|
53
53
|
}
|
|
54
|
-
const canvasSize = getRangeMax(particle.size.value) * 2
|
|
55
|
-
|
|
56
|
-
if (
|
|
57
|
-
|
|
54
|
+
const canvasSize = getRangeMax(particle.size.value) * 2;
|
|
55
|
+
let emojiData;
|
|
56
|
+
if (typeof OffscreenCanvas !== "undefined") {
|
|
57
|
+
const canvas = new OffscreenCanvas(canvasSize, canvasSize), context = canvas.getContext("2d");
|
|
58
|
+
if (!context) {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
context.font = `400 ${getRangeMax(particle.size.value) * 2}px ${font}`;
|
|
62
|
+
context.textBaseline = "middle";
|
|
63
|
+
context.textAlign = "center";
|
|
64
|
+
context.fillText(emoji, getRangeMax(particle.size.value), getRangeMax(particle.size.value));
|
|
65
|
+
emojiData = canvas.transferToImageBitmap();
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
const canvas = document.createElement("canvas");
|
|
69
|
+
canvas.width = canvasSize;
|
|
70
|
+
canvas.height = canvasSize;
|
|
71
|
+
const context = canvas.getContext("2d");
|
|
72
|
+
if (!context) {
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
context.font = `400 ${getRangeMax(particle.size.value) * 2}px ${font}`;
|
|
76
|
+
context.textBaseline = "middle";
|
|
77
|
+
context.textAlign = "center";
|
|
78
|
+
context.fillText(emoji, getRangeMax(particle.size.value), getRangeMax(particle.size.value));
|
|
79
|
+
emojiData = canvas;
|
|
58
80
|
}
|
|
59
|
-
context.font = `400 ${getRangeMax(particle.size.value) * 2}px ${font}`;
|
|
60
|
-
context.textBaseline = "middle";
|
|
61
|
-
context.textAlign = "center";
|
|
62
|
-
context.fillText(emoji, getRangeMax(particle.size.value), getRangeMax(particle.size.value));
|
|
63
|
-
const emojiData = canvas.transferToImageBitmap();
|
|
64
81
|
this._emojiShapeDict.set(key, emojiData);
|
|
65
82
|
particle.emojiData = emojiData;
|
|
66
83
|
}
|
package/cjs/EmojiDrawer.js
CHANGED
|
@@ -10,7 +10,7 @@ class EmojiDrawer {
|
|
|
10
10
|
}
|
|
11
11
|
destroy() {
|
|
12
12
|
for (const [, emojiData] of this._emojiShapeDict) {
|
|
13
|
-
emojiData?.close();
|
|
13
|
+
emojiData instanceof ImageBitmap && emojiData?.close();
|
|
14
14
|
}
|
|
15
15
|
}
|
|
16
16
|
draw(data) {
|
|
@@ -54,16 +54,33 @@ class EmojiDrawer {
|
|
|
54
54
|
particle.emojiData = existingData;
|
|
55
55
|
return;
|
|
56
56
|
}
|
|
57
|
-
const canvasSize = (0, engine_1.getRangeMax)(particle.size.value) * 2
|
|
58
|
-
|
|
59
|
-
if (
|
|
60
|
-
|
|
57
|
+
const canvasSize = (0, engine_1.getRangeMax)(particle.size.value) * 2;
|
|
58
|
+
let emojiData;
|
|
59
|
+
if (typeof OffscreenCanvas !== "undefined") {
|
|
60
|
+
const canvas = new OffscreenCanvas(canvasSize, canvasSize), context = canvas.getContext("2d");
|
|
61
|
+
if (!context) {
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
context.font = `400 ${(0, engine_1.getRangeMax)(particle.size.value) * 2}px ${font}`;
|
|
65
|
+
context.textBaseline = "middle";
|
|
66
|
+
context.textAlign = "center";
|
|
67
|
+
context.fillText(emoji, (0, engine_1.getRangeMax)(particle.size.value), (0, engine_1.getRangeMax)(particle.size.value));
|
|
68
|
+
emojiData = canvas.transferToImageBitmap();
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
const canvas = document.createElement("canvas");
|
|
72
|
+
canvas.width = canvasSize;
|
|
73
|
+
canvas.height = canvasSize;
|
|
74
|
+
const context = canvas.getContext("2d");
|
|
75
|
+
if (!context) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
context.font = `400 ${(0, engine_1.getRangeMax)(particle.size.value) * 2}px ${font}`;
|
|
79
|
+
context.textBaseline = "middle";
|
|
80
|
+
context.textAlign = "center";
|
|
81
|
+
context.fillText(emoji, (0, engine_1.getRangeMax)(particle.size.value), (0, engine_1.getRangeMax)(particle.size.value));
|
|
82
|
+
emojiData = canvas;
|
|
61
83
|
}
|
|
62
|
-
context.font = `400 ${(0, engine_1.getRangeMax)(particle.size.value) * 2}px ${font}`;
|
|
63
|
-
context.textBaseline = "middle";
|
|
64
|
-
context.textAlign = "center";
|
|
65
|
-
context.fillText(emoji, (0, engine_1.getRangeMax)(particle.size.value), (0, engine_1.getRangeMax)(particle.size.value));
|
|
66
|
-
const emojiData = canvas.transferToImageBitmap();
|
|
67
84
|
this._emojiShapeDict.set(key, emojiData);
|
|
68
85
|
particle.emojiData = emojiData;
|
|
69
86
|
}
|
package/esm/EmojiDrawer.js
CHANGED
|
@@ -7,7 +7,7 @@ export class EmojiDrawer {
|
|
|
7
7
|
}
|
|
8
8
|
destroy() {
|
|
9
9
|
for (const [, emojiData] of this._emojiShapeDict) {
|
|
10
|
-
emojiData?.close();
|
|
10
|
+
emojiData instanceof ImageBitmap && emojiData?.close();
|
|
11
11
|
}
|
|
12
12
|
}
|
|
13
13
|
draw(data) {
|
|
@@ -51,16 +51,33 @@ export class EmojiDrawer {
|
|
|
51
51
|
particle.emojiData = existingData;
|
|
52
52
|
return;
|
|
53
53
|
}
|
|
54
|
-
const canvasSize = getRangeMax(particle.size.value) * 2
|
|
55
|
-
|
|
56
|
-
if (
|
|
57
|
-
|
|
54
|
+
const canvasSize = getRangeMax(particle.size.value) * 2;
|
|
55
|
+
let emojiData;
|
|
56
|
+
if (typeof OffscreenCanvas !== "undefined") {
|
|
57
|
+
const canvas = new OffscreenCanvas(canvasSize, canvasSize), context = canvas.getContext("2d");
|
|
58
|
+
if (!context) {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
context.font = `400 ${getRangeMax(particle.size.value) * 2}px ${font}`;
|
|
62
|
+
context.textBaseline = "middle";
|
|
63
|
+
context.textAlign = "center";
|
|
64
|
+
context.fillText(emoji, getRangeMax(particle.size.value), getRangeMax(particle.size.value));
|
|
65
|
+
emojiData = canvas.transferToImageBitmap();
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
const canvas = document.createElement("canvas");
|
|
69
|
+
canvas.width = canvasSize;
|
|
70
|
+
canvas.height = canvasSize;
|
|
71
|
+
const context = canvas.getContext("2d");
|
|
72
|
+
if (!context) {
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
context.font = `400 ${getRangeMax(particle.size.value) * 2}px ${font}`;
|
|
76
|
+
context.textBaseline = "middle";
|
|
77
|
+
context.textAlign = "center";
|
|
78
|
+
context.fillText(emoji, getRangeMax(particle.size.value), getRangeMax(particle.size.value));
|
|
79
|
+
emojiData = canvas;
|
|
58
80
|
}
|
|
59
|
-
context.font = `400 ${getRangeMax(particle.size.value) * 2}px ${font}`;
|
|
60
|
-
context.textBaseline = "middle";
|
|
61
|
-
context.textAlign = "center";
|
|
62
|
-
context.fillText(emoji, getRangeMax(particle.size.value), getRangeMax(particle.size.value));
|
|
63
|
-
const emojiData = canvas.transferToImageBitmap();
|
|
64
81
|
this._emojiShapeDict.set(key, emojiData);
|
|
65
82
|
particle.emojiData = emojiData;
|
|
66
83
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tsparticles/shape-emoji",
|
|
3
|
-
"version": "3.0.
|
|
3
|
+
"version": "3.0.1",
|
|
4
4
|
"description": "tsParticles emoji shape",
|
|
5
5
|
"homepage": "https://particles.js.org",
|
|
6
6
|
"repository": {
|
|
@@ -59,7 +59,7 @@
|
|
|
59
59
|
"./package.json": "./package.json"
|
|
60
60
|
},
|
|
61
61
|
"dependencies": {
|
|
62
|
-
"@tsparticles/engine": "^3.0.
|
|
62
|
+
"@tsparticles/engine": "^3.0.1"
|
|
63
63
|
},
|
|
64
64
|
"publishConfig": {
|
|
65
65
|
"access": "public"
|
package/report.html
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
<head>
|
|
4
4
|
<meta charset="UTF-8"/>
|
|
5
5
|
<meta name="viewport" content="width=device-width, initial-scale=1"/>
|
|
6
|
-
<title>@tsparticles/shape-emoji [
|
|
6
|
+
<title>@tsparticles/shape-emoji [6 Dec 2023 at 09:41]</title>
|
|
7
7
|
<link rel="shortcut icon" href="" type="image/x-icon" />
|
|
8
8
|
|
|
9
9
|
<script>
|
|
@@ -31,7 +31,7 @@
|
|
|
31
31
|
<body>
|
|
32
32
|
<div id="app"></div>
|
|
33
33
|
<script>
|
|
34
|
-
window.chartData = [{"label":"tsparticles.shape.emoji.js","isAsset":true,"statSize":
|
|
34
|
+
window.chartData = [{"label":"tsparticles.shape.emoji.js","isAsset":true,"statSize":3420,"parsedSize":7389,"gzipSize":2283,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":3378,"groups":[{"id":335,"label":"index.js + 1 modules (concatenated)","path":"./dist/browser/index.js + 1 modules (concatenated)","statSize":3378,"parsedSize":7389,"gzipSize":2283,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser","statSize":3378,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser/index.js","statSize":189,"parsedSize":413,"gzipSize":127,"inaccurateSizes":true},{"id":null,"label":"EmojiDrawer.js","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser/EmojiDrawer.js","statSize":3189,"parsedSize":6975,"gzipSize":2155,"inaccurateSizes":true}],"parsedSize":7389,"gzipSize":2283,"inaccurateSizes":true}]}],"parsedSize":7389,"gzipSize":2283},{"label":"engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles","path":"./engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles","statSize":42,"groups":[{"id":533,"label":"engine\",\"root\":\"window\"}","path":"./engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles/engine\",\"root\":\"window\"}","statSize":42}],"parsedSize":0,"gzipSize":0}],"isInitialByEntrypoint":{"tsparticles.shape.emoji":true}}];
|
|
35
35
|
window.entrypoints = ["tsparticles.shape.emoji","tsparticles.shape.emoji.min"];
|
|
36
36
|
window.defaultSizes = "parsed";
|
|
37
37
|
</script>
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* Demo / Generator : https://particles.js.org/
|
|
5
5
|
* GitHub : https://www.github.com/matteobruni/tsparticles
|
|
6
6
|
* How to use? : Check the GitHub README
|
|
7
|
-
* v3.0.
|
|
7
|
+
* v3.0.1
|
|
8
8
|
*/
|
|
9
9
|
(function webpackUniversalModuleDefinition(root, factory) {
|
|
10
10
|
if(typeof exports === 'object' && typeof module === 'object')
|
|
@@ -106,7 +106,7 @@ class EmojiDrawer {
|
|
|
106
106
|
}
|
|
107
107
|
destroy() {
|
|
108
108
|
for (const [, emojiData] of this._emojiShapeDict) {
|
|
109
|
-
emojiData?.close();
|
|
109
|
+
emojiData instanceof ImageBitmap && emojiData?.close();
|
|
110
110
|
}
|
|
111
111
|
}
|
|
112
112
|
draw(data) {
|
|
@@ -157,17 +157,33 @@ class EmojiDrawer {
|
|
|
157
157
|
particle.emojiData = existingData;
|
|
158
158
|
return;
|
|
159
159
|
}
|
|
160
|
-
const canvasSize = (0,engine_root_window_.getRangeMax)(particle.size.value) * 2
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
160
|
+
const canvasSize = (0,engine_root_window_.getRangeMax)(particle.size.value) * 2;
|
|
161
|
+
let emojiData;
|
|
162
|
+
if (typeof OffscreenCanvas !== "undefined") {
|
|
163
|
+
const canvas = new OffscreenCanvas(canvasSize, canvasSize),
|
|
164
|
+
context = canvas.getContext("2d");
|
|
165
|
+
if (!context) {
|
|
166
|
+
return;
|
|
167
|
+
}
|
|
168
|
+
context.font = `400 ${(0,engine_root_window_.getRangeMax)(particle.size.value) * 2}px ${font}`;
|
|
169
|
+
context.textBaseline = "middle";
|
|
170
|
+
context.textAlign = "center";
|
|
171
|
+
context.fillText(emoji, (0,engine_root_window_.getRangeMax)(particle.size.value), (0,engine_root_window_.getRangeMax)(particle.size.value));
|
|
172
|
+
emojiData = canvas.transferToImageBitmap();
|
|
173
|
+
} else {
|
|
174
|
+
const canvas = document.createElement("canvas");
|
|
175
|
+
canvas.width = canvasSize;
|
|
176
|
+
canvas.height = canvasSize;
|
|
177
|
+
const context = canvas.getContext("2d");
|
|
178
|
+
if (!context) {
|
|
179
|
+
return;
|
|
180
|
+
}
|
|
181
|
+
context.font = `400 ${(0,engine_root_window_.getRangeMax)(particle.size.value) * 2}px ${font}`;
|
|
182
|
+
context.textBaseline = "middle";
|
|
183
|
+
context.textAlign = "center";
|
|
184
|
+
context.fillText(emoji, (0,engine_root_window_.getRangeMax)(particle.size.value), (0,engine_root_window_.getRangeMax)(particle.size.value));
|
|
185
|
+
emojiData = canvas;
|
|
165
186
|
}
|
|
166
|
-
context.font = `400 ${(0,engine_root_window_.getRangeMax)(particle.size.value) * 2}px ${font}`;
|
|
167
|
-
context.textBaseline = "middle";
|
|
168
|
-
context.textAlign = "center";
|
|
169
|
-
context.fillText(emoji, (0,engine_root_window_.getRangeMax)(particle.size.value), (0,engine_root_window_.getRangeMax)(particle.size.value));
|
|
170
|
-
const emojiData = canvas.transferToImageBitmap();
|
|
171
187
|
this._emojiShapeDict.set(key, emojiData);
|
|
172
188
|
particle.emojiData = emojiData;
|
|
173
189
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/*! For license information please see tsparticles.shape.emoji.min.js.LICENSE.txt */
|
|
2
|
-
!function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],t);else{var o="object"==typeof exports?t(require("@tsparticles/engine")):t(e.window);for(var a in o)("object"==typeof exports?exports:e)[a]=o[a]}}(this,(e=>(()=>{"use strict";var t={533:t=>{t.exports=e}},o={};function a(e){var i=o[e];if(void 0!==i)return i.exports;var n=o[e]={exports:{}};return t[e](n,n.exports,a),n.exports}a.d=(e,t)=>{for(var o in t)a.o(t,o)&&!a.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:t[o]})},a.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var i={};return(()=>{a.r(i),a.d(i,{loadEmojiShape:()=>r});var e=a(533);const t=["emoji"],o='"Twemoji Mozilla", Apple Color Emoji, "Segoe UI Emoji", "Noto Color Emoji", "EmojiOne Color"';class n{constructor(){this._emojiShapeDict=new Map}destroy(){for(const[,e]of this._emojiShapeDict)e?.close()}draw(e){const{context:t,particle:o,radius:a,opacity:i}=e,n=o.emojiData;n&&(t.globalAlpha=i,t.drawImage(n,-a,-a,2*a,2*a),t.globalAlpha=1)}async init(a){const i=a.actualOptions;if(t.find((t=>(0,e.isInArray)(t,i.particles.shape.type)))){const a=[(0,e.loadFont)(o)],n=t.map((e=>i.particles.shape.options[e])).find((e=>!!e));n&&(0,e.executeOnSingleOrMultiple)(n,(t=>{t.font&&a.push((0,e.loadFont)(t.font))})),await Promise.all(a)}}particleDestroy(e){delete e.emojiData}particleInit(t,a){if(!a.emojiData){const t=a.shapeData;if(!t?.value)return;const i=(0,e.itemFromSingleOrMultiple)(t.value,a.randomIndexData),n=t.font??o;if(!i)return;const r=`${i}_${n}`,s=this._emojiShapeDict.get(r);if(s)return void(a.emojiData=s);const l=2*(0,e.getRangeMax)(a.size.value)
|
|
2
|
+
!function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],t);else{var o="object"==typeof exports?t(require("@tsparticles/engine")):t(e.window);for(var a in o)("object"==typeof exports?exports:e)[a]=o[a]}}(this,(e=>(()=>{"use strict";var t={533:t=>{t.exports=e}},o={};function a(e){var i=o[e];if(void 0!==i)return i.exports;var n=o[e]={exports:{}};return t[e](n,n.exports,a),n.exports}a.d=(e,t)=>{for(var o in t)a.o(t,o)&&!a.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:t[o]})},a.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var i={};return(()=>{a.r(i),a.d(i,{loadEmojiShape:()=>r});var e=a(533);const t=["emoji"],o='"Twemoji Mozilla", Apple Color Emoji, "Segoe UI Emoji", "Noto Color Emoji", "EmojiOne Color"';class n{constructor(){this._emojiShapeDict=new Map}destroy(){for(const[,e]of this._emojiShapeDict)e instanceof ImageBitmap&&e?.close()}draw(e){const{context:t,particle:o,radius:a,opacity:i}=e,n=o.emojiData;n&&(t.globalAlpha=i,t.drawImage(n,-a,-a,2*a,2*a),t.globalAlpha=1)}async init(a){const i=a.actualOptions;if(t.find((t=>(0,e.isInArray)(t,i.particles.shape.type)))){const a=[(0,e.loadFont)(o)],n=t.map((e=>i.particles.shape.options[e])).find((e=>!!e));n&&(0,e.executeOnSingleOrMultiple)(n,(t=>{t.font&&a.push((0,e.loadFont)(t.font))})),await Promise.all(a)}}particleDestroy(e){delete e.emojiData}particleInit(t,a){if(!a.emojiData){const t=a.shapeData;if(!t?.value)return;const i=(0,e.itemFromSingleOrMultiple)(t.value,a.randomIndexData),n=t.font??o;if(!i)return;const r=`${i}_${n}`,s=this._emojiShapeDict.get(r);if(s)return void(a.emojiData=s);const l=2*(0,e.getRangeMax)(a.size.value);let p;if("undefined"!=typeof OffscreenCanvas){const t=new OffscreenCanvas(l,l),o=t.getContext("2d");if(!o)return;o.font=`400 ${2*(0,e.getRangeMax)(a.size.value)}px ${n}`,o.textBaseline="middle",o.textAlign="center",o.fillText(i,(0,e.getRangeMax)(a.size.value),(0,e.getRangeMax)(a.size.value)),p=t.transferToImageBitmap()}else{const t=document.createElement("canvas");t.width=l,t.height=l;const o=t.getContext("2d");if(!o)return;o.font=`400 ${2*(0,e.getRangeMax)(a.size.value)}px ${n}`,o.textBaseline="middle",o.textAlign="center",o.fillText(i,(0,e.getRangeMax)(a.size.value),(0,e.getRangeMax)(a.size.value)),p=t}this._emojiShapeDict.set(r,p),a.emojiData=p}}}async function r(e,o=!0){await e.addShape(t,new n,o)}})(),i})()));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
/*! tsParticles Emoji Shape v3.0.
|
|
1
|
+
/*! tsParticles Emoji Shape v3.0.1 by Matteo Bruni */
|
package/types/EmojiParticle.d.ts
CHANGED
package/umd/EmojiDrawer.js
CHANGED
|
@@ -19,7 +19,7 @@
|
|
|
19
19
|
}
|
|
20
20
|
destroy() {
|
|
21
21
|
for (const [, emojiData] of this._emojiShapeDict) {
|
|
22
|
-
emojiData?.close();
|
|
22
|
+
emojiData instanceof ImageBitmap && emojiData?.close();
|
|
23
23
|
}
|
|
24
24
|
}
|
|
25
25
|
draw(data) {
|
|
@@ -63,16 +63,33 @@
|
|
|
63
63
|
particle.emojiData = existingData;
|
|
64
64
|
return;
|
|
65
65
|
}
|
|
66
|
-
const canvasSize = (0, engine_1.getRangeMax)(particle.size.value) * 2
|
|
67
|
-
|
|
68
|
-
if (
|
|
69
|
-
|
|
66
|
+
const canvasSize = (0, engine_1.getRangeMax)(particle.size.value) * 2;
|
|
67
|
+
let emojiData;
|
|
68
|
+
if (typeof OffscreenCanvas !== "undefined") {
|
|
69
|
+
const canvas = new OffscreenCanvas(canvasSize, canvasSize), context = canvas.getContext("2d");
|
|
70
|
+
if (!context) {
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
context.font = `400 ${(0, engine_1.getRangeMax)(particle.size.value) * 2}px ${font}`;
|
|
74
|
+
context.textBaseline = "middle";
|
|
75
|
+
context.textAlign = "center";
|
|
76
|
+
context.fillText(emoji, (0, engine_1.getRangeMax)(particle.size.value), (0, engine_1.getRangeMax)(particle.size.value));
|
|
77
|
+
emojiData = canvas.transferToImageBitmap();
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
const canvas = document.createElement("canvas");
|
|
81
|
+
canvas.width = canvasSize;
|
|
82
|
+
canvas.height = canvasSize;
|
|
83
|
+
const context = canvas.getContext("2d");
|
|
84
|
+
if (!context) {
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
context.font = `400 ${(0, engine_1.getRangeMax)(particle.size.value) * 2}px ${font}`;
|
|
88
|
+
context.textBaseline = "middle";
|
|
89
|
+
context.textAlign = "center";
|
|
90
|
+
context.fillText(emoji, (0, engine_1.getRangeMax)(particle.size.value), (0, engine_1.getRangeMax)(particle.size.value));
|
|
91
|
+
emojiData = canvas;
|
|
70
92
|
}
|
|
71
|
-
context.font = `400 ${(0, engine_1.getRangeMax)(particle.size.value) * 2}px ${font}`;
|
|
72
|
-
context.textBaseline = "middle";
|
|
73
|
-
context.textAlign = "center";
|
|
74
|
-
context.fillText(emoji, (0, engine_1.getRangeMax)(particle.size.value), (0, engine_1.getRangeMax)(particle.size.value));
|
|
75
|
-
const emojiData = canvas.transferToImageBitmap();
|
|
76
93
|
this._emojiShapeDict.set(key, emojiData);
|
|
77
94
|
particle.emojiData = emojiData;
|
|
78
95
|
}
|