@pirireis/webglobeplugins 0.9.8 → 0.9.9

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 (213) hide show
  1. package/index.js +58 -15
  2. package/package.json +1 -1
  3. package/dist/Math/angle-calculation.js +0 -15
  4. package/dist/Math/arc.js +0 -65
  5. package/dist/Math/bounds/line-bbox.js +0 -188
  6. package/dist/Math/constants.js +0 -9
  7. package/dist/Math/frustum/camera.js +0 -24
  8. package/dist/Math/frustum/from-globeinfo.js +0 -48
  9. package/dist/Math/frustum/types.js +0 -2
  10. package/dist/Math/globe-util/horizon-plane.js +0 -112
  11. package/dist/Math/index.js +0 -1
  12. package/dist/Math/juction/arc-plane.js +0 -83
  13. package/dist/Math/juction/line-sphere.js +0 -25
  14. package/dist/Math/juction/plane-plane.js +0 -58
  15. package/dist/Math/line.js +0 -56
  16. package/dist/Math/matrix4.js +0 -1
  17. package/dist/Math/methods.js +0 -201
  18. package/dist/Math/plane.js +0 -60
  19. package/dist/Math/quaternion.js +0 -104
  20. package/dist/Math/types.js +0 -2
  21. package/dist/Math/utils.js +0 -4
  22. package/dist/Math/vec3.js +0 -126
  23. package/dist/algorithms/search-binary.js +0 -19
  24. package/dist/altitude-locator/adaptors.js +0 -1
  25. package/dist/altitude-locator/draw-subset-obj.js +0 -18
  26. package/dist/altitude-locator/keymethod.js +0 -1
  27. package/dist/altitude-locator/plugin.js +0 -341
  28. package/dist/altitude-locator/types.js +0 -23
  29. package/dist/arrowfield/adaptor.js +0 -14
  30. package/dist/arrowfield/index.js +0 -10
  31. package/dist/arrowfield/plugin.js +0 -86
  32. package/dist/bearing-line/index.js +0 -8
  33. package/dist/bearing-line/plugin.js +0 -449
  34. package/dist/circle-line-chain/chain-list-map.js +0 -205
  35. package/dist/circle-line-chain/init.js +0 -1
  36. package/dist/circle-line-chain/plugin.js +0 -424
  37. package/dist/circle-line-chain/util.js +0 -5
  38. package/dist/compass-rose/compass-rose-padding-flat.js +0 -225
  39. package/dist/compass-rose/compass-text-writer.js +0 -153
  40. package/dist/compass-rose/index.js +0 -7
  41. package/dist/compassrose/compassrose.js +0 -296
  42. package/dist/compassrose/index.js +0 -8
  43. package/dist/globe-types.js +0 -1
  44. package/dist/heatwave/index.js +0 -10
  45. package/dist/heatwave/isobar/objectarraylabels.js +0 -202
  46. package/dist/heatwave/isobar/plugin.js +0 -343
  47. package/dist/heatwave/isobar/quadtreecontours.js +0 -300
  48. package/dist/heatwave/plugins/heatwaveglobeshell.js +0 -206
  49. package/dist/index.js +0 -58
  50. package/dist/jest.config.js +0 -7
  51. package/dist/partialrings/buffer-manager.js +0 -81
  52. package/dist/partialrings/index.js +0 -41
  53. package/dist/partialrings/plugin.js +0 -135
  54. package/dist/partialrings/program.js +0 -286
  55. package/dist/pin/pin-object-array.js +0 -305
  56. package/dist/pin/pin-point-totem.js +0 -60
  57. package/dist/point-heat-map/adaptors/timetracksplugin-format-to-this.js +0 -66
  58. package/dist/point-heat-map/index.js +0 -1
  59. package/dist/point-heat-map/plugin-webworker.js +0 -126
  60. package/dist/point-heat-map/point-to-heat-map-flow.js +0 -127
  61. package/dist/point-tracks/key-methods.js +0 -5
  62. package/dist/point-tracks/plugin.js +0 -338
  63. package/dist/programs/arrowfield/index.js +0 -7
  64. package/dist/programs/arrowfield/logic.js +0 -257
  65. package/dist/programs/arrowfield/object.js +0 -66
  66. package/dist/programs/data2legend/density-to-legend.js +0 -101
  67. package/dist/programs/data2legend/point-to-density-texture.js +0 -100
  68. package/dist/programs/float2legendwithratio/index.js +0 -8
  69. package/dist/programs/float2legendwithratio/logic.js +0 -171
  70. package/dist/programs/float2legendwithratio/object.js +0 -110
  71. package/dist/programs/globe-util/is-globe-moved.js +0 -21
  72. package/dist/programs/globeshell/index.js +0 -8
  73. package/dist/programs/globeshell/noise/noises.js +0 -1
  74. package/dist/programs/globeshell/wiggle/index.js +0 -8
  75. package/dist/programs/globeshell/wiggle/logic.js +0 -345
  76. package/dist/programs/globeshell/wiggle/object.js +0 -72
  77. package/dist/programs/helpers/blender/index.js +0 -1
  78. package/dist/programs/helpers/blender/program.js +0 -79
  79. package/dist/programs/helpers/fadeaway/index.js +0 -7
  80. package/dist/programs/helpers/fadeaway/logic.js +0 -72
  81. package/dist/programs/helpers/fadeaway/object.js +0 -20
  82. package/dist/programs/helpers/index.js +0 -8
  83. package/dist/programs/index.js +0 -58
  84. package/dist/programs/interface.js +0 -1
  85. package/dist/programs/line-on-globe/angled-line.js +0 -176
  86. package/dist/programs/line-on-globe/circle-accurate-3d.js +0 -141
  87. package/dist/programs/line-on-globe/circle-accurate-flat.js +0 -216
  88. package/dist/programs/line-on-globe/circle-accurate.js +0 -178
  89. package/dist/programs/line-on-globe/circle.js +0 -167
  90. package/dist/programs/line-on-globe/degree-padding-around-circle-3d.js +0 -159
  91. package/dist/programs/line-on-globe/index.js +0 -1
  92. package/dist/programs/line-on-globe/lines-color-instanced-flat.js +0 -136
  93. package/dist/programs/line-on-globe/linestrip.js +0 -171
  94. package/dist/programs/line-on-globe/naive-accurate-flexible.js +0 -195
  95. package/dist/programs/line-on-globe/to-the-surface.js +0 -111
  96. package/dist/programs/line-on-globe/util.js +0 -8
  97. package/dist/programs/picking/pickable-renderer.js +0 -188
  98. package/dist/programs/point-on-globe/element-globe-surface-glow.js +0 -142
  99. package/dist/programs/point-on-globe/element-point-glow.js +0 -153
  100. package/dist/programs/point-on-globe/square-pixel-point.js +0 -174
  101. package/dist/programs/programcache.js +0 -131
  102. package/dist/programs/rings/distancering/circleflatprogram.js +0 -156
  103. package/dist/programs/rings/distancering/circlepaddingfreeangleprogram.js +0 -369
  104. package/dist/programs/rings/distancering/circlepaddysharedbuffer.js +0 -357
  105. package/dist/programs/rings/distancering/index.js +0 -14
  106. package/dist/programs/rings/distancering/paddyflatprogram.js +0 -172
  107. package/dist/programs/rings/distancering/paddyflatprogram2d.js +0 -174
  108. package/dist/programs/rings/distancering/paddyflatprogram3d.js +0 -172
  109. package/dist/programs/rings/distancering/shader.js +0 -1
  110. package/dist/programs/rings/index.js +0 -17
  111. package/dist/programs/rings/partial-ring/piece-of-pie.js +0 -275
  112. package/dist/programs/totems/camerauniformblock.js +0 -160
  113. package/dist/programs/totems/canvas-webglobe-info.js +0 -110
  114. package/dist/programs/totems/gpu-selection-uniform-block.js +0 -108
  115. package/dist/programs/totems/index.js +0 -40
  116. package/dist/programs/two-d/pixel-circle.js +0 -1
  117. package/dist/programs/two-d/pixel-padding-for-compass.js +0 -162
  118. package/dist/programs/util.js +0 -17
  119. package/dist/programs/vectorfields/index.js +0 -23
  120. package/dist/programs/vectorfields/logics/drawrectangleparticles.js +0 -107
  121. package/dist/programs/vectorfields/logics/index.js +0 -12
  122. package/dist/programs/vectorfields/logics/pixelbased.js +0 -142
  123. package/dist/programs/vectorfields/logics/ubo.js +0 -63
  124. package/dist/programs/vectorfields/pingpongbuffermanager.js +0 -76
  125. package/dist/rangerings/enum.js +0 -5
  126. package/dist/rangerings/index.js +0 -15
  127. package/dist/rangerings/plugin.js +0 -560
  128. package/dist/rangerings/rangeringangletext.js +0 -329
  129. package/dist/rangerings/ring-account.js +0 -117
  130. package/dist/shaders/fragment-toy/firework.js +0 -58
  131. package/dist/shaders/fragment-toy/singularity.js +0 -59
  132. package/dist/shape-on-terrain/arc/naive/plugin.js +0 -252
  133. package/dist/timetracks/adaptors-line-strip.js +0 -71
  134. package/dist/timetracks/adaptors.js +0 -122
  135. package/dist/timetracks/index.js +0 -19
  136. package/dist/timetracks/plugin-line-strip.js +0 -250
  137. package/dist/timetracks/plugin.js +0 -258
  138. package/dist/timetracks/program-line-strip.js +0 -611
  139. package/dist/timetracks/program.js +0 -772
  140. package/dist/timetracks/programpoint-line-strip.js +0 -154
  141. package/dist/timetracks/programpoint.js +0 -147
  142. package/dist/types.js +0 -15
  143. package/dist/util/account/bufferoffsetmanager.js +0 -179
  144. package/dist/util/account/index.js +0 -23
  145. package/dist/util/account/single-attribute-buffer-management/buffer-manager.js +0 -108
  146. package/dist/util/account/single-attribute-buffer-management/buffer-orchestrator.js +0 -150
  147. package/dist/util/account/single-attribute-buffer-management/index.js +0 -9
  148. package/dist/util/account/single-attribute-buffer-management/object-store.js +0 -51
  149. package/dist/util/account/single-attribute-buffer-management/types.js +0 -2
  150. package/dist/util/account/util.js +0 -22
  151. package/dist/util/algorithms/index.js +0 -1
  152. package/dist/util/algorithms/search-binary.js +0 -28
  153. package/dist/util/check/get.js +0 -18
  154. package/dist/util/check/index.js +0 -1
  155. package/dist/util/check/typecheck.js +0 -49
  156. package/dist/util/geometry/index.js +0 -51
  157. package/dist/util/gl-util/buffer/attribute-loader.js +0 -69
  158. package/dist/util/gl-util/buffer/index.js +0 -6
  159. package/dist/util/gl-util/buffer/types.js +0 -1
  160. package/dist/util/gl-util/draw-options/methods.js +0 -38
  161. package/dist/util/gl-util/draw-options/types.js +0 -15
  162. package/dist/util/gl-util/uniform-block/manager.js +0 -156
  163. package/dist/util/gl-util/uniform-block/shader.js +0 -1
  164. package/dist/util/gl-util/uniform-block/types.js +0 -8
  165. package/dist/util/heatwavedatamanager/datamanager.js +0 -152
  166. package/dist/util/heatwavedatamanager/index.js +0 -10
  167. package/dist/util/heatwavedatamanager/pointcoordinatesdatacalculator.js +0 -122
  168. package/dist/util/heatwavedatamanager/pointcoordsmeta.js +0 -20
  169. package/dist/util/index.js +0 -57
  170. package/dist/util/interpolation/index.js +0 -1
  171. package/dist/util/interpolation/timetrack/index.js +0 -5
  172. package/dist/util/interpolation/timetrack/timetrack-interpolator.js +0 -79
  173. package/dist/util/interpolation/timetrack/web-worker-str.js +0 -183
  174. package/dist/util/interpolation/timetrack/web-worker.js +0 -48
  175. package/dist/util/jshelpers/data-filler.js +0 -20
  176. package/dist/util/jshelpers/equality.js +0 -20
  177. package/dist/util/jshelpers/index.js +0 -37
  178. package/dist/util/jshelpers/timefilters.js +0 -32
  179. package/dist/util/picking/fence.js +0 -46
  180. package/dist/util/picking/picker-displayer.js +0 -139
  181. package/dist/util/programs/draw-texture-on-canvas.js +0 -89
  182. package/dist/util/programs/index.js +0 -17
  183. package/dist/util/programs/shapesonglobe.js +0 -214
  184. package/dist/util/programs/supersampletotextures.js +0 -113
  185. package/dist/util/programs/texturetoglobe.js +0 -182
  186. package/dist/util/shaderfunctions/geometrytransformations.js +0 -340
  187. package/dist/util/shaderfunctions/index.js +0 -18
  188. package/dist/util/shaderfunctions/nodata.js +0 -11
  189. package/dist/util/shaderfunctions/noisefunctions.js +0 -43
  190. package/dist/util/surface-line-data/arc-bboxes.js +0 -25
  191. package/dist/util/surface-line-data/arcs-to-cuts.js +0 -50
  192. package/dist/util/surface-line-data/cut-arc.js +0 -1
  193. package/dist/util/surface-line-data/flow.js +0 -28
  194. package/dist/util/surface-line-data/rbush-manager.js +0 -1
  195. package/dist/util/surface-line-data/types.js +0 -1
  196. package/dist/util/surface-line-data/web-worker.js +0 -1
  197. package/dist/util/webglobe/gldefaultstates.js +0 -7
  198. package/dist/util/webglobe/index.js +0 -18
  199. package/dist/util/webglobe/rasteroverlay.js +0 -78
  200. package/dist/util/webglobjectbuilders.js +0 -388
  201. package/dist/util/webglobjectbuilders1.js +0 -237
  202. package/dist/waveparticles/adaptor.js +0 -17
  203. package/dist/waveparticles/index.js +0 -10
  204. package/dist/waveparticles/plugin.js +0 -266
  205. package/dist/wind/imagetovectorfieldandmagnitude.js +0 -35
  206. package/dist/wind/index.js +0 -14
  207. package/dist/wind/plugin.js +0 -926
  208. package/dist/wind/vectorfieldimage.js +0 -25
  209. package/dist/write-text/attached-text-writer.js +0 -91
  210. package/dist/write-text/context-text.js +0 -98
  211. package/dist/write-text/context-text3.js +0 -155
  212. package/dist/write-text/index.js +0 -5
  213. package/dist/write-text/writer-plugin.js +0 -8
