@tolokoban/tgd 2.0.88 → 2.0.91

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.
Files changed (132) hide show
  1. package/lib/dist/bounding-box.d.ts +1 -1
  2. package/lib/dist/bounding-box.d.ts.map +1 -1
  3. package/lib/dist/context/context.d.ts +6 -4
  4. package/lib/dist/context/context.d.ts.map +1 -1
  5. package/lib/dist/context/context.js +9 -9
  6. package/lib/dist/context/webgl-params.d.ts +51 -0
  7. package/lib/dist/context/webgl-params.d.ts.map +1 -0
  8. package/lib/dist/context/webgl-params.js +152 -0
  9. package/lib/dist/filter/blur.d.ts.map +1 -1
  10. package/lib/dist/filter/blur.js +5 -13
  11. package/lib/dist/filter/index.d.ts +1 -0
  12. package/lib/dist/filter/index.d.ts.map +1 -1
  13. package/lib/dist/filter/index.js +2 -1
  14. package/lib/dist/filter/multiply.d.ts +13 -0
  15. package/lib/dist/filter/multiply.d.ts.map +1 -0
  16. package/lib/dist/filter/multiply.js +28 -0
  17. package/lib/dist/filter/verbatim.d.ts.map +1 -1
  18. package/lib/dist/filter/verbatim.js +1 -5
  19. package/lib/dist/geometry/tubes.d.ts +19 -0
  20. package/lib/dist/geometry/tubes.d.ts.map +1 -0
  21. package/lib/dist/geometry/tubes.js +78 -0
  22. package/lib/dist/index.d.ts +1 -1
  23. package/lib/dist/index.d.ts.map +1 -1
  24. package/lib/dist/index.js +2 -2
  25. package/lib/dist/material/glass.d.ts +3 -3
  26. package/lib/dist/material/glass.d.ts.map +1 -1
  27. package/lib/dist/material/glass.js +13 -15
  28. package/lib/dist/material/global.d.ts +2 -2
  29. package/lib/dist/material/global.d.ts.map +1 -1
  30. package/lib/dist/material/global.js +5 -7
  31. package/lib/dist/material/material.d.ts +10 -2
  32. package/lib/dist/material/material.d.ts.map +1 -1
  33. package/lib/dist/material/material.js +3 -3
  34. package/lib/dist/math/vec3.d.ts +2 -1
  35. package/lib/dist/math/vec3.d.ts.map +1 -1
  36. package/lib/dist/math/vec3.js +14 -4
  37. package/lib/dist/painter/background/background.d.ts +2 -0
  38. package/lib/dist/painter/background/background.d.ts.map +1 -1
  39. package/lib/dist/painter/background/background.js +7 -7
  40. package/lib/dist/painter/background-with-depth/background-with-depth.d.ts.map +1 -1
  41. package/lib/dist/painter/background-with-depth/background-with-depth.js +10 -7
  42. package/lib/dist/painter/filter/filter.d.ts +9 -9
  43. package/lib/dist/painter/filter/filter.d.ts.map +1 -1
  44. package/lib/dist/painter/filter/filter.js +80 -89
  45. package/lib/dist/painter/framebuffer-msaa.d.ts +1 -0
  46. package/lib/dist/painter/framebuffer-msaa.d.ts.map +1 -1
  47. package/lib/dist/painter/framebuffer-msaa.js +5 -2
  48. package/lib/dist/painter/framebuffer.d.ts +16 -3
  49. package/lib/dist/painter/framebuffer.d.ts.map +1 -1
  50. package/lib/dist/painter/framebuffer.js +19 -8
  51. package/lib/dist/painter/index.d.ts +2 -1
  52. package/lib/dist/painter/index.d.ts.map +1 -1
  53. package/lib/dist/painter/index.js +3 -2
  54. package/lib/dist/painter/mesh/gltf/gltf.d.ts +6 -4
  55. package/lib/dist/painter/mesh/gltf/gltf.d.ts.map +1 -1
  56. package/lib/dist/painter/mesh/gltf/gltf.js +5 -5
  57. package/lib/dist/painter/mesh/mesh/mesh.d.ts +3 -0
  58. package/lib/dist/painter/mesh/mesh/mesh.d.ts.map +1 -1
  59. package/lib/dist/painter/mesh/mesh/mesh.js +4 -4
  60. package/lib/dist/painter/mix/index.d.ts +2 -0
  61. package/lib/dist/painter/mix/index.d.ts.map +1 -0
  62. package/lib/dist/painter/mix/index.js +2 -0
  63. package/lib/dist/painter/mix/mix.d.ts +25 -0
  64. package/lib/dist/painter/mix/mix.d.ts.map +1 -0
  65. package/lib/dist/painter/mix/mix.js +85 -0
  66. package/lib/dist/painter/segments/segments-morphing.d.ts +13 -4
  67. package/lib/dist/painter/segments/segments-morphing.d.ts.map +1 -1
  68. package/lib/dist/painter/segments/segments-morphing.js +40 -38
  69. package/lib/dist/painter/segments/segments.d.ts +15 -5
  70. package/lib/dist/painter/segments/segments.d.ts.map +1 -1
  71. package/lib/dist/painter/segments/segments.js +39 -37
  72. package/lib/dist/painter/skybox/skybox.d.ts +4 -4
  73. package/lib/dist/painter/skybox/skybox.d.ts.map +1 -1
  74. package/lib/dist/painter/skybox/skybox.js +7 -9
  75. package/lib/dist/painter/state/state.d.ts +15 -6
  76. package/lib/dist/painter/state/state.d.ts.map +1 -1
  77. package/lib/dist/painter/state/state.js +40 -27
  78. package/lib/dist/painter/tubes/capsule.d.ts +11 -0
  79. package/lib/dist/painter/tubes/capsule.d.ts.map +1 -0
  80. package/lib/dist/painter/tubes/capsule.js +109 -0
  81. package/lib/dist/painter/tubes/ellipse.d.ts +32 -0
  82. package/lib/dist/painter/tubes/ellipse.d.ts.map +1 -0
  83. package/lib/dist/painter/tubes/ellipse.js +62 -0
  84. package/lib/dist/painter/tubes/geometry.d.ts +8 -0
  85. package/lib/dist/painter/tubes/geometry.d.ts.map +1 -0
  86. package/lib/dist/painter/tubes/geometry.js +78 -0
  87. package/lib/dist/painter/tubes/index.d.ts +2 -0
  88. package/lib/dist/painter/tubes/index.d.ts.map +1 -0
  89. package/lib/dist/painter/tubes/index.js +2 -0
  90. package/lib/dist/painter/tubes/segments-morphing.d.ts +89 -0
  91. package/lib/dist/painter/tubes/segments-morphing.d.ts.map +1 -0
  92. package/lib/dist/painter/tubes/segments-morphing.js +215 -0
  93. package/lib/dist/painter/tubes/segments.d.ts +133 -0
  94. package/lib/dist/painter/tubes/segments.d.ts.map +1 -0
  95. package/lib/dist/painter/tubes/segments.js +270 -0
  96. package/lib/dist/painter/tubes/tubes.d.ts +26 -0
  97. package/lib/dist/painter/tubes/tubes.d.ts.map +1 -0
  98. package/lib/dist/painter/tubes/tubes.js +62 -0
  99. package/lib/dist/painter/tubes/types.d.ts +45 -0
  100. package/lib/dist/painter/tubes/types.d.ts.map +1 -0
  101. package/lib/dist/painter/tubes/types.js +2 -0
  102. package/lib/dist/painter/tubes/vertices.d.ts +10 -0
  103. package/lib/dist/painter/tubes/vertices.d.ts.map +1 -0
  104. package/lib/dist/painter/tubes/vertices.js +31 -0
  105. package/lib/dist/painter/x-ray/x-ray.d.ts +2 -0
  106. package/lib/dist/painter/x-ray/x-ray.d.ts.map +1 -1
  107. package/lib/dist/painter/x-ray/x-ray.js +5 -5
  108. package/lib/dist/parser/gltf/gltf.d.ts +6 -4
  109. package/lib/dist/parser/gltf/gltf.d.ts.map +1 -1
  110. package/lib/dist/parser/gltf/gltf.js +8 -12
  111. package/lib/dist/texture/texture-depth.d.ts +3 -0
  112. package/lib/dist/texture/texture-depth.d.ts.map +1 -1
  113. package/lib/dist/texture/texture-depth.js +1 -1
  114. package/lib/dist/texture/texture2d.d.ts +4 -1
  115. package/lib/dist/texture/texture2d.d.ts.map +1 -1
  116. package/lib/dist/texture/texture2d.js +10 -7
  117. package/lib/dist/types/index.d.ts +1 -1
  118. package/lib/dist/types/index.d.ts.map +1 -1
  119. package/lib/dist/types/index.js +2 -2
  120. package/lib/dist/utils/functions.d.ts +2 -0
  121. package/lib/dist/utils/functions.d.ts.map +1 -0
  122. package/lib/dist/utils/functions.js +4 -0
  123. package/lib/dist/utils/state/blend.d.ts +13 -4
  124. package/lib/dist/utils/state/blend.d.ts.map +1 -1
  125. package/lib/dist/utils/state/blend.js +21 -22
  126. package/lib/dist/utils/state/cull.d.ts +13 -4
  127. package/lib/dist/utils/state/cull.d.ts.map +1 -1
  128. package/lib/dist/utils/state/cull.js +15 -16
  129. package/lib/dist/utils/state/depth.d.ts +13 -4
  130. package/lib/dist/utils/state/depth.d.ts.map +1 -1
  131. package/lib/dist/utils/state/depth.js +19 -20
  132. package/package.json +1 -1
