@pirireis/webglobeplugins 0.9.11 → 0.9.12
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/Math/angle-calculation.js +8 -8
- package/Math/arc.js +18 -18
- package/Math/bounds/line-bbox.js +78 -80
- package/Math/constants.js +3 -3
- package/Math/juction/arc-plane.js +23 -23
- package/Math/juction/line-sphere.js +11 -11
- package/Math/juction/plane-plane.js +11 -11
- package/Math/line.js +14 -16
- package/Math/methods.js +65 -70
- package/Math/plane.js +16 -18
- package/Math/quaternion.js +45 -49
- package/Math/utils.js +2 -2
- package/Math/vec3.js +42 -45
- package/algorithms/search-binary.js +4 -4
- package/altitude-locator/draw-subset-obj.js +7 -8
- package/altitude-locator/plugin.js +98 -114
- package/arrowfield/adaptor.js +3 -4
- package/arrowfield/index.js +2 -2
- package/arrowfield/plugin.js +62 -65
- package/bearing-line/index.js +1 -1
- package/bearing-line/plugin.js +200 -226
- package/circle-line-chain/chain-list-map.js +82 -88
- package/circle-line-chain/plugin.js +134 -165
- package/circle-line-chain/util.js +1 -1
- package/compass-rose/compass-rose-padding-flat.js +108 -133
- package/compass-rose/compass-text-writer.js +62 -70
- package/compass-rose/index.js +2 -2
- package/compassrose/compassrose.js +46 -50
- package/compassrose/index.js +1 -1
- package/heatwave/index.js +2 -2
- package/heatwave/isobar/objectarraylabels.js +44 -48
- package/heatwave/isobar/plugin.js +104 -123
- package/heatwave/isobar/quadtreecontours.js +76 -92
- package/heatwave/plugins/heatwaveglobeshell.js +69 -87
- package/index.js +11 -11
- package/package.json +1 -1
- package/partialrings/buffer-manager.js +32 -64
- package/partialrings/index.js +1 -1
- package/partialrings/plugin.js +48 -84
- package/partialrings/program.js +136 -47
- package/pin/pin-object-array.js +83 -86
- package/pin/pin-point-totem.js +21 -22
- package/point-heat-map/adaptors/timetracksplugin-format-to-this.js +10 -10
- package/point-heat-map/plugin-webworker.js +40 -45
- package/point-heat-map/point-to-heat-map-flow.js +40 -42
- package/point-tracks/key-methods.js +1 -1
- package/point-tracks/plugin.js +137 -162
- package/programs/arrowfield/index.js +1 -1
- package/programs/arrowfield/logic.js +170 -62
- package/programs/arrowfield/object.js +33 -35
- package/programs/data2legend/density-to-legend.js +45 -21
- package/programs/data2legend/point-to-density-texture.js +52 -27
- package/programs/float2legendwithratio/index.js +1 -1
- package/programs/float2legendwithratio/logic.js +88 -42
- package/programs/float2legendwithratio/object.js +43 -46
- package/programs/globe-util/is-globe-moved.js +10 -11
- package/programs/globeshell/index.js +1 -1
- package/programs/globeshell/wiggle/index.js +1 -1
- package/programs/globeshell/wiggle/logic.js +191 -98
- package/programs/globeshell/wiggle/object.js +33 -35
- package/programs/helpers/blender/program.js +36 -19
- package/programs/helpers/fadeaway/index.js +1 -1
- package/programs/helpers/fadeaway/logic.js +35 -13
- package/programs/helpers/fadeaway/object.js +9 -10
- package/programs/helpers/index.js +1 -1
- package/programs/index.js +8 -8
- package/programs/line-on-globe/angled-line.js +91 -32
- package/programs/line-on-globe/circle-accurate-3d.js +82 -32
- package/programs/line-on-globe/circle-accurate-flat.js +108 -50
- package/programs/line-on-globe/circle-accurate.js +103 -33
- package/programs/line-on-globe/circle.js +97 -32
- package/programs/line-on-globe/degree-padding-around-circle-3d.js +83 -33
- package/programs/line-on-globe/lines-color-instanced-flat.js +79 -34
- package/programs/line-on-globe/linestrip.js +111 -45
- package/programs/line-on-globe/naive-accurate-flexible.js +120 -50
- package/programs/line-on-globe/to-the-surface.js +58 -29
- package/programs/line-on-globe/util.js +1 -1
- package/programs/picking/pickable-renderer.js +117 -33
- package/programs/point-on-globe/element-globe-surface-glow.js +78 -38
- package/programs/point-on-globe/element-point-glow.js +103 -35
- package/programs/point-on-globe/square-pixel-point.js +76 -27
- package/programs/programcache.js +13 -13
- package/programs/rings/distancering/circleflatprogram.js +63 -21
- package/programs/rings/distancering/circlepaddingfreeangleprogram.js +156 -145
- package/programs/rings/distancering/circlepaddysharedbuffer.js +121 -197
- package/programs/rings/distancering/index.js +4 -4
- package/programs/rings/distancering/paddyflatprogram.js +73 -20
- package/programs/rings/distancering/paddyflatprogram2d.js +75 -22
- package/programs/rings/distancering/paddyflatprogram3d.js +73 -20
- package/programs/rings/partial-ring/piece-of-pie.js +137 -35
- package/programs/totems/camerauniformblock.js +64 -51
- package/programs/totems/canvas-webglobe-info.js +48 -40
- package/programs/totems/gpu-selection-uniform-block.js +44 -40
- package/programs/totems/index.js +1 -1
- package/programs/two-d/pixel-padding-for-compass.js +90 -29
- package/programs/util.js +6 -7
- package/programs/vectorfields/index.js +1 -1
- package/programs/vectorfields/logics/drawrectangleparticles.js +70 -29
- package/programs/vectorfields/logics/index.js +3 -3
- package/programs/vectorfields/logics/pixelbased.js +91 -35
- package/programs/vectorfields/logics/ubo.js +31 -25
- package/programs/vectorfields/pingpongbuffermanager.js +30 -34
- package/rangerings/index.js +4 -4
- package/rangerings/plugin.js +202 -258
- package/rangerings/rangeringangletext.js +108 -120
- package/rangerings/ring-account.js +52 -69
- package/shaders/fragment-toy/firework.js +55 -1
- package/shaders/fragment-toy/singularity.js +55 -1
- package/timetracks/adaptors-line-strip.js +26 -37
- package/timetracks/adaptors.js +47 -61
- package/timetracks/index.js +4 -4
- package/timetracks/plugin-line-strip.js +63 -71
- package/timetracks/plugin.js +69 -77
- package/timetracks/program-line-strip.js +296 -103
- package/timetracks/program.js +419 -113
- package/timetracks/programpoint-line-strip.js +97 -44
- package/timetracks/programpoint.js +90 -44
- package/util/account/bufferoffsetmanager.js +72 -95
- package/util/account/index.js +1 -1
- package/util/account/single-attribute-buffer-management/buffer-manager.js +44 -44
- package/util/account/single-attribute-buffer-management/buffer-orchestrator.js +68 -94
- package/util/account/single-attribute-buffer-management/index.js +3 -3
- package/util/account/single-attribute-buffer-management/object-store.js +29 -30
- package/util/account/util.js +2 -4
- package/util/algorithms/search-binary.js +4 -4
- package/util/check/get.js +5 -5
- package/util/check/typecheck.js +13 -15
- package/util/geometry/index.js +9 -11
- package/util/gl-util/buffer/attribute-loader.js +8 -20
- package/util/gl-util/buffer/index.js +1 -1
- package/util/gl-util/draw-options/methods.js +8 -9
- package/util/gl-util/uniform-block/manager.js +67 -67
- package/util/heatwavedatamanager/datamanager.js +56 -116
- package/util/heatwavedatamanager/index.js +2 -2
- package/util/heatwavedatamanager/pointcoordinatesdatacalculator.js +37 -40
- package/util/heatwavedatamanager/pointcoordsmeta.js +9 -10
- package/util/index.js +6 -6
- package/util/interpolation/timetrack/index.js +1 -1
- package/util/interpolation/timetrack/timetrack-interpolator.js +27 -29
- package/util/interpolation/timetrack/web-worker-str.js +179 -1
- package/util/interpolation/timetrack/web-worker.js +4 -4
- package/util/jshelpers/data-filler.js +7 -7
- package/util/jshelpers/timefilters.js +7 -7
- package/util/picking/fence.js +7 -7
- package/util/picking/picker-displayer.js +46 -52
- package/util/programs/draw-texture-on-canvas.js +39 -21
- package/util/programs/shapesonglobe.js +104 -64
- package/util/programs/supersampletotextures.js +45 -39
- package/util/programs/texturetoglobe.js +98 -48
- package/util/shaderfunctions/geometrytransformations.js +322 -27
- package/util/shaderfunctions/nodata.js +7 -1
- package/util/shaderfunctions/noisefunctions.js +39 -9
- package/util/surface-line-data/arcs-to-cuts.js +20 -23
- package/util/webglobe/rasteroverlay.js +35 -37
- package/util/webglobjectbuilders.js +55 -60
- package/util/webglobjectbuilders1.js +48 -49
- package/waveparticles/adaptor.js +6 -7
- package/waveparticles/index.js +2 -2
- package/waveparticles/plugin.js +79 -84
- package/wind/imagetovectorfieldandmagnitude.js +15 -15
- package/wind/index.js +4 -4
- package/wind/plugin.js +453 -251
- package/wind/vectorfieldimage.js +5 -5
- package/write-text/attached-text-writer.js +46 -48
- package/write-text/context-text.js +51 -58
- package/write-text/context-text3.js +69 -74
|
@@ -1,11 +1,65 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
3
|
+
const util_1 = require("../util");
|
|
4
|
+
const programs_1 = require("../programs");
|
|
5
|
+
const vertexShader = `#version 300 es
|
|
6
|
+
|
|
7
|
+
layout(std140) uniform GlobeCamera {
|
|
8
|
+
mat4 view; // 64 bytes 0
|
|
9
|
+
mat4 projection; // 64 bytes 64
|
|
10
|
+
vec3 translate; // 12 bytes 128
|
|
11
|
+
bool is3D; // 4 bytes 140
|
|
12
|
+
vec2 mapWH; // 8 bytes 144
|
|
13
|
+
vec2 screenWH; // 8 bytes 152
|
|
14
|
+
float z_level; // 4 bytes 160
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
layout(std140) uniform Globals {
|
|
18
|
+
float head_time;
|
|
19
|
+
float final_opacity;
|
|
20
|
+
float point_size;
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
in vec3 start_position;
|
|
24
|
+
in float start_time;
|
|
25
|
+
in vec3 start_color;
|
|
26
|
+
in vec3 end_position;
|
|
27
|
+
in float end_time;
|
|
28
|
+
in vec3 end_color;
|
|
29
|
+
out vec4 v_color;
|
|
30
|
+
|
|
31
|
+
` + util_1.shaderfunctions.pixelXYToCartesian3DPoint + util_1.shaderfunctions.pixelXYToCartesian2DPoint + `
|
|
32
|
+
|
|
33
|
+
void main() {
|
|
34
|
+
if (head_time < start_time || head_time > end_time) { return; }
|
|
35
|
+
if ( start_color.r < 0.0 || end_color.r < 0.0) { return; }
|
|
36
|
+
float t = (head_time - start_time) / (end_time - start_time);
|
|
37
|
+
vec3 position = mix(start_position, end_position, t);
|
|
38
|
+
if (is3D){
|
|
39
|
+
vec3 pos = pixelXYToCartesian3DPoint(position);
|
|
40
|
+
gl_Position = projection * view * vec4(pos - translate, 1.0);
|
|
41
|
+
} else {
|
|
42
|
+
vec2 xy = pixelXYToCartesian2DPoint(position.xy, translate.xy, mapWH, screenWH);
|
|
43
|
+
gl_Position = projection * vec4(xy.x, xy.y, 0.0, 1.0);
|
|
44
|
+
}
|
|
45
|
+
v_color = vec4(mix(start_color, end_color, t), final_opacity);
|
|
46
|
+
gl_PointSize = point_size;
|
|
47
|
+
}`;
|
|
48
|
+
const fragmentShader = `#version 300 es
|
|
49
|
+
precision highp float;
|
|
50
|
+
in vec4 v_color;
|
|
51
|
+
out vec4 outColor;
|
|
52
|
+
void main() {
|
|
53
|
+
// circle point
|
|
54
|
+
vec2 cxy = 2.0 * gl_PointCoord - 1.0;
|
|
55
|
+
float cc = dot(cxy, cxy);
|
|
56
|
+
outColor = v_color;
|
|
57
|
+
if (cc > 0.5) {
|
|
58
|
+
outColor.a = 0.0;
|
|
59
|
+
}
|
|
60
|
+
}`;
|
|
61
|
+
class default_1 {
|
|
62
|
+
constructor(gl, globe, attrBuffer, options) {
|
|
9
63
|
this.gl = gl;
|
|
10
64
|
this._cameraBlockBindingPoint = 0;
|
|
11
65
|
this._globalsBlockBindingPoint = 1;
|
|
@@ -16,31 +70,31 @@ var default_1 = /** @class */ (function () {
|
|
|
16
70
|
this._drawCount = 0;
|
|
17
71
|
this._globalsbuffer = gl.createBuffer();
|
|
18
72
|
{
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
73
|
+
const { gl, _globalsbuffer } = this;
|
|
74
|
+
gl.bindBuffer(gl.UNIFORM_BUFFER, _globalsbuffer);
|
|
75
|
+
gl.bufferData(gl.UNIFORM_BUFFER, 12, gl.STREAM_DRAW);
|
|
76
|
+
gl.bufferSubData(gl.UNIFORM_BUFFER, 0, new Float32Array([0, options.opacity, options.pointSize]));
|
|
77
|
+
gl.bindBufferBase(gl.UNIFORM_BUFFER, this._globalsBlockBindingPoint, _globalsbuffer);
|
|
78
|
+
gl.bindBuffer(gl.UNIFORM_BUFFER, null);
|
|
25
79
|
}
|
|
26
80
|
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
81
|
+
_createProgram() {
|
|
82
|
+
const gl = this.gl;
|
|
83
|
+
const program = (0, util_1.createProgram)(gl, vertexShader, fragmentShader);
|
|
84
|
+
const ubo = this.cameraUniformBlockTotem.getUBO(); // ubo bl
|
|
85
|
+
const cameraBlockIndex = gl.getUniformBlockIndex(program, "GlobeCamera");
|
|
32
86
|
gl.uniformBlockBinding(program, cameraBlockIndex, this._cameraBlockBindingPoint);
|
|
33
|
-
|
|
87
|
+
const globalsBlockIndex = gl.getUniformBlockIndex(program, "Globals");
|
|
34
88
|
gl.bindBufferBase(gl.UNIFORM_BUFFER, this._cameraBlockBindingPoint, ubo);
|
|
35
89
|
gl.uniformBlockBinding(program, globalsBlockIndex, this._globalsBlockBindingPoint);
|
|
36
90
|
gl.bindBufferBase(gl.UNIFORM_BUFFER, this._globalsBlockBindingPoint, this._globalsbuffer);
|
|
37
91
|
// numaralarda yanlışlık olabilir
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
92
|
+
const start_position = gl.getAttribLocation(program, "start_position");
|
|
93
|
+
const start_time = gl.getAttribLocation(program, "start_time");
|
|
94
|
+
const start_color = gl.getAttribLocation(program, "start_color");
|
|
95
|
+
const end_position = gl.getAttribLocation(program, "end_position");
|
|
96
|
+
const end_time = gl.getAttribLocation(program, "end_time");
|
|
97
|
+
const end_color = gl.getAttribLocation(program, "end_color");
|
|
44
98
|
gl.bindVertexArray(this._vao);
|
|
45
99
|
gl.bindBuffer(gl.ARRAY_BUFFER, this._attbuffer);
|
|
46
100
|
gl.enableVertexAttribArray(start_position);
|
|
@@ -58,44 +112,43 @@ var default_1 = /** @class */ (function () {
|
|
|
58
112
|
gl.bindVertexArray(null);
|
|
59
113
|
gl.bindBuffer(gl.ARRAY_BUFFER, null);
|
|
60
114
|
return program;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
|
|
115
|
+
}
|
|
116
|
+
setOpacity(opacity) {
|
|
117
|
+
const { gl, _globalsbuffer } = this;
|
|
64
118
|
gl.bindBuffer(gl.UNIFORM_BUFFER, _globalsbuffer);
|
|
65
119
|
gl.bufferSubData(gl.UNIFORM_BUFFER, 4, new Float32Array([opacity]));
|
|
66
120
|
gl.bindBuffer(gl.UNIFORM_BUFFER, null);
|
|
67
|
-
}
|
|
68
|
-
|
|
121
|
+
}
|
|
122
|
+
setDrawCount(count) {
|
|
69
123
|
this._drawCount = count;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
|
|
124
|
+
}
|
|
125
|
+
setPointSize(size) {
|
|
126
|
+
const { gl, _globalsbuffer } = this;
|
|
73
127
|
gl.bindBuffer(gl.UNIFORM_BUFFER, _globalsbuffer);
|
|
74
128
|
gl.bufferSubData(gl.UNIFORM_BUFFER, 8, new Float32Array([size]));
|
|
75
129
|
gl.bindBuffer(gl.UNIFORM_BUFFER, null);
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
|
|
130
|
+
}
|
|
131
|
+
setHeadTime(time) {
|
|
132
|
+
const { gl, _globalsbuffer } = this;
|
|
79
133
|
gl.bindBuffer(gl.UNIFORM_BUFFER, _globalsbuffer);
|
|
80
134
|
gl.bufferSubData(gl.UNIFORM_BUFFER, 0, new Float32Array([time]));
|
|
81
135
|
gl.bindBuffer(gl.UNIFORM_BUFFER, null);
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
|
|
136
|
+
}
|
|
137
|
+
draw() {
|
|
138
|
+
const { gl, program, _vao, _drawCount } = this;
|
|
85
139
|
gl.useProgram(program);
|
|
86
140
|
gl.bindVertexArray(_vao);
|
|
87
141
|
gl.disable(gl.DEPTH_TEST);
|
|
88
142
|
gl.drawArrays(gl.POINTS, 0, _drawCount);
|
|
89
143
|
gl.enable(gl.DEPTH_TEST);
|
|
90
144
|
gl.bindVertexArray(null);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
|
|
145
|
+
}
|
|
146
|
+
free() {
|
|
147
|
+
const { gl, _vao, _globalsbuffer, program } = this;
|
|
94
148
|
gl.deleteVertexArray(_vao);
|
|
95
149
|
// gl.deleteBuffer(_attbuffer);
|
|
96
150
|
gl.deleteBuffer(_globalsbuffer);
|
|
97
151
|
gl.deleteProgram(program);
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
}());
|
|
152
|
+
}
|
|
153
|
+
}
|
|
101
154
|
exports.default = default_1;
|
|
@@ -1,11 +1,58 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
3
|
+
const util_1 = require("../util");
|
|
4
|
+
const programs_1 = require("../programs");
|
|
5
|
+
const vertexShader = `#version 300 es
|
|
6
|
+
|
|
7
|
+
layout(std140) uniform GlobeCamera {
|
|
8
|
+
mat4 view; // 64 bytes 0
|
|
9
|
+
mat4 projection; // 64 bytes 64
|
|
10
|
+
vec3 translate; // 12 bytes 128
|
|
11
|
+
bool is3D; // 4 bytes 140
|
|
12
|
+
vec2 mapWH; // 8 bytes 144
|
|
13
|
+
vec2 screenWH; // 8 bytes 152
|
|
14
|
+
float z_level; // 4 bytes 160
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
layout(std140) uniform Globals {
|
|
18
|
+
float head_time;
|
|
19
|
+
float final_opacity;
|
|
20
|
+
float point_size;
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
in vec3 start_position;
|
|
24
|
+
in float start_time;
|
|
25
|
+
in vec3 start_color;
|
|
26
|
+
in vec3 end_position;
|
|
27
|
+
in float end_time;
|
|
28
|
+
in vec3 end_color;
|
|
29
|
+
out vec4 v_color;
|
|
30
|
+
|
|
31
|
+
` + util_1.shaderfunctions.pixelXYToCartesian3DPoint + util_1.shaderfunctions.pixelXYToCartesian2DPoint + `
|
|
32
|
+
|
|
33
|
+
void main() {
|
|
34
|
+
if (head_time < start_time || head_time > end_time) { return; }
|
|
35
|
+
float t = (head_time - start_time) / (end_time - start_time);
|
|
36
|
+
vec3 position = mix(start_position, end_position, t);
|
|
37
|
+
if (is3D){
|
|
38
|
+
vec3 pos = pixelXYToCartesian3DPoint(position);
|
|
39
|
+
gl_Position = projection * view * vec4(pos - translate, 1.0);
|
|
40
|
+
} else {
|
|
41
|
+
vec2 xy = pixelXYToCartesian2DPoint(position.xy, translate.xy, mapWH, screenWH);
|
|
42
|
+
gl_Position = projection * vec4(xy.x, xy.y, 0.0, 1.0);
|
|
43
|
+
}
|
|
44
|
+
v_color = vec4(mix(start_color, end_color, t), final_opacity);
|
|
45
|
+
gl_PointSize = point_size;
|
|
46
|
+
}`;
|
|
47
|
+
const fragmentShader = `#version 300 es
|
|
48
|
+
precision highp float;
|
|
49
|
+
in vec4 v_color;
|
|
50
|
+
out vec4 outColor;
|
|
51
|
+
void main() {
|
|
52
|
+
outColor = v_color;
|
|
53
|
+
}`;
|
|
54
|
+
class default_1 {
|
|
55
|
+
constructor(gl, globe, attrBuffer, options) {
|
|
9
56
|
this.gl = gl;
|
|
10
57
|
this._cameraBlockBindingPoint = 0;
|
|
11
58
|
this._globalsBlockBindingPoint = 1;
|
|
@@ -16,31 +63,31 @@ var default_1 = /** @class */ (function () {
|
|
|
16
63
|
this._drawCount = 0;
|
|
17
64
|
this._globalsbuffer = gl.createBuffer();
|
|
18
65
|
{
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
66
|
+
const { gl, _globalsbuffer } = this;
|
|
67
|
+
gl.bindBuffer(gl.UNIFORM_BUFFER, _globalsbuffer);
|
|
68
|
+
gl.bufferData(gl.UNIFORM_BUFFER, 12, gl.STREAM_DRAW);
|
|
69
|
+
gl.bufferSubData(gl.UNIFORM_BUFFER, 0, new Float32Array([0, options.opacity, options.pointSize]));
|
|
70
|
+
gl.bindBufferBase(gl.UNIFORM_BUFFER, this._globalsBlockBindingPoint, _globalsbuffer);
|
|
71
|
+
gl.bindBuffer(gl.UNIFORM_BUFFER, null);
|
|
25
72
|
}
|
|
26
73
|
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
74
|
+
_createProgram() {
|
|
75
|
+
const gl = this.gl;
|
|
76
|
+
const program = (0, util_1.createProgram)(gl, vertexShader, fragmentShader);
|
|
77
|
+
const ubo = this.cameraUniformBlockTotem.getUBO(); // ubo bl
|
|
78
|
+
const cameraBlockIndex = gl.getUniformBlockIndex(program, "GlobeCamera");
|
|
32
79
|
gl.uniformBlockBinding(program, cameraBlockIndex, this._cameraBlockBindingPoint);
|
|
33
|
-
|
|
80
|
+
const globalsBlockIndex = gl.getUniformBlockIndex(program, "Globals");
|
|
34
81
|
gl.bindBufferBase(gl.UNIFORM_BUFFER, this._cameraBlockBindingPoint, ubo);
|
|
35
82
|
gl.uniformBlockBinding(program, globalsBlockIndex, this._globalsBlockBindingPoint);
|
|
36
83
|
gl.bindBufferBase(gl.UNIFORM_BUFFER, this._globalsBlockBindingPoint, this._globalsbuffer);
|
|
37
84
|
// numaralarda yanlışlık olabilir
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
85
|
+
const start_position = gl.getAttribLocation(program, "start_position");
|
|
86
|
+
const start_time = gl.getAttribLocation(program, "start_time");
|
|
87
|
+
const start_color = gl.getAttribLocation(program, "start_color");
|
|
88
|
+
const end_position = gl.getAttribLocation(program, "end_position");
|
|
89
|
+
const end_time = gl.getAttribLocation(program, "end_time");
|
|
90
|
+
const end_color = gl.getAttribLocation(program, "end_color");
|
|
44
91
|
gl.bindVertexArray(this._vao);
|
|
45
92
|
gl.bindBuffer(gl.ARRAY_BUFFER, this._attbuffer);
|
|
46
93
|
gl.enableVertexAttribArray(start_position);
|
|
@@ -58,44 +105,43 @@ var default_1 = /** @class */ (function () {
|
|
|
58
105
|
gl.bindVertexArray(null);
|
|
59
106
|
gl.bindBuffer(gl.ARRAY_BUFFER, null);
|
|
60
107
|
return program;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
|
|
108
|
+
}
|
|
109
|
+
setOpacity(opacity) {
|
|
110
|
+
const { gl, _globalsbuffer } = this;
|
|
64
111
|
gl.bindBuffer(gl.UNIFORM_BUFFER, _globalsbuffer);
|
|
65
112
|
gl.bufferSubData(gl.UNIFORM_BUFFER, 4, new Float32Array([opacity]));
|
|
66
113
|
gl.bindBuffer(gl.UNIFORM_BUFFER, null);
|
|
67
|
-
}
|
|
68
|
-
|
|
114
|
+
}
|
|
115
|
+
setDrawCount(count) {
|
|
69
116
|
this._drawCount = count;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
|
|
117
|
+
}
|
|
118
|
+
setPointSize(size) {
|
|
119
|
+
const { gl, _globalsbuffer } = this;
|
|
73
120
|
gl.bindBuffer(gl.UNIFORM_BUFFER, _globalsbuffer);
|
|
74
121
|
gl.bufferSubData(gl.UNIFORM_BUFFER, 8, new Float32Array([size]));
|
|
75
122
|
gl.bindBuffer(gl.UNIFORM_BUFFER, null);
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
|
|
123
|
+
}
|
|
124
|
+
setHeadTime(time) {
|
|
125
|
+
const { gl, _globalsbuffer } = this;
|
|
79
126
|
gl.bindBuffer(gl.UNIFORM_BUFFER, _globalsbuffer);
|
|
80
127
|
gl.bufferSubData(gl.UNIFORM_BUFFER, 0, new Float32Array([time]));
|
|
81
128
|
gl.bindBuffer(gl.UNIFORM_BUFFER, null);
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
|
|
129
|
+
}
|
|
130
|
+
draw() {
|
|
131
|
+
const { gl, program, _vao, _drawCount } = this;
|
|
85
132
|
gl.useProgram(program);
|
|
86
133
|
gl.bindVertexArray(_vao);
|
|
87
134
|
gl.disable(gl.DEPTH_TEST);
|
|
88
135
|
gl.drawArrays(gl.POINTS, 0, _drawCount);
|
|
89
136
|
gl.enable(gl.DEPTH_TEST);
|
|
90
137
|
gl.bindVertexArray(null);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
|
|
138
|
+
}
|
|
139
|
+
free() {
|
|
140
|
+
const { gl, _vao, _globalsbuffer, program } = this;
|
|
94
141
|
gl.deleteVertexArray(_vao);
|
|
95
142
|
// gl.deleteBuffer(_attbuffer);
|
|
96
143
|
gl.deleteBuffer(_globalsbuffer);
|
|
97
144
|
gl.deleteProgram(program);
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
}());
|
|
145
|
+
}
|
|
146
|
+
}
|
|
101
147
|
exports.default = default_1;
|
|
@@ -19,9 +19,8 @@
|
|
|
19
19
|
* This unpredicatable behavior is not handled by this class.
|
|
20
20
|
*/
|
|
21
21
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
var _b = _a === void 0 ? {} : _a, _c = _b.capacity, capacity = _c === void 0 ? 10 : _c, _d = _b.bufferType, bufferType = _d === void 0 ? "STATIC_DRAW" : _d;
|
|
22
|
+
class default_1 {
|
|
23
|
+
constructor(itemSize, { capacity = 10, bufferType = "STATIC_DRAW" } = {}) {
|
|
25
24
|
this.itemSize = itemSize;
|
|
26
25
|
this.bufferType = bufferType;
|
|
27
26
|
this.offSetMap = new Map();
|
|
@@ -29,52 +28,36 @@ var default_1 = /** @class */ (function () {
|
|
|
29
28
|
this._capacity = capacity;
|
|
30
29
|
this._length = 0;
|
|
31
30
|
}
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
Object.defineProperty(default_1.prototype, "capacity", {
|
|
40
|
-
get: function () {
|
|
41
|
-
return this._capacity;
|
|
42
|
-
},
|
|
43
|
-
enumerable: false,
|
|
44
|
-
configurable: true
|
|
45
|
-
});
|
|
46
|
-
default_1.prototype.getOffset = function (key) {
|
|
31
|
+
get length() {
|
|
32
|
+
return this._length;
|
|
33
|
+
}
|
|
34
|
+
get capacity() {
|
|
35
|
+
return this._capacity;
|
|
36
|
+
}
|
|
37
|
+
getOffset(key) {
|
|
47
38
|
return this.offSetMap.get(key);
|
|
48
|
-
}
|
|
49
|
-
|
|
39
|
+
}
|
|
40
|
+
setOffset(key, offset) {
|
|
50
41
|
this.offSetMap.set(key, offset);
|
|
51
|
-
}
|
|
52
|
-
|
|
42
|
+
}
|
|
43
|
+
nextOffset() {
|
|
53
44
|
if (this.tombstoneOffSet.length > 0) {
|
|
54
|
-
|
|
45
|
+
const offset = this.tombstoneOffSet.pop();
|
|
55
46
|
return offset;
|
|
56
47
|
}
|
|
57
48
|
if (this._length < this._capacity) {
|
|
58
49
|
return this._length++ * this.itemSize * 4;
|
|
59
50
|
}
|
|
60
51
|
return false;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
get: function () {
|
|
71
|
-
return this._length - this.tombstoneOffSet.length;
|
|
72
|
-
},
|
|
73
|
-
enumerable: false,
|
|
74
|
-
configurable: true
|
|
75
|
-
});
|
|
76
|
-
default_1.prototype.deleteFromAccount = function (key) {
|
|
77
|
-
var offSet = this.offSetMap.get(key);
|
|
52
|
+
}
|
|
53
|
+
get spaceLeft() {
|
|
54
|
+
return this._capacity - (this._length - this.tombstoneOffSet.length);
|
|
55
|
+
}
|
|
56
|
+
get itemCount() {
|
|
57
|
+
return this._length - this.tombstoneOffSet.length;
|
|
58
|
+
}
|
|
59
|
+
deleteFromAccount(key) {
|
|
60
|
+
const offSet = this.offSetMap.get(key);
|
|
78
61
|
if (offSet !== undefined) {
|
|
79
62
|
this.tombstoneOffSet.push(offSet);
|
|
80
63
|
this.offSetMap.delete(key);
|
|
@@ -83,41 +66,38 @@ var default_1 = /** @class */ (function () {
|
|
|
83
66
|
else {
|
|
84
67
|
return false;
|
|
85
68
|
}
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
69
|
+
}
|
|
70
|
+
_deleteBulk(keys) {
|
|
71
|
+
const { gl, buffer } = this;
|
|
72
|
+
const emptyBlock = new Float32Array(this.itemSize).fill(0);
|
|
90
73
|
gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
|
|
91
|
-
for (
|
|
92
|
-
|
|
93
|
-
var offset = this.getOffset(key);
|
|
74
|
+
for (let key of keys) {
|
|
75
|
+
const offset = this.getOffset(key);
|
|
94
76
|
if (offset !== undefined) {
|
|
95
77
|
this.deleteFromAccount(key);
|
|
96
78
|
gl.bufferSubData(gl.ARRAY_BUFFER, offset, emptyBlock);
|
|
97
79
|
}
|
|
98
80
|
}
|
|
99
81
|
gl.bindBuffer(gl.ARRAY_BUFFER, null);
|
|
100
|
-
}
|
|
101
|
-
|
|
82
|
+
}
|
|
83
|
+
offsetMapIterator() {
|
|
102
84
|
return this.offSetMap.entries();
|
|
103
|
-
}
|
|
85
|
+
}
|
|
104
86
|
// TODO: this is broken
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
var _a = this, gl = _a.gl, buffer = _a.buffer, bufferType = _a.bufferType;
|
|
87
|
+
defrag(newCapacity = null) {
|
|
88
|
+
const { gl, buffer, bufferType } = this;
|
|
108
89
|
if (gl === undefined || buffer === undefined || bufferType === undefined) {
|
|
109
90
|
throw new Error("gl, buffer, bufferType are required");
|
|
110
91
|
}
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
for (
|
|
119
|
-
|
|
120
|
-
var itemOffSet = offSet / 4;
|
|
92
|
+
const itemSize = this.itemSize;
|
|
93
|
+
const itemCount = this.itemCount;
|
|
94
|
+
const capacity = (newCapacity && newCapacity > itemCount) ? newCapacity : itemCount;
|
|
95
|
+
const newArray = new Float32Array(itemCount * itemSize);
|
|
96
|
+
const bufferData = this._getBufferData();
|
|
97
|
+
let newOffSet = 0;
|
|
98
|
+
const newOffSetMap = new Map();
|
|
99
|
+
for (const [key, offSet] of this.offSetMap) {
|
|
100
|
+
const itemOffSet = offSet / 4;
|
|
121
101
|
newArray.set(bufferData.slice(itemOffSet, itemOffSet + itemSize), newOffSet);
|
|
122
102
|
// this.offSetMap.set(key, newOffSet * 4);
|
|
123
103
|
newOffSetMap.set(key, newOffSet * 4);
|
|
@@ -131,23 +111,23 @@ var default_1 = /** @class */ (function () {
|
|
|
131
111
|
this.tombstoneOffSet = [];
|
|
132
112
|
this._length = itemCount;
|
|
133
113
|
this.offSetMap = newOffSetMap;
|
|
134
|
-
}
|
|
135
|
-
|
|
114
|
+
}
|
|
115
|
+
autoExtendBuffer(payloadSize) {
|
|
136
116
|
if (payloadSize <= this.spaceLeft)
|
|
137
117
|
return;
|
|
138
|
-
|
|
118
|
+
const newCapacity = Math.ceil((payloadSize + this.length));
|
|
139
119
|
this.extendBuffer(newCapacity);
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
120
|
+
}
|
|
121
|
+
extendBuffer(newCapacity) {
|
|
122
|
+
const { gl, buffer, bufferType } = this;
|
|
123
|
+
const itemSize = this.itemSize;
|
|
124
|
+
const bufferData = this._getBufferData();
|
|
145
125
|
gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
|
|
146
126
|
gl.bufferData(gl.ARRAY_BUFFER, newCapacity * itemSize * 4, gl[bufferType]);
|
|
147
127
|
gl.bufferSubData(gl.ARRAY_BUFFER, 0, bufferData);
|
|
148
128
|
gl.bindBuffer(gl.ARRAY_BUFFER, null);
|
|
149
129
|
this._capacity = newCapacity;
|
|
150
|
-
}
|
|
130
|
+
}
|
|
151
131
|
/** implicit methods to be used by the child class */
|
|
152
132
|
/**
|
|
153
133
|
* @typedef {Float32Array} payload
|
|
@@ -155,48 +135,45 @@ var default_1 = /** @class */ (function () {
|
|
|
155
135
|
* @param {number} partOffset
|
|
156
136
|
* @returns
|
|
157
137
|
*/
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
138
|
+
_updatePartial(items, partOffset) {
|
|
139
|
+
const { gl, buffer } = this;
|
|
140
|
+
const partStart = partOffset * 4;
|
|
161
141
|
gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
|
|
162
|
-
for (
|
|
163
|
-
|
|
164
|
-
var offset = this.getOffset(key);
|
|
142
|
+
for (let { key, payload } of items) {
|
|
143
|
+
let offset = this.getOffset(key);
|
|
165
144
|
if (offset !== undefined) {
|
|
166
145
|
gl.bufferSubData(gl.ARRAY_BUFFER, offset + partStart, payload);
|
|
167
146
|
}
|
|
168
147
|
}
|
|
169
148
|
gl.bindBuffer(gl.ARRAY_BUFFER, null);
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
149
|
+
}
|
|
150
|
+
_getBufferData() {
|
|
151
|
+
const { gl, buffer } = this;
|
|
152
|
+
const size = new Float32Array(this.length * this.itemSize);
|
|
153
|
+
const bufferData = new Float32Array(size);
|
|
175
154
|
gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
|
|
176
155
|
gl.getBufferSubData(gl.ARRAY_BUFFER, 0, bufferData);
|
|
177
156
|
gl.bindBuffer(gl.ARRAY_BUFFER, null);
|
|
178
157
|
return bufferData;
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
158
|
+
}
|
|
159
|
+
_removeFromBuffer(keys) {
|
|
160
|
+
const { gl, buffer } = this;
|
|
161
|
+
const emptyBlock = new Float32Array(this.itemSize).fill(0);
|
|
183
162
|
gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
|
|
184
|
-
for (
|
|
185
|
-
|
|
186
|
-
var offset = this.getOffset(key);
|
|
163
|
+
for (let key of keys) {
|
|
164
|
+
let offset = this.getOffset(key);
|
|
187
165
|
if (offset !== undefined) {
|
|
188
166
|
this.deleteFromAccount(key);
|
|
189
167
|
gl.bufferSubData(gl.ARRAY_BUFFER, offset, emptyBlock);
|
|
190
168
|
}
|
|
191
169
|
}
|
|
192
170
|
gl.bindBuffer(gl.ARRAY_BUFFER, null);
|
|
193
|
-
}
|
|
194
|
-
|
|
171
|
+
}
|
|
172
|
+
free() {
|
|
195
173
|
this.gl.deleteBuffer(this.buffer);
|
|
196
174
|
this.buffer = null;
|
|
197
175
|
this.vao = null;
|
|
198
176
|
this.gl = null;
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
}());
|
|
177
|
+
}
|
|
178
|
+
}
|
|
202
179
|
exports.default = default_1;
|
package/util/account/index.js
CHANGED
|
@@ -18,6 +18,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
18
18
|
};
|
|
19
19
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
20
20
|
exports.BufferOffsetManager = void 0;
|
|
21
|
-
|
|
21
|
+
const bufferoffsetmanager_1 = __importDefault(require("./bufferoffsetmanager"));
|
|
22
22
|
exports.BufferOffsetManager = bufferoffsetmanager_1.default;
|
|
23
23
|
__exportStar(require("./single-attribute-buffer-management/index"), exports);
|