@@ -1,174 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.PaddingProgramCache = void 0;
37
- const util_1 = require("../../../util");
38
- const camerauniformblock_1 = __importStar(require("../../totems/camerauniformblock"));
39
- const programcache_1 = require("../../programcache");
40
- const vertexShader = `#version 300 es ` +
41
- util_1.shaderfunctions.PI +
42
- util_1.shaderfunctions.R +
43
- util_1.shaderfunctions.POLE +
44
- camerauniformblock_1.CameraUniformBlockString +
45
- util_1.shaderfunctions.mercatorXYToGLPosition +
46
- util_1.shaderfunctions.longLatRadToMercator +
47
- util_1.shaderfunctions.longLatRadToCartesian3D +
48
- util_1.shaderfunctions.circleLimpFromLongLatRadCenterCartesian3D +
49
- util_1.shaderfunctions.circleLimpFromLongLatRadCenterMercatorCompass +
50
- util_1.shaderfunctions.circleLimpFromLongLatRadCenterMercatorRealDistancePadding +
51
- util_1.shaderfunctions.circleLimpFromLongLatRadCenterMercatorRealDistance + `
52
-
53
- in vec2 center;
54
- in float radius;
55
- in float pad_range;
56
- in vec4 color;
57
- in float flag;
58
-
59
- uniform int compass;
60
- uniform float pad_count;
61
-
62
- uniform float opacity;
63
-
64
-
65
- out vec2 v_limp;
66
- out vec4 v_color;
67
-
68
-
69
- void main() {
70
-
71
- float alpha_padding = z_level * z_level / (pad_range/ 100.0 );
72
- if( flag == 2.0 || flag == 1.0 || radius == 0.0 || alpha_padding < 0.1 || z_level < 3.0 ) return; // 1.0 is hide
73
- v_color = vec4(color.rgb, color.a * alpha_padding * opacity);
74
-
75
- gl_PointSize = 2.0;
76
-
77
- float odd = mod(float(gl_VertexID), 2.0);
78
- float index = (float(gl_VertexID)- odd ) / 2.0;
79
- float angle = 3.1415926535897932384626433832795 * 2.0 * (index / pad_count );
80
- float radius_ = radius - (pad_range * odd);
81
-
82
- if ( is3D){
83
- gl_Position = projection * view * vec4(
84
- circleLimpFromLongLatRadCenterCartesian3D( center, radius_, angle) - translate, 1.0);
85
- v_limp = vec2(0.0, 0.0);
86
- return;
87
- }
88
- vec2 limp;
89
- if ( compass == 1 ){
90
- limp = circleLimpFromLongLatRadCenterMercatorCompass(center , radius_, angle);
91
- } else {
92
- // limp = circleLimpFromLongLatRadCenterMercatorRealDistancePadding(center, radius_, angle);
93
- limp = circleLimpFromLongLatRadCenterMercatorRealDistance(center, radius_, angle);
94
- }
95
- v_limp = limp;
96
- gl_Position = mercatorXYToGLPosition(limp);
97
- }`;
98
- const fragmentShader = `#version 300 es
99
- precision highp float; ` +
100
- util_1.shaderfunctions.POLE + `
101
- in vec4 v_color;
102
- in vec2 v_limp;
103
- out vec4 outColor;
104
- void main() {
105
- if ( v_limp.x < -POLE || v_limp.x > POLE || v_limp.y < -POLE || v_limp.y > POLE ){ discard; }
106
- outColor = v_color;
107
- }`;
108
- class Logic {
109
- constructor(globe) {
110
- this.globe = globe;
111
- this.gl = globe.gl;
112
- this.program = (0, util_1.createProgram)(this.gl, vertexShader, fragmentShader);
113
- { // bind positions so bufferManager can use them
114
- this.gl.bindAttribLocation(this.program, 0, "center");
115
- this.gl.bindAttribLocation(this.program, 1, "radius");
116
- this.gl.bindAttribLocation(this.program, 2, "pad_range");
117
- this.gl.bindAttribLocation(this.program, 3, "color");
118
- this.gl.bindAttribLocation(this.program, 4, "flag");
119
- }
120
- this.cameraBlockBindingPoint = 0;
121
- const cameraBlockIndex = this.gl.getUniformBlockIndex(this.program, "CameraUniformBlock");
122
- this.gl.uniformBlockBinding(this.program, cameraBlockIndex, this.cameraBlockBindingPoint);
123
- this.cameraBlockTotem = programcache_1.globeProgramCache.getProgram(globe, camerauniformblock_1.default);
124
- this._padCountLocation = this.gl.getUniformLocation(this.program, "pad_count");
125
- this._opacityLocation = this.gl.getUniformLocation(this.program, "opacity");
126
- this._compassLocation = this.gl.getUniformLocation(this.program, "compass");
127
- this._compassMode = 1;
128
- this._opacity = 1.0;
129
- this._padCount = 360;
130
- {
131
- const currentProgram = this.gl.getParameter(this.gl.CURRENT_PROGRAM);
132
- this.gl.useProgram(this.program);
133
- this.gl.uniform1i(this._compassLocation, 1);
134
- this.gl.uniform1f(this._opacityLocation, 1.0);
135
- this.gl.uniform1f(this._padCountLocation, 360);
136
- this.gl.useProgram(currentProgram);
137
- }
138
- }
139
- draw(vao, length, opaity) {
140
- }
141
- draw(attrBufferManager, padCount, compass, opacity) {
142
- const { gl, program, _padCountLocation, cameraBlockBindingPoint, cameraBlockTotem, _compassLocation } = this;
143
- gl.useProgram(program);
144
- attrBufferManager.bindPaddingVAO();
145
- cameraBlockTotem.bind(cameraBlockBindingPoint);
146
- // draw instanced
147
- if (padCount !== this._padCount) {
148
- this._padCount = padCount;
149
- // console.log("padCount", padCount);
150
- gl.uniform1f(_padCountLocation, padCount);
151
- }
152
- if (compass !== this._compassMode) {
153
- // console.log("compass", compass);
154
- gl.uniform1i(_compassLocation, compass);
155
- this._compassMode = compass;
156
- }
157
- if (opacity !== this._opacity) {
158
- // console.log("opacity", opacity);
159
- this._opacity = opacity;
160
- gl.uniform1f(this._opacityLocation, opacity);
161
- }
162
- gl.drawArraysInstanced(gl.LINES, 0, padCount * 2, attrBufferManager.length);
163
- gl.bindVertexArray(null);
164
- cameraBlockTotem.unbind(cameraBlockBindingPoint);
165
- }
166
- free() {
167
- this.gl.deleteProgram(this.program);
168
- programcache_1.globeProgramCache.releaseProgram(this.globe, camerauniformblock_1.default);
169
- }
170
- }
171
- exports.PaddingProgramCache = Object.freeze({
172
- getProgram: (globe) => { return programcache_1.noRegisterGlobeProgramCache.getProgram(globe, Logic); },
173
- releaseProgram: (globe) => { programcache_1.noRegisterGlobeProgramCache.releaseProgram(globe, Logic); }
174
- });
@@ -1,172 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.PaddingProgramCache = void 0;
37
- const util_1 = require("../../../util");
38
- const camerauniformblock_1 = __importStar(require("../../totems/camerauniformblock"));
39
- const programcache_1 = require("../../programcache");
40
- const vertexShader = `#version 300 es ` +
41
- util_1.shaderfunctions.PI +
42
- util_1.shaderfunctions.R +
43
- util_1.shaderfunctions.POLE +
44
- camerauniformblock_1.CameraUniformBlockString +
45
- util_1.shaderfunctions.mercatorXYToGLPosition +
46
- util_1.shaderfunctions.longLatRadToMercator +
47
- util_1.shaderfunctions.longLatRadToCartesian3D +
48
- util_1.shaderfunctions.circleLimpFromLongLatRadCenterCartesian3D +
49
- util_1.shaderfunctions.circleLimpFromLongLatRadCenterMercatorCompass +
50
- util_1.shaderfunctions.circleLimpFromLongLatRadCenterMercatorRealDistancePadding +
51
- util_1.shaderfunctions.circleLimpFromLongLatRadCenterMercatorRealDistance + `
52
-
53
- in vec2 center;
54
- in float radius;
55
- in float pad_range;
56
- in vec4 color;
57
- in float flag;
58
-
59
- uniform int compass;
60
- uniform float pad_count;
61
-
62
- uniform float opacity;
63
-
64
-
65
- out vec2 v_limp;
66
- out vec4 v_color;
67
-
68
-
69
- void main() {
70
-
71
- float alpha_padding = z_level * z_level / (pad_range/ 100.0 );
72
- if( flag == 2.0 || flag == 1.0 || radius == 0.0 || alpha_padding < 0.1 || z_level < 3.0 ) return; // 1.0 is hide
73
- v_color = vec4(color.rgb, color.a * alpha_padding * opacity);
74
-
75
- gl_PointSize = 2.0;
76
-
77
- float odd = mod(float(gl_VertexID), 2.0);
78
- float index = (float(gl_VertexID)- odd ) / 2.0;
79
- float angle = 3.1415926535897932384626433832795 * 2.0 * (index / pad_count );
80
- float radius_ = radius - (pad_range * odd);
81
-
82
- if ( is3D){
83
- gl_Position = projection * view * vec4(
84
- circleLimpFromLongLatRadCenterCartesian3D( center, radius_, angle) - translate, 1.0);
85
- v_limp = vec2(0.0, 0.0);
86
- return;
87
- }
88
- vec2 limp;
89
- if ( compass == 1 ){
90
- limp = circleLimpFromLongLatRadCenterMercatorCompass(center , radius_, angle);
91
- } else {
92
- // limp = circleLimpFromLongLatRadCenterMercatorRealDistancePadding(center, radius_, angle);
93
- limp = circleLimpFromLongLatRadCenterMercatorRealDistance(center, radius_, angle);
94
- }
95
- v_limp = limp;
96
- gl_Position = mercatorXYToGLPosition(limp);
97
- }`;
98
- const fragmentShader = `#version 300 es
99
- precision highp float; ` +
100
- util_1.shaderfunctions.POLE + `
101
- in vec4 v_color;
102
- in vec2 v_limp;
103
- out vec4 outColor;
104
- void main() {
105
- if ( v_limp.x < -POLE || v_limp.x > POLE || v_limp.y < -POLE || v_limp.y > POLE ){ discard; }
106
- outColor = v_color;
107
- }`;
108
- class Logic {
109
- constructor(globe) {
110
- this.globe = globe;
111
- this.gl = globe.gl;
112
- this.program = (0, util_1.createProgram)(this.gl, vertexShader, fragmentShader);
113
- { // bind positions so bufferManager can use them
114
- this.gl.bindAttribLocation(this.program, 0, "center");
115
- this.gl.bindAttribLocation(this.program, 1, "radius");
116
- this.gl.bindAttribLocation(this.program, 2, "pad_range");
117
- this.gl.bindAttribLocation(this.program, 3, "color");
118
- this.gl.bindAttribLocation(this.program, 4, "flag");
119
- }
120
- this.cameraBlockBindingPoint = 0;
121
- const cameraBlockIndex = this.gl.getUniformBlockIndex(this.program, "CameraUniformBlock");
122
- this.gl.uniformBlockBinding(this.program, cameraBlockIndex, this.cameraBlockBindingPoint);
123
- this.cameraBlockTotem = programcache_1.globeProgramCache.getProgram(globe, camerauniformblock_1.default);
124
- this._padCountLocation = this.gl.getUniformLocation(this.program, "pad_count");
125
- this._opacityLocation = this.gl.getUniformLocation(this.program, "opacity");
126
- this._compassLocation = this.gl.getUniformLocation(this.program, "compass");
127
- this._compassMode = 1;
128
- this._opacity = 1.0;
129
- this._padCount = 360;
130
- {
131
- const currentProgram = this.gl.getParameter(this.gl.CURRENT_PROGRAM);
132
- this.gl.useProgram(this.program);
133
- this.gl.uniform1i(this._compassLocation, 1);
134
- this.gl.uniform1f(this._opacityLocation, 1.0);
135
- this.gl.uniform1f(this._padCountLocation, 360);
136
- this.gl.useProgram(currentProgram);
137
- }
138
- }
139
- draw(attrBufferManager, padCount, compass, opacity) {
140
- const { gl, program, _padCountLocation, cameraBlockBindingPoint, cameraBlockTotem, _compassLocation } = this;
141
- gl.useProgram(program);
142
- attrBufferManager.bindPaddingVAO();
143
- cameraBlockTotem.bind(cameraBlockBindingPoint);
144
- // draw instanced
145
- if (padCount !== this._padCount) {
146
- this._padCount = padCount;
147
- // console.log("padCount", padCount);
148
- gl.uniform1f(_padCountLocation, padCount);
149
- }
150
- if (compass !== this._compassMode) {
151
- // console.log("compass", compass);
152
- gl.uniform1i(_compassLocation, compass);
153
- this._compassMode = compass;
154
- }
155
- if (opacity !== this._opacity) {
156
- // console.log("opacity", opacity);
157
- this._opacity = opacity;
158
- gl.uniform1f(this._opacityLocation, opacity);
159
- }
160
- gl.drawArraysInstanced(gl.LINES, 0, padCount * 2, attrBufferManager.length);
161
- gl.bindVertexArray(null);
162
- cameraBlockTotem.unbind(cameraBlockBindingPoint);
163
- }
164
- free() {
165
- this.gl.deleteProgram(this.program);
166
- programcache_1.globeProgramCache.releaseProgram(this.globe, camerauniformblock_1.default);
167
- }
168
- }
169
- exports.PaddingProgramCache = Object.freeze({
170
- getProgram: (globe) => { return programcache_1.noRegisterGlobeProgramCache.getProgram(globe, Logic); },
171
- releaseProgram: (globe) => { programcache_1.noRegisterGlobeProgramCache.releaseProgram(globe, Logic); }
172
- });
@@ -1 +0,0 @@
1
- "use strict";
@@ -1,17 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./distancering"), exports);
@@ -1,275 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.PieceOfPieProgramCache = exports.Logic = exports.ITEM_SIZE = void 0;
4
- const util_1 = require("../../../util");
5
- const totems_1 = require("../../totems");
6
- const programcache_1 = require("../../programcache");
7
- const geometrytransformations_1 = require("../../../util/shaderfunctions/geometrytransformations");
8
- /**
9
- * TODO:
10
- * 1. Triangle face looks at screen. if rotation angle is positive the last vertex must be the faintest.
11
- *
12
- */
13
- const drawModeMap = Object.freeze({
14
- LINE_STRIP: 0,
15
- TRIANGLE_FAN: 1,
16
- });
17
- //${ circleLimpFromLongLatRadCenterMercatorRealDistanceNew_accurate }
18
- const vertexShaderSource = `#version 300 es
19
-
20
- ${totems_1.CameraUniformBlockString}
21
- ${geometrytransformations_1.PI}
22
- ${geometrytransformations_1.longLatRadToMercator}
23
- ${geometrytransformations_1.mercatorXYToGLPosition}
24
- ${geometrytransformations_1.longLatRadToCartesian3D}
25
- ${geometrytransformations_1.circleLimpFromLongLatRadCenterCartesian3D_accurate}
26
- ${geometrytransformations_1.circleLimpFromLongLatRadCenterMercatorCompass_accurate}
27
- ${geometrytransformations_1.cartesian3DToGLPosition}
28
-
29
- uniform float edge_count;
30
- uniform int draw_mode; // %2 => 0: LINE_STRIP, 1: TRIANGLE_FAN
31
- uniform float plugin_alpha_multiplier;
32
- //, lat, startAngle, tailAngle, ...rgba, radius, rgbaMode
33
- // in vec2 center; // long, lat in radian
34
- in vec2 center2d;
35
- in vec3 center3d;
36
- in float start_angle2d;
37
- in float tail_angle2d;
38
-
39
- in float start_angle3d;
40
- in float tail_angle3d;
41
-
42
- in vec4 color;
43
- in float radius; // in meter
44
- in float color_mode; // 0.0: constant, 1.0: fading, 2.0: hide
45
- // flat out int vid;
46
- // flat out float v_phase;
47
- out vec2 v_pos;
48
- out vec4 v_color;
49
- // flat out float v_angle;
50
-
51
- void main() {
52
- // vid = gl_VertexID;
53
- if (color_mode == 2.0 || radius == 0.0) { return; }
54
- float start_angle, tail_angle;
55
- if (is3D) {
56
- start_angle = start_angle3d;
57
- tail_angle = tail_angle3d;
58
- } else {
59
- start_angle = start_angle2d;
60
- tail_angle = tail_angle2d;
61
- }
62
- float color_mode_ = color_mode;
63
- if ( draw_mode == 0 && color_mode == 1.0) {color_mode_ = 0.0;}
64
- float vertexID = float(gl_VertexID);
65
- float radius_ = radius;
66
- float alpha = plugin_alpha_multiplier;
67
- if (draw_mode == 1) { // TRIANGLE_FAN
68
- if (gl_VertexID == 0) {
69
- radius_ = 0.0;
70
- if ( color_mode == 1.0 ) { alpha = 0.0; }
71
- }
72
- vertexID -= 1.0;
73
- }
74
- float phase = ( vertexID / (edge_count - 1.0) );
75
- // v_angle = tail_angle;
76
-
77
- if ( color_mode_ == 1.0 ) {
78
- if ( tail_angle < 0.0 ) {
79
- v_color = vec4( color.rgb , color.a * ( 1.0 - phase ) * alpha );
80
- } else {
81
- v_color = vec4( color.rgb , color.a * phase * alpha );
82
- }
83
- } else {
84
- v_color = vec4( color.rgb , color.a * alpha );
85
- }
86
- if ( color_mode == 0.0 && draw_mode == 1 ) {
87
- v_color.a /= 2.0;
88
- }
89
- float angle;
90
- if ( tail_angle > 0.0 ) {
91
- angle = tail_angle * (-phase + 1.0) + start_angle;
92
- } else {
93
- angle = tail_angle * phase + start_angle;
94
- }
95
- if (is3D) {
96
- vec3 pos = circleLimpFromLongLatRadCenterCartesian3D_accurate(center3d, radius_, angle);
97
- v_pos = vec2(0.0, 0.0);
98
- gl_Position = cartesian3DToGLPosition(pos);
99
- }
100
- else {
101
- vec2 pos2 = circleLimpFromLongLatRadCenterMercatorCompass_accurate(center2d, radius_, angle);
102
- v_pos = pos2;
103
- gl_Position = mercatorXYToGLPosition(pos2);
104
- }
105
-
106
- gl_PointSize = 10.0;
107
- }`;
108
- const fragmentShaderSource = `#version 300 es` + geometrytransformations_1.POLE + geometrytransformations_1.PI + `
109
- precision highp float;
110
- // flat in int vid;
111
- in vec4 v_color;
112
- in vec2 v_pos;
113
- // flat in float v_phase;
114
- // in float v_angle;
115
- out vec4 outColor;
116
- void main() {
117
- // if( vid % 2 == 0 ) { discard; }
118
- // if ( mod(v_angle, PI / 36.0 ) < (PI / 72.0)) { discard; }
119
- // if ( mod(v_angle * v_phase, PI / 90.0 ) < (PI / 180.0)) { discard; }
120
- if ( v_pos.x < -POLE || v_pos.x > POLE || v_pos.y < -POLE || v_pos.y > POLE ) { discard; }
121
- outColor = v_color;
122
- }`;
123
- exports.ITEM_SIZE = 10;
124
- class Logic {
125
- constructor(globe) {
126
- this.globe = globe;
127
- this.gl = globe.gl;
128
- this._lastMode = 0;
129
- this._lastEdgeCount = 64;
130
- this._lastAlphaMultiplier = 1.0;
131
- this.program = (0, util_1.createProgram)(this.gl, vertexShaderSource, fragmentShaderSource);
132
- const { gl, program } = this;
133
- { // set attributes locations
134
- gl.bindAttribLocation(program, 0, 'center2d');
135
- gl.bindAttribLocation(program, 1, 'center3d');
136
- gl.bindAttribLocation(program, 2, 'start_angle2d');
137
- gl.bindAttribLocation(program, 3, 'tail_angle2d');
138
- gl.bindAttribLocation(program, 4, 'start_angle3d');
139
- gl.bindAttribLocation(program, 5, 'tail_angle3d');
140
- gl.bindAttribLocation(program, 6, 'color');
141
- gl.bindAttribLocation(program, 7, 'radius');
142
- gl.bindAttribLocation(program, 8, 'color_mode');
143
- // vao
144
- // instanced draw read 1
145
- }
146
- { // Uniforms
147
- this._edgeCountLocation = gl.getUniformLocation(program, 'edge_count');
148
- this._draw_modeLocation = gl.getUniformLocation(program, 'draw_mode');
149
- this._plugin_alpha_multiplierLocation = gl.getUniformLocation(program, 'plugin_alpha_multiplier');
150
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
151
- gl.useProgram(program);
152
- gl.uniform1i(this._draw_modeLocation, this._lastMode);
153
- gl.uniform1f(this._edgeCountLocation, this._lastEdgeCount);
154
- gl.uniform1f(this._plugin_alpha_multiplierLocation, 1.0);
155
- this.cameraBlockBindingPoint = 0;
156
- this.cameraBlockTotem = programcache_1.globeProgramCache.getProgram(globe, totems_1.CameraUniformBlockTotem);
157
- const cameraBlockIndex = gl.getUniformBlockIndex(program, "CameraUniformBlock");
158
- gl.uniformBlockBinding(program, cameraBlockIndex, this.cameraBlockBindingPoint);
159
- gl.useProgram(currentProgram);
160
- }
161
- }
162
- draw(length, vao, edgeCount, alphaMultiplier, drawMode) {
163
- const { gl, program, cameraBlockTotem, cameraBlockBindingPoint } = this;
164
- // gl.disable(gl.DEPTH_TEST);
165
- gl.useProgram(program);
166
- if (drawMode !== this._lastMode) {
167
- gl.uniform1i(this._draw_modeLocation, drawModeMap[drawMode]);
168
- this._lastMode = drawMode;
169
- }
170
- if (edgeCount !== this._lastEdgeCount) {
171
- gl.uniform1f(this._edgeCountLocation, edgeCount);
172
- this._lastEdgeCount = edgeCount;
173
- }
174
- if (alphaMultiplier !== this._lastAlphaMultiplier) {
175
- gl.uniform1f(this._plugin_alpha_multiplierLocation, alphaMultiplier);
176
- this._lastAlphaMultiplier = alphaMultiplier;
177
- }
178
- const overdraw = drawModeMap[drawMode];
179
- cameraBlockTotem.bind(cameraBlockBindingPoint);
180
- gl.bindVertexArray(vao);
181
- gl.drawArraysInstanced(gl[drawMode], 0, edgeCount + overdraw, length);
182
- cameraBlockTotem.unbind(cameraBlockBindingPoint);
183
- gl.bindVertexArray(null);
184
- // gl.enable(gl.DEPTH_TEST);
185
- }
186
- free() {
187
- programcache_1.noRegisterGlobeProgramCache.releaseProgram(this.globe, totems_1.CameraUniformBlockTotem);
188
- this.gl.deleteProgram(this.program);
189
- this.program = null;
190
- }
191
- /**
192
- * in vec2 center; // long, lat in radian
193
- in float start_angle; // the start of partial circle from bearing point
194
- in float tail_angle; // the rotation of the partial circle
195
- in vec4 color;
196
- in float radius; // in meter
197
- in float color_mode; // 0.0: constant, 1.0: fading, 2.0: hide
198
- */
199
- createVAO(center2dObj, center3dObj, startAngle2DObj, tailAngle2DObj, startAngle3DObj, tailAngle3DObj, colorObj, radiusObj, colorModeObj) {
200
- const { gl } = this;
201
- const vao = gl.createVertexArray();
202
- gl.bindVertexArray(vao);
203
- {
204
- const { buffer, stride, offset } = center2dObj;
205
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
206
- gl.enableVertexAttribArray(0);
207
- gl.vertexAttribPointer(0, 2, gl.FLOAT, false, stride, offset);
208
- gl.vertexAttribDivisor(0, 1);
209
- }
210
- {
211
- const { buffer, stride, offset } = center3dObj;
212
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
213
- gl.enableVertexAttribArray(1);
214
- gl.vertexAttribPointer(1, 3, gl.FLOAT, false, stride, offset);
215
- gl.vertexAttribDivisor(1, 1);
216
- }
217
- {
218
- const { buffer, stride, offset } = startAngle2DObj;
219
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
220
- gl.enableVertexAttribArray(2);
221
- gl.vertexAttribPointer(2, 1, gl.FLOAT, false, stride, offset);
222
- gl.vertexAttribDivisor(2, 1);
223
- }
224
- {
225
- const { buffer, stride, offset } = tailAngle2DObj;
226
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
227
- gl.enableVertexAttribArray(3);
228
- gl.vertexAttribPointer(3, 1, gl.FLOAT, false, stride, offset);
229
- gl.vertexAttribDivisor(3, 1);
230
- }
231
- {
232
- const { buffer, stride, offset } = startAngle3DObj;
233
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
234
- gl.enableVertexAttribArray(4);
235
- gl.vertexAttribPointer(4, 1, gl.FLOAT, false, stride, offset);
236
- gl.vertexAttribDivisor(4, 1);
237
- }
238
- {
239
- const { buffer, stride, offset } = tailAngle3DObj;
240
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
241
- gl.enableVertexAttribArray(5);
242
- gl.vertexAttribPointer(5, 1, gl.FLOAT, false, stride, offset);
243
- gl.vertexAttribDivisor(5, 1);
244
- }
245
- {
246
- const { buffer, stride, offset } = colorObj;
247
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
248
- gl.enableVertexAttribArray(6);
249
- gl.vertexAttribPointer(6, 4, gl.FLOAT, false, stride, offset);
250
- gl.vertexAttribDivisor(6, 1);
251
- }
252
- {
253
- const { buffer, stride, offset } = radiusObj;
254
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
255
- gl.enableVertexAttribArray(7);
256
- gl.vertexAttribPointer(7, 1, gl.FLOAT, false, stride, offset);
257
- gl.vertexAttribDivisor(7, 1);
258
- }
259
- {
260
- const { buffer, stride, offset } = colorModeObj;
261
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
262
- gl.enableVertexAttribArray(8);
263
- gl.vertexAttribPointer(8, 1, gl.FLOAT, false, stride, offset);
264
- gl.vertexAttribDivisor(8, 1);
265
- }
266
- gl.bindVertexArray(null);
267
- gl.bindBuffer(gl.ARRAY_BUFFER, null);
268
- return vao;
269
- }
270
- }
271
- exports.Logic = Logic;
272
- exports.PieceOfPieProgramCache = Object.freeze({
273
- get: (globe) => programcache_1.noRegisterGlobeProgramCache.getProgram(globe, Logic),
274
- release: (globe) => programcache_1.noRegisterGlobeProgramCache.releaseProgram(globe, Logic)
275
- });