@@ -0,0 +1,215 @@
1
+ import { TgdMaterialFaceOrientation } from "./../../material/index.js";
2
+ import { TgdTransfo } from "./../../math/index.js";
3
+ import { TgdPainter } from "./../painter.js";
4
+ import { TgdProgram } from "./../../program/index.js";
5
+ import { TgdShaderFragment, TgdShaderVertex } from "./../../shader/index.js";
6
+ import { TgdTexture2D } from "./../../texture/index.js";
7
+ import { tgdCanvasCreatePalette } from "./../../utils/index.js";
8
+ import { TgdVertexArray } from "./../../vao/index.js";
9
+ import { makeCapsule } from "./geometry.js";
10
+ /**
11
+ * @example
12
+ * ```
13
+ * const factory = new TgdPainterSegmentsData()
14
+ * factory.add(
15
+ * [0, 0, 0, .2],
16
+ * [1, 0, 0, .1],
17
+ * )
18
+ * factory.add(
19
+ * [0, 0, 0, .2],
20
+ * [0, 1, 0, .1],
21
+ * )
22
+ * factory.add(
23
+ * [0, 0, 0, .2],
24
+ * [0, 0, 1, .1],
25
+ * )
26
+ * const segments = new TgdPainterSegments(
27
+ * segment, factory
28
+ * )
29
+ * ```
30
+ */
31
+ export class TgdPainterSegmentsMorphing extends TgdPainter {
32
+ // private readonly painter: TgdPainter
33
+ constructor(context, options) {
34
+ var _a, _b, _c, _d, _e;
35
+ super();
36
+ this.context = context;
37
+ this.transfo = new TgdTransfo();
38
+ this.minRadius = 1;
39
+ this.radiusMultiplier = 1;
40
+ this.radiusConstant = 1;
41
+ this.radiusSwitch = 0;
42
+ this.instanceCount = 0;
43
+ /**
44
+ * Mix between two datasets of a pair.
45
+ * 0.0 for the first one, 1.0 for the second one.
46
+ */
47
+ this.mix = 0;
48
+ this.name = `TgdPainterSegments#${this.id}`;
49
+ this.radiusMultiplier = (_a = options.radiusMultiplier) !== null && _a !== void 0 ? _a : 1;
50
+ const { roundness = 3, minRadius = 1, datasetsPairs } = options;
51
+ if (datasetsPairs.length === 0) {
52
+ throw new Error('[TgdPainterSegmentsMorphing] "datasetsPairs" must contain at least one pair of datasets!');
53
+ }
54
+ const geometry = makeCapsule(roundness);
55
+ const material = (_b = options.material) !== null && _b !== void 0 ? _b : new TgdMaterialFaceOrientation();
56
+ this.material = material;
57
+ material.attPosition = geometry.attPosition;
58
+ material.attNormal = geometry.attNormal;
59
+ material.attUV =
60
+ "((mix(attUV0_A, attUV0_B, uniMix) + mix(attUV1_A, attUV1_B, uniMix)) * .5)";
61
+ this.minRadius = minRadius;
62
+ if (roundness > 127) {
63
+ throw new Error("[TgdPainterSegments] Max roundness is 127!");
64
+ }
65
+ if (roundness < 0) {
66
+ throw new Error("[TgdPainterSegments] Min roundness is 0!");
67
+ }
68
+ this.colorTexture = new TgdTexture2D(context)
69
+ .setParams({
70
+ magFilter: "NEAREST",
71
+ minFilter: "NEAREST",
72
+ wrapR: "CLAMP_TO_EDGE",
73
+ wrapS: "CLAMP_TO_EDGE",
74
+ wrapT: "CLAMP_TO_EDGE",
75
+ })
76
+ .loadBitmap(tgdCanvasCreatePalette(["#f44", "#ff4", "#4f4", "#4ff", "#44f"]));
77
+ const vert = new TgdShaderVertex({
78
+ uniforms: Object.assign({ uniMix: "float", uniTransfoMatrix: "mat4", uniModelViewMatrix: "mat4", uniProjectionMatrix: "mat4", uniMinRadius: "float", uniRadiusMultiplier: "float" }, material.uniforms),
79
+ attributes: {
80
+ [geometry.attPosition]: "vec3",
81
+ [geometry.attNormal]: "vec3",
82
+ attTip: "float",
83
+ attXYZR0_A: "vec4",
84
+ attXYZR0_B: "vec4",
85
+ attXYZR1_A: "vec4",
86
+ attXYZR1_B: "vec4",
87
+ attUV0_A: "vec2",
88
+ attUV0_B: "vec2",
89
+ attUV1_A: "vec2",
90
+ attUV1_B: "vec2",
91
+ },
92
+ varying: Object.assign(Object.assign({}, material.varyings), { varNormal: "vec3" }),
93
+ functions: Object.assign(Object.assign({}, material.extraVertexShaderFunctions), { applyMaterial: [
94
+ "void applyMaterial() {",
95
+ [material.vertexShaderCode],
96
+ "}",
97
+ ], getPosition: [
98
+ "vec4 getPosition(vec4 pos) {",
99
+ [(_c = material.vertexShaderCodeForGetPosition) !== null && _c !== void 0 ? _c : "return pos;"],
100
+ "}",
101
+ ] }),
102
+ mainCode: [
103
+ "vec4 attXYZR0 = mix(attXYZR0_A, attXYZR0_B, uniMix);",
104
+ "vec4 attXYZR1 = mix(attXYZR1_A, attXYZR1_B, uniMix);",
105
+ "vec2 attUV0 = mix(attUV0_A, attUV0_B, uniMix);",
106
+ "vec2 attUV1 = mix(attUV1_A, attUV1_B, uniMix);",
107
+ "vec3 normal = NORMAL;",
108
+ "vec3 pos = POSITION;",
109
+ "vec4 xyzr = mix(attXYZR0, attXYZR1, attTip);",
110
+ "vec3 center = xyzr.xyz;",
111
+ "float radius = max(",
112
+ [
113
+ "xyzr.w * uniRadiusMultiplier,",
114
+ "uniMinRadius * (uniProjectionMatrix * uniModelViewMatrix * uniTransfoMatrix * vec4(center, 1)).w",
115
+ ],
116
+ ");",
117
+ "vec3 dir = attXYZR1.xyz - attXYZR0.xyz;",
118
+ "float len = length(dir);",
119
+ "if (len == 0.0) {",
120
+ ["// Just a sphere", "pos *= radius;", "pos += center.xyz;"],
121
+ "} else {",
122
+ [
123
+ "// Full capsule",
124
+ "vec3 Z = dir / len;",
125
+ "vec3 v = abs(Z.z) > 0.7 ? vec3(1,0,0) : vec3(0,0,1);",
126
+ "vec3 Y = cross(v, Z);",
127
+ "vec3 X = cross(Y, Z);",
128
+ "mat3 mat = mat3(X, Y, Z);",
129
+ "pos *= radius;",
130
+ "pos = mat * pos + center.xyz;",
131
+ "normal = mat * normal;",
132
+ ],
133
+ "}",
134
+ "gl_Position = uniProjectionMatrix * uniModelViewMatrix * uniTransfoMatrix * vec4(pos, 1);",
135
+ "applyMaterial();",
136
+ "varNormal = normal;",
137
+ ],
138
+ }).code;
139
+ const frag = new TgdShaderFragment({
140
+ uniforms: material.uniforms,
141
+ outputs: { FragColor: "vec4" },
142
+ varying: material.varyings,
143
+ functions: Object.assign(Object.assign({}, material.extraFragmentShaderFunctions), { applyMaterial: [
144
+ "vec4 applyMaterial() {",
145
+ [material.fragmentShaderCode],
146
+ "}",
147
+ ] }),
148
+ mainCode: ["FragColor = applyMaterial();"],
149
+ }).code;
150
+ const prg = new TgdProgram(context.gl, {
151
+ name: `TgdPainterSegments/TgdProgram#${this.id}`,
152
+ vert,
153
+ frag,
154
+ });
155
+ this.prg = prg;
156
+ this.vaos = datasetsPairs.map(([A, B]) => {
157
+ const datasetA = extract(A).renameAttributes([
158
+ "attXYZR0_A",
159
+ "attUV0_A",
160
+ "attInfluence0_A",
161
+ "attXYZR1_A",
162
+ "attUV1_A",
163
+ "attInfluence1_A",
164
+ ]);
165
+ const datasetB = extract(B).renameAttributes([
166
+ "attXYZR0_B",
167
+ "attUV0_B",
168
+ "attInfluence0_B",
169
+ "attXYZR1_B",
170
+ "attUV1_B",
171
+ "attInfluence1_B",
172
+ ]);
173
+ if (datasetA.count !== datasetB.count) {
174
+ throw new Error(`[TgdPainterSegmentsMorphing] Datasets of a pair must have the same count, but we got ${datasetA.count} ≠ ${datasetB.count}!`);
175
+ }
176
+ const vao = new TgdVertexArray(context.gl, prg, [geometry.dataset, datasetA, datasetB], geometry.elements);
177
+ this.instanceCount = datasetA.count;
178
+ return vao;
179
+ });
180
+ this.vertexCount = (_e = (_d = geometry.elements) === null || _d === void 0 ? void 0 : _d.length) !== null && _e !== void 0 ? _e : 0;
181
+ }
182
+ delete() {
183
+ for (const vao of this.vaos)
184
+ vao.delete();
185
+ this.prg.delete();
186
+ }
187
+ paint(time, delay) {
188
+ var _a, _b;
189
+ const { context, prg, vao, vertexCount, instanceCount, material } = this;
190
+ const { gl, camera } = context;
191
+ gl.disable(gl.DITHER);
192
+ prg.use();
193
+ (_b = (_a = this.material).setUniforms) === null || _b === void 0 ? void 0 : _b.call(_a, { program: prg, context, time, delay });
194
+ prg.uniform1f("uniMix", this.mix);
195
+ prg.uniform1f("uniRadiusMultiplier", this.radiusMultiplier);
196
+ prg.uniform1f("uniMinRadius", (this.minRadius * 2) / gl.drawingBufferHeight);
197
+ prg.uniformMatrix4fv("uniTransfoMatrix", this.transfo.matrix);
198
+ prg.uniformMatrix4fv("uniModelViewMatrix", camera.matrixModelView);
199
+ prg.uniformMatrix4fv("uniProjectionMatrix", camera.matrixProjection);
200
+ material.applyState(this.context, () => {
201
+ vao.bind();
202
+ gl.drawElementsInstanced(gl.TRIANGLES, vertexCount, gl.UNSIGNED_SHORT, 0, instanceCount);
203
+ vao.unbind();
204
+ });
205
+ }
206
+ get vao() {
207
+ return this.vaos[0];
208
+ }
209
+ }
210
+ function extract(arg) {
211
+ if (typeof arg === "function")
212
+ return arg();
213
+ return arg;
214
+ }
215
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VnbWVudHMtbW9ycGhpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGFpbnRlci90dWJlcy9zZWdtZW50cy1tb3JwaGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxPQUFPLEVBQW9CLDBCQUEwQixFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQzVFLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxXQUFXLENBQUE7QUFDdEMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFBO0FBQ2pELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxjQUFjLENBQUE7QUFDekMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLGVBQWUsRUFBRSxNQUFNLGFBQWEsQ0FBQTtBQUNoRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sY0FBYyxDQUFBO0FBQzNDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLFlBQVksQ0FBQTtBQUNuRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sVUFBVSxDQUFBO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxZQUFZLENBQUE7QUFnQ3hDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CRztBQUNILE1BQU0sT0FBTywwQkFBMkIsU0FBUSxVQUFVO0lBbUJ0RCx1Q0FBdUM7SUFFdkMsWUFDdUIsT0FJbEIsRUFDRCxPQUEwQzs7UUFFMUMsS0FBSyxFQUFFLENBQUE7UUFQWSxZQUFPLEdBQVAsT0FBTyxDQUl6QjtRQXpCVyxZQUFPLEdBQUcsSUFBSSxVQUFVLEVBQUUsQ0FBQTtRQUVuQyxjQUFTLEdBQUcsQ0FBQyxDQUFBO1FBQ2IscUJBQWdCLEdBQUcsQ0FBQyxDQUFBO1FBQ3BCLG1CQUFjLEdBQUcsQ0FBQyxDQUFBO1FBQ2xCLGlCQUFZLEdBQUcsQ0FBQyxDQUFBO1FBQ2hCLGtCQUFhLEdBQUcsQ0FBQyxDQUFBO1FBQ3hCOzs7V0FHRztRQUNJLFFBQUcsR0FBRyxDQUFDLENBQUE7UUFrQlYs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
@@ -0,0 +1,133 @@
1
+ import type { TgdBuffer, TgdBufferOptionTarget, TgdBufferOptionUsage } from "../../buffer";
2
+ import type { TgdCamera } from "../../camera";
3
+ import type { WebglParams } from "../../context/webgl-params";
4
+ import { TgdDataset } from "../../dataset";
5
+ import { type TgdMaterial } from "../../material";
6
+ import { TgdTransfo } from "../../math";
7
+ import { TgdPainter } from "../painter";
8
+ import type { ArrayNumber2, ArrayNumber4 } from "../../types";
9
+ type DatasetOption = TgdPainterSegments | InstanceDataset | (() => InstanceDataset);
10
+ export type TgdPainterSegmentsOptions = {
11
+ /**
12
+ * Number of faces around the cylinder.
13
+ * Min is 3.
14
+ *
15
+ * Default to **3**.
16
+ */
17
+ roundness?: number;
18
+ /**
19
+ * With orthographic camera, this is a value in pixels.
20
+ */
21
+ minRadius?: number;
22
+ /**
23
+ * Multiply all the radii by this value.
24
+ *
25
+ * Default to `1`.
26
+ */
27
+ radiusMultiplier?: number;
28
+ /**
29
+ * Material to apply to the resulting mesh.
30
+ */
31
+ material?: TgdMaterial;
32
+ /**
33
+ * If a `TgdPainterSegments` is given, then the
34
+ * data will be shared between the painters.
35
+ */
36
+ dataset: DatasetOption;
37
+ };
38
+ /**
39
+ * @example
40
+ * ```
41
+ * const factory = new TgdPainterSegmentsData()
42
+ * factory.add(
43
+ * [0, 0, 0, .2],
44
+ * [1, 0, 0, .1],
45
+ * )
46
+ * factory.add(
47
+ * [0, 0, 0, .2],
48
+ * [0, 1, 0, .1],
49
+ * )
50
+ * factory.add(
51
+ * [0, 0, 0, .2],
52
+ * [0, 0, 1, .1],
53
+ * )
54
+ * const segments = new TgdPainterSegments(
55
+ * segment, factory
56
+ * )
57
+ * ```
58
+ */
59
+ export declare class TgdPainterSegments extends TgdPainter {
60
+ protected readonly context: {
61
+ gl: WebGL2RenderingContext;
62
+ webglParams: WebglParams;
63
+ camera: TgdCamera;
64
+ };
65
+ static createDataset({ attXYZR0, attUV0, attInfluence0, attXYZR1, attUV1, attInfluence1, buffer, usage, target, }?: Partial<{
66
+ attXYZR0: string;
67
+ attUV0: string;
68
+ attInfluence0: string;
69
+ attXYZR1: string;
70
+ attUV1: string;
71
+ attInfluence1: string;
72
+ buffer: TgdBuffer;
73
+ target: TgdBufferOptionTarget;
74
+ usage: TgdBufferOptionUsage;
75
+ }>): TgdDataset;
76
+ readonly transfo: TgdTransfo;
77
+ minRadius: number;
78
+ radiusMultiplier: number;
79
+ radiusConstant: number;
80
+ radiusSwitch: number;
81
+ instanceCount: number;
82
+ private readonly vao;
83
+ private readonly prg;
84
+ private readonly vertexCount;
85
+ private readonly material;
86
+ constructor(context: {
87
+ gl: WebGL2RenderingContext;
88
+ webglParams: WebglParams;
89
+ camera: TgdCamera;
90
+ }, options: TgdPainterSegmentsOptions);
91
+ getBuffer(): TgdBuffer | undefined;
92
+ delete(): void;
93
+ paint(time: number, delay: number): void;
94
+ }
95
+ type InstanceDataset = TgdDataset;
96
+ export declare class TgdPainterSegmentsData {
97
+ private _count;
98
+ private readonly attXYZR0;
99
+ private readonly attUV0;
100
+ private readonly attInfluence0;
101
+ private readonly attXYZR1;
102
+ private readonly attUV1;
103
+ private readonly attInfluence1;
104
+ get count(): number;
105
+ getXYZR0(index: number): ArrayNumber4;
106
+ getXYZR1(index: number): ArrayNumber4;
107
+ /**
108
+ * @param XYZR0 (x,y,z) and radius of point A.
109
+ * @param XYZR1 (x,y,z) and radius of point B.
110
+ * @param UV0 Texture coordinates for point A.
111
+ * @param UV1 Texture coordinates for point B.
112
+ * @param radiusMultiplierInfluence0 If you put 0, the radius won't change regardless to the currently applied radius multiplicator.
113
+ * @param radiusMultiplierInfluence1
114
+ */
115
+ add(XYZR0: ArrayNumber4, XYZR1: ArrayNumber4, UV0?: ArrayNumber2, UV1?: ArrayNumber2, radiusMultiplierInfluence0?: number, radiusMultiplierInfluence1?: number): void;
116
+ /**
117
+ * You can rename the attributes if you need to use
118
+ * them in another Painter.
119
+ */
120
+ readonly makeDataset: (args?: Partial<{
121
+ attXYZR0: string;
122
+ attUV0: string;
123
+ attInfluence0: string;
124
+ attXYZR1: string;
125
+ attUV1: string;
126
+ attInfluence1: string;
127
+ buffer: TgdBuffer;
128
+ target: TgdBufferOptionTarget;
129
+ usage: TgdBufferOptionUsage;
130
+ }>) => InstanceDataset;
131
+ }
132
+ export {};
133
+ //# sourceMappingURL=segments.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"segments.d.ts","sourceRoot":"","sources":["../../../src/painter/tubes/segments.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,270 @@
1
+ import { TgdDataset } from "./../../dataset/index.js";
2
+ import { TgdMaterialFaceOrientation } from "./../../material/index.js";
3
+ import { TgdTransfo } from "./../../math/index.js";
4
+ import { TgdPainter } from "./../painter.js";
5
+ import { TgdProgram } from "./../../program/index.js";
6
+ import { TgdShaderFragment, TgdShaderVertex } from "./../../shader/index.js";
7
+ import { TgdVertexArray } from "./../../vao/index.js";
8
+ import { makeCapsule } from "./capsule.js";
9
+ /**
10
+ * @example
11
+ * ```
12
+ * const factory = new TgdPainterSegmentsData()
13
+ * factory.add(
14
+ * [0, 0, 0, .2],
15
+ * [1, 0, 0, .1],
16
+ * )
17
+ * factory.add(
18
+ * [0, 0, 0, .2],
19
+ * [0, 1, 0, .1],
20
+ * )
21
+ * factory.add(
22
+ * [0, 0, 0, .2],
23
+ * [0, 0, 1, .1],
24
+ * )
25
+ * const segments = new TgdPainterSegments(
26
+ * segment, factory
27
+ * )
28
+ * ```
29
+ */
30
+ export class TgdPainterSegments extends TgdPainter {
31
+ static createDataset({ attXYZR0 = "attXYZR0", attUV0 = "attUV0", attInfluence0 = "attInfluence0", attXYZR1 = "attXYZR1", attUV1 = "attUV1", attInfluence1 = "attInfluence1", buffer, usage, target, } = {}) {
32
+ const dataset = new TgdDataset({
33
+ [attXYZR0]: "vec4",
34
+ [attUV0]: "vec2",
35
+ [attInfluence0]: "float",
36
+ [attXYZR1]: "vec4",
37
+ [attUV1]: "vec2",
38
+ [attInfluence1]: "float",
39
+ }, {
40
+ divisor: 1,
41
+ buffer,
42
+ usage,
43
+ target,
44
+ });
45
+ return dataset;
46
+ }
47
+ constructor(context, options) {
48
+ var _a, _b, _c, _d, _e;
49
+ super();
50
+ this.context = context;
51
+ this.transfo = new TgdTransfo();
52
+ this.minRadius = 1;
53
+ this.radiusMultiplier = 1;
54
+ this.radiusConstant = 1;
55
+ this.radiusSwitch = 0;
56
+ this.instanceCount = 0;
57
+ this.name = `TgdPainterSegments#${this.id}`;
58
+ this.radiusMultiplier = (_a = options.radiusMultiplier) !== null && _a !== void 0 ? _a : 1;
59
+ const { roundness = 3, minRadius = 1, dataset } = options;
60
+ const geometry = makeCapsule(roundness);
61
+ const material = (_b = options.material) !== null && _b !== void 0 ? _b : new TgdMaterialFaceOrientation();
62
+ this.material = material;
63
+ material.attPosition = geometry.attPosition;
64
+ material.attNormal = geometry.attNormal;
65
+ material.attUV = "((attUV0 + attUV1) * .5)";
66
+ this.minRadius = minRadius;
67
+ if (roundness > 127) {
68
+ throw new Error("[TgdPainterSegments] Max roundness is 127!");
69
+ }
70
+ if (roundness < 0) {
71
+ throw new Error("[TgdPainterSegments] Min roundness is 0!");
72
+ }
73
+ const vert = new TgdShaderVertex({
74
+ uniforms: Object.assign({ uniTransfoMatrix: "mat4", uniModelViewMatrix: "mat4", uniProjectionMatrix: "mat4", uniMinRadius: "float", uniRadiusMultiplier: "float" }, material.uniforms),
75
+ attributes: {
76
+ [geometry.attPosition]: "vec3",
77
+ [geometry.attNormal]: "vec3",
78
+ attTip: "float",
79
+ attXYZR0: "vec4",
80
+ attXYZR1: "vec4",
81
+ attUV0: "vec2",
82
+ attUV1: "vec2",
83
+ },
84
+ varying: Object.assign(Object.assign({}, material.varyings), { varNormal: "vec3" }),
85
+ functions: Object.assign(Object.assign({}, material.extraVertexShaderFunctions), { applyMaterial: [
86
+ "void applyMaterial() {",
87
+ [material.vertexShaderCode],
88
+ "}",
89
+ ], getPosition: [
90
+ "vec4 getPosition(vec4 pos) {",
91
+ [(_c = material.vertexShaderCodeForGetPosition) !== null && _c !== void 0 ? _c : "return pos;"],
92
+ "}",
93
+ ] }),
94
+ mainCode: [
95
+ "vec3 normal = NORMAL;",
96
+ "vec3 pos = POSITION;",
97
+ "vec4 xyzr = mix(attXYZR0, attXYZR1, attTip);",
98
+ "vec3 center = xyzr.xyz;",
99
+ "float radius = max(",
100
+ [
101
+ "xyzr.w * uniRadiusMultiplier,",
102
+ "uniMinRadius * (uniProjectionMatrix * uniModelViewMatrix * uniTransfoMatrix * vec4(center, 1)).w",
103
+ ],
104
+ ");",
105
+ "vec3 dir = attXYZR1.xyz - attXYZR0.xyz;",
106
+ "float len = length(dir);",
107
+ "if (len == 0.0) {",
108
+ ["// Just a sphere", "pos *= radius;", "pos += center.xyz;"],
109
+ "} else {",
110
+ [
111
+ "// Full capsule",
112
+ "vec3 Z = dir / len;",
113
+ "vec3 v = abs(Z.z) > 0.7 ? vec3(1,0,0) : vec3(0,0,1);",
114
+ "vec3 Y = cross(v, Z);",
115
+ "vec3 X = cross(Y, Z);",
116
+ "mat3 mat = mat3(X, Y, Z);",
117
+ "pos *= radius;",
118
+ "pos = mat * pos + center.xyz;",
119
+ "normal = mat * normal;",
120
+ ],
121
+ "}",
122
+ "gl_Position = uniProjectionMatrix * uniModelViewMatrix * uniTransfoMatrix * vec4(pos, 1);",
123
+ "applyMaterial();",
124
+ "varNormal = normal;",
125
+ ],
126
+ }).code;
127
+ const frag = new TgdShaderFragment({
128
+ uniforms: material.uniforms,
129
+ outputs: { FragColor: "vec4" },
130
+ varying: material.varyings,
131
+ functions: Object.assign(Object.assign({}, material.extraFragmentShaderFunctions), { applyMaterial: [
132
+ "vec4 applyMaterial() {",
133
+ [material.fragmentShaderCode],
134
+ "}",
135
+ ] }),
136
+ mainCode: ["FragColor = applyMaterial();"],
137
+ }).code;
138
+ const prg = new TgdProgram(context.gl, {
139
+ name: `TgdPainterSegments/TgdProgram#${this.id}`,
140
+ vert,
141
+ frag,
142
+ });
143
+ this.prg = prg;
144
+ if (dataset instanceof TgdPainterSegments) {
145
+ if (dataset.vao.gl !== context.gl) {
146
+ throw new Error("[TgdPainterSegments] You cannot share a VAO accross different contexts!");
147
+ }
148
+ this.vao = dataset.vao;
149
+ this.vao.share();
150
+ this.instanceCount = dataset.instanceCount;
151
+ }
152
+ else if (dataset) {
153
+ const instance = extract(dataset);
154
+ instance.addAttributes({
155
+ attXYZR0: "vec4",
156
+ attUV0: "vec2",
157
+ attInfluence0: "float",
158
+ attXYZR1: "vec4",
159
+ attUV1: "vec2",
160
+ attInfluence1: "float",
161
+ });
162
+ this.vao = new TgdVertexArray(context.gl, prg, [geometry.dataset, instance], geometry.elements);
163
+ this.instanceCount = instance.count;
164
+ }
165
+ else {
166
+ console.error("[TgdPainterSegments] options =", options); // @FIXME: Remove this line written on 2026-02-04 at 19:53
167
+ throw new Error("option `dataset` of TgdPainterSegments is undefined!");
168
+ }
169
+ this.vertexCount = (_e = (_d = geometry.elements) === null || _d === void 0 ? void 0 : _d.length) !== null && _e !== void 0 ? _e : 0;
170
+ }
171
+ getBuffer() {
172
+ return this.vao.getBuffer(1);
173
+ }
174
+ delete() {
175
+ this.vao.delete();
176
+ this.prg.delete();
177
+ }
178
+ paint(time, delay) {
179
+ var _a, _b;
180
+ const { context, prg, vao, vertexCount, instanceCount, material } = this;
181
+ const { gl, camera } = context;
182
+ gl.disable(gl.DITHER);
183
+ prg.use();
184
+ (_b = (_a = this.material).setUniforms) === null || _b === void 0 ? void 0 : _b.call(_a, { program: prg, context, time, delay });
185
+ prg.uniform1f("uniMinRadius", (this.minRadius * 2) / gl.drawingBufferHeight);
186
+ prg.uniform1f("uniRadiusMultiplier", this.radiusMultiplier);
187
+ prg.uniformMatrix4fv("uniTransfoMatrix", this.transfo.matrix);
188
+ prg.uniformMatrix4fv("uniModelViewMatrix", camera.matrixModelView);
189
+ prg.uniformMatrix4fv("uniProjectionMatrix", camera.matrixProjection);
190
+ material.applyState(this.context, () => {
191
+ vao.bind();
192
+ gl.drawElementsInstanced(gl.TRIANGLES, vertexCount, gl.UNSIGNED_SHORT, 0, instanceCount);
193
+ vao.unbind();
194
+ });
195
+ }
196
+ }
197
+ export class TgdPainterSegmentsData {
198
+ constructor() {
199
+ this._count = 0;
200
+ this.attXYZR0 = [];
201
+ this.attUV0 = [];
202
+ this.attInfluence0 = [];
203
+ this.attXYZR1 = [];
204
+ this.attUV1 = [];
205
+ this.attInfluence1 = [];
206
+ /**
207
+ * You can rename the attributes if you need to use
208
+ * them in another Painter.
209
+ */
210
+ this.makeDataset = (args = {}) => {
211
+ const dataset = TgdPainterSegments.createDataset(args);
212
+ const { attXYZR0 = "attXYZR0", attUV0 = "attUV0", attInfluence0 = "attInfluence0", attXYZR1 = "attXYZR1", attUV1 = "attUV1", attInfluence1 = "attInfluence1", } = args;
213
+ dataset.set(attXYZR0, new Float32Array(this.attXYZR0));
214
+ dataset.set(attUV0, new Float32Array(this.attUV0));
215
+ dataset.set(attInfluence0, new Float32Array(this.attInfluence0));
216
+ dataset.set(attXYZR1, new Float32Array(this.attXYZR1));
217
+ dataset.set(attUV1, new Float32Array(this.attUV1));
218
+ dataset.set(attInfluence1, new Float32Array(this.attInfluence1));
219
+ return dataset;
220
+ };
221
+ }
222
+ get count() {
223
+ return this._count;
224
+ }
225
+ getXYZR0(index) {
226
+ var _a, _b, _c, _d;
227
+ const arr = this.attXYZR0;
228
+ const offset = index * 4;
229
+ return [
230
+ (_a = arr[offset + 0]) !== null && _a !== void 0 ? _a : 0,
231
+ (_b = arr[offset + 1]) !== null && _b !== void 0 ? _b : 0,
232
+ (_c = arr[offset + 2]) !== null && _c !== void 0 ? _c : 0,
233
+ (_d = arr[offset + 3]) !== null && _d !== void 0 ? _d : 0,
234
+ ];
235
+ }
236
+ getXYZR1(index) {
237
+ var _a, _b, _c, _d;
238
+ const arr = this.attXYZR1;
239
+ const offset = index * 4;
240
+ return [
241
+ (_a = arr[offset + 0]) !== null && _a !== void 0 ? _a : 0,
242
+ (_b = arr[offset + 1]) !== null && _b !== void 0 ? _b : 0,
243
+ (_c = arr[offset + 2]) !== null && _c !== void 0 ? _c : 0,
244
+ (_d = arr[offset + 3]) !== null && _d !== void 0 ? _d : 0,
245
+ ];
246
+ }
247
+ /**
248
+ * @param XYZR0 (x,y,z) and radius of point A.
249
+ * @param XYZR1 (x,y,z) and radius of point B.
250
+ * @param UV0 Texture coordinates for point A.
251
+ * @param UV1 Texture coordinates for point B.
252
+ * @param radiusMultiplierInfluence0 If you put 0, the radius won't change regardless to the currently applied radius multiplicator.
253
+ * @param radiusMultiplierInfluence1
254
+ */
255
+ add(XYZR0, XYZR1, UV0 = [0, 0], UV1 = [0, 0], radiusMultiplierInfluence0 = 1, radiusMultiplierInfluence1 = 1) {
256
+ this.attXYZR0.push(...XYZR0);
257
+ this.attUV0.push(...UV0);
258
+ this.attInfluence0.push(radiusMultiplierInfluence0);
259
+ this.attXYZR1.push(...XYZR1);
260
+ this.attUV1.push(...UV1);
261
+ this.attInfluence1.push(radiusMultiplierInfluence1);
262
+ this._count++;
263
+ }
264
+ }
265
+ function extract(arg) {
266
+ if (typeof arg === "function")
267
+ return arg();
268
+ return arg;
269
+ }
270
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VnbWVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGFpbnRlci90dWJlcy9zZWdtZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sY0FBYyxDQUFBO0FBQ3pDLE9BQU8sRUFBb0IsMEJBQTBCLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDNUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLFdBQVcsQ0FBQTtBQUN0QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUE7QUFDakQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGNBQWMsQ0FBQTtBQUN6QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsZUFBZSxFQUFFLE1BQU0sYUFBYSxDQUFBO0FBRWhFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxVQUFVLENBQUE7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLFdBQVcsQ0FBQTtBQW9DdkM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0JHO0FBQ0gsTUFBTSxPQUFPLGtCQUFtQixTQUFRLFVBQVU7SUFDakQsTUFBTSxDQUFDLGFBQWEsQ0FBQyxFQUNwQixRQUFRLEdBQUcsVUFBVSxFQUNyQixNQUFNLEdBQUcsUUFBUSxFQUNqQixhQUFhLEdBQUcsZUFBZSxFQUMvQixRQUFRLEdBQUcsVUFBVSxFQUNyQixNQUFNLEdBQUcsUUFBUSxFQUNqQixhQUFhLEdBQUcsZUFBZSxFQUMvQixNQUFNLEVBQ04sS0FBSyxFQUNMLE1BQU0sTUFXRixFQUFFO1FBQ04sTUFBTSxPQUFPLEdBQUcsSUFBSSxVQUFVLENBQzdCO1lBQ0MsQ0FBQyxRQUFRLENBQUMsRUFBRSxNQUFNO1lBQ2xCLENBQUMsTUFBTSxDQUFDLEVBQUUsTUFBTTtZQUNoQixDQUFDLGFBQWEsQ0FBQyxFQUFFLE9BQU87WUFDeEIsQ0FBQyxRQUFRLENBQUMsRUFBRSxNQUFNO1lBQ2xCLENBQUMsTUFB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