@pirireis/webglobeplugins 0.16.7 → 0.17.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (159) hide show
  1. package/Math/angle-calculation.js +1 -0
  2. package/Math/contour/quadtreecontours.js +300 -0
  3. package/Math/finite-line-2d.js +58 -0
  4. package/Math/methods.js +6 -0
  5. package/Math/tessellation/hybrid-triangle-tessellation-meta.js +123 -0
  6. package/Math/tessellation/tile-merger.js +298 -0
  7. package/Math/tessellation/triangle-tessellation-meta.js +195 -42
  8. package/Math/tessellation/triangle-tessellation.js +5 -1
  9. package/compass-rose/compass-text-writer.js +39 -33
  10. package/constants.js +3 -0
  11. package/{util/heatwavedatamanager → heatwave}/datamanager.js +1 -1
  12. package/heatwave/{plugins/heatwaveglobeshell.js → heatwave.js} +8 -6
  13. package/heatwave/index.js +5 -3
  14. package/heatwave/{isobar/plugin.js → isobar.js} +6 -5
  15. package/{util/heatwavedatamanager → heatwave}/texture-point-sampler.js +24 -3
  16. package/investigation-tools/draw/tiles/adapters.js +67 -0
  17. package/investigation-tools/draw/tiles/tiles.js +128 -0
  18. package/package.json +4 -2
  19. package/programs/arrowfield/{object.js → arrow-field.js} +1 -1
  20. package/programs/arrowfield/logic.js +1 -1
  21. package/programs/data2legend/density-to-legend.js +24 -29
  22. package/programs/data2legend/point-to-density-texture.js +14 -17
  23. package/programs/float2legendwithratio/logic.js +2 -2
  24. package/programs/float2legendwithratio/object.js +1 -1
  25. package/programs/helpers/{blender/program.js → blender.js} +1 -1
  26. package/programs/helpers/{fadeaway/logic.js → fadeaway.js} +11 -2
  27. package/programs/index.js +20 -9
  28. package/programs/line-on-globe/circle-accurate-3d.js +12 -14
  29. package/programs/line-on-globe/circle-accurate-flat.js +0 -1
  30. package/programs/line-on-globe/degree-padding-around-circle-3d.js +13 -15
  31. package/programs/line-on-globe/lines-color-instanced-flat.js +15 -18
  32. package/programs/line-on-globe/naive-accurate-flexible.js +0 -1
  33. package/programs/picking/pickable-polygon-renderer.js +1 -1
  34. package/programs/picking/pickable-renderer.js +2 -2
  35. package/programs/point-on-globe/element-globe-surface-glow.js +2 -2
  36. package/programs/point-on-globe/element-point-glow.js +1 -1
  37. package/programs/point-on-globe/square-pixel-point.js +1 -1
  38. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin-triangle.js +180 -30
  39. package/programs/polygon-on-globe/texture-dem-triangles.js +93 -34
  40. package/programs/rings/partial-ring/piece-of-pie.js +26 -29
  41. package/programs/totems/camerauniformblock.js +31 -42
  42. package/programs/two-d/pixel-padding-for-compass.js +14 -24
  43. package/programs/vectorfields/logics/drawrectangleparticles.js +9 -8
  44. package/programs/vectorfields/logics/drawrectangleparticles1.js +112 -0
  45. package/programs/vectorfields/logics/pixelbased.js +1 -2
  46. package/programs/vectorfields/pingpongbuffermanager.js +1 -1
  47. package/range-tools-on-terrain/bearing-line/adapters.js +1 -1
  48. package/range-tools-on-terrain/circle-line-chain/adapters.js +0 -5
  49. package/range-tools-on-terrain/circle-line-chain/plugin.js +1 -1
  50. package/range-tools-on-terrain/range-ring/plugin.js +4 -6
  51. package/semiplugins/lightweight/line-plugin.js +0 -1
  52. package/semiplugins/shape-on-terrain/arc-plugin.js +9 -2
  53. package/semiplugins/shape-on-terrain/circle-plugin.js +2 -2
  54. package/semiplugins/shape-on-terrain/padding-1-degree.js +1 -1
  55. package/semiplugins/shell/bbox-renderer/index.js +2 -0
  56. package/{programs/globeshell/wiggle → semiplugins/shell/bbox-renderer}/logic.js +101 -102
  57. package/{programs/globeshell/wiggle → semiplugins/shell/bbox-renderer}/object.js +6 -7
  58. package/semiplugins/utility/container-plugin.js +94 -0
  59. package/semiplugins/utility/object-pass-container-plugin.js +80 -0
  60. package/{point-heat-map → tracks/point-heat-map}/adaptors/timetracksplugin-format-to-this.js +1 -1
  61. package/{point-heat-map → tracks/point-heat-map}/plugin-webworker.js +3 -3
  62. package/{point-heat-map → tracks/point-heat-map}/point-to-heat-map-flow.js +11 -14
  63. package/{point-tracks → tracks/point-tracks}/plugin.js +6 -5
  64. package/{timetracks → tracks/timetracks}/adaptors-line-strip.js +1 -1
  65. package/{timetracks → tracks/timetracks}/program-line-strip.js +49 -49
  66. package/{timetracks → tracks/timetracks}/programpoint-line-strip.js +16 -13
  67. package/types.js +6 -0
  68. package/util/account/bufferoffsetmanager.js +1 -1
  69. package/util/account/single-attribute-buffer-management/buffer-orchestrator.js +9 -95
  70. package/util/gl-util/uniform-block/manager.js +0 -1
  71. package/util/gl-util/uniform-block/types.js +0 -7
  72. package/util/index.js +10 -13
  73. package/util/picking/fence.js +16 -18
  74. package/util/picking/picker-displayer.js +6 -8
  75. package/util/programs/{shapesonglobe.js → draw-from-pixel-coords.js} +4 -7
  76. package/util/programs/draw-texture-on-canvas.js +1 -1
  77. package/util/programs/texturetoglobe.js +3 -3
  78. package/util/shaderfunctions/geometrytransformations.js +1 -1
  79. package/vectorfield/arrowfield/index.js +3 -0
  80. package/{arrowfield → vectorfield/arrowfield}/plugin.js +2 -2
  81. package/{waveparticles → vectorfield/waveparticles}/plugin.js +12 -12
  82. package/{wind → vectorfield/wind}/index.js +1 -1
  83. package/{wind → vectorfield/wind}/plugin.js +65 -51
  84. package/write-text/context-text3.js +0 -1
  85. package/write-text/context-text4.js +2 -1
  86. package/write-text/objectarraylabels/index.js +2 -0
  87. package/Math/tessellation/tessellation-algorithm.js +0 -67
  88. package/arrowfield/index.js +0 -3
  89. package/bearing-line/index.js +0 -2
  90. package/bearing-line/plugin.js +0 -444
  91. package/circle-line-chain/chain-list-map.js +0 -201
  92. package/circle-line-chain/init.js +0 -1
  93. package/circle-line-chain/plugin.js +0 -411
  94. package/circle-line-chain/util.js +0 -1
  95. package/compassrose/compassrose.js +0 -293
  96. package/compassrose/index.js +0 -2
  97. package/index.js +0 -12
  98. package/partialrings/buffer-manager.js +0 -75
  99. package/partialrings/index.js +0 -2
  100. package/partialrings/plugin.js +0 -128
  101. package/partialrings/program.js +0 -279
  102. package/programs/arrowfield/index.js +0 -2
  103. package/programs/globe-util/is-globe-moved.js +0 -19
  104. package/programs/globeshell/index.js +0 -2
  105. package/programs/globeshell/wiggle/index.js +0 -2
  106. package/programs/helpers/blender/index.js +0 -1
  107. package/programs/helpers/fadeaway/index.js +0 -2
  108. package/programs/helpers/fadeaway/object.js +0 -14
  109. package/programs/helpers/index.js +0 -2
  110. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin.js +0 -118
  111. package/programs/rings/distancering/circleflatprogram.js +0 -116
  112. package/programs/rings/distancering/circlepaddingfreeangleprogram.js +0 -326
  113. package/programs/rings/distancering/circlepaddysharedbuffer.js +0 -368
  114. package/programs/rings/distancering/index.js +0 -6
  115. package/programs/rings/distancering/paddyflatprogram.js +0 -127
  116. package/programs/rings/distancering/paddyflatprogram2d.js +0 -129
  117. package/programs/rings/distancering/paddyflatprogram3d.js +0 -128
  118. package/programs/two-d/pixel-circle.js +0 -1
  119. package/programs/vectorfields/index.js +0 -3
  120. package/rangerings/enum.js +0 -2
  121. package/rangerings/index.js +0 -5
  122. package/rangerings/plugin.js +0 -543
  123. package/rangerings/rangeringangletext.js +0 -326
  124. package/rangerings/ring-account.js +0 -112
  125. package/timetracks/index.js +0 -1
  126. package/util/build-strategy/general-strategy.js +0 -62
  127. package/util/gl-util/uniform-block/shader.js +0 -1
  128. package/util/heatwavedatamanager/index.js +0 -2
  129. package/util/heatwavedatamanager/pointcoordsmeta.js +0 -22
  130. package/util/jshelpers/data-filler.js +0 -17
  131. package/util/jshelpers/equality.js +0 -18
  132. package/util/jshelpers/index.js +0 -2
  133. package/util/jshelpers/timefilters.js +0 -30
  134. package/util/programs/index.js +0 -1
  135. package/util/surface-line-data/arc-bboxes.js +0 -25
  136. package/util/surface-line-data/arcs-to-cuts.js +0 -50
  137. package/util/surface-line-data/cut-arc.js +0 -1
  138. package/util/surface-line-data/flow.js +0 -28
  139. package/util/surface-line-data/rbush-manager.js +0 -1
  140. package/util/surface-line-data/types.js +0 -1
  141. package/util/surface-line-data/web-worker.js +0 -1
  142. package/util/webglobe/rasteroverlay.js +0 -75
  143. package/write-text/attached-text-writer.js +0 -87
  144. package/write-text/context-text3old.js +0 -152
  145. package/write-text/index.js +0 -1
  146. package/write-text/writer-plugin.js +0 -8
  147. /package/{heatwave/isobar/quadtreecontours.js → Math/contour/quadtreecontours1.js} +0 -0
  148. /package/pin/{pin-object-array.js → pin-object-array1.js} +0 -0
  149. /package/pin/{pin-point-totem.js → pin-point-totem1.js} +0 -0
  150. /package/{point-heat-map → tracks/point-heat-map}/index.js +0 -0
  151. /package/{point-tracks → tracks/point-tracks}/key-methods.js +0 -0
  152. /package/{timetracks → tracks/timetracks}/plugin-line-strip.js +0 -0
  153. /package/{arrowfield → vectorfield/arrowfield}/adaptor.js +0 -0
  154. /package/{waveparticles → vectorfield/waveparticles}/adaptor.js +0 -0
  155. /package/{waveparticles → vectorfield/waveparticles}/index.js +0 -0
  156. /package/{wind → vectorfield/wind}/imagetovectorfieldandmagnitude.js +0 -0
  157. /package/{wind → vectorfield/wind}/vectorfieldimage.js +0 -0
  158. /package/write-text/{context-text.js → context-textDELETE.js} +0 -0
  159. /package/{heatwave/isobar → write-text/objectarraylabels}/objectarraylabels.js +0 -0
@@ -1,444 +0,0 @@
1
- import { PieceOfPieProgramCache } from '../programs/rings/partial-ring/piece-of-pie';
2
- import { LineOnGlobeCache } from '../programs/line-on-globe/naive-accurate-flexible';
3
- import { CircleCache as Circle3DCache } from '../programs/line-on-globe/circle-accurate-3d';
4
- import { CircleCache, EDGE_COUNT as flatCircleEdgeCount, centerCoords2dflatDataCreator } from '../programs/line-on-globe/circle-accurate-flat';
5
- import { BufferOrchestrator, BufferManager } from '../util/account';
6
- import { populateFloat32Array } from "../util/jshelpers/data-filler";
7
- import { ContextTextWriter3 } from '../write-text/context-text3';
8
- import { constraintFloat, isBoolean, mapGetOrThrow } from '../util/check/typecheck';
9
- import { sphereCoord } from '../util/geometry';
10
- import { createBufferAndReadInfo } from '../util/gl-util/buffer/attribute-loader';
11
- export const RINGPARTIAL_DRAW_MODE = Object.freeze({
12
- LINE_STRIP: "LINE_STRIP",
13
- TRIANGLE_FAN: "TRIANGLE_FAN",
14
- });
15
- /**
16
- * @typedef {{key, long, lat, endLong, endLat, bearingAngle, radius, rgba:[4numbers], rgbaMode, bigRadius, dashRatio, dashOpacity, circleDashAngle}} BearingLineItem
17
- * @property {string} key
18
- * @property {number} long
19
- * @property {number} lat
20
- * @property {number} endLong
21
- * @property {number} endLat
22
- * @property {number} bearingAngle 0-360
23
- * @property {number} radius angle ring radius
24
- * @property {number} altitude in meters effects all parts of the item
25
- * @property {Array<numbers>} rgba [r,g,b,a] 0-1
26
- * @property {number} rgbaMode 0 constant, 1 fading, 2 hides angle ring
27
- * @property {number} bigRadius undefined means it will be calculated from long, lat, endLong, endLat
28
- * @property {number} dashRatio 0-1
29
- * @property {number} dashOpacity 0-1
30
- * @property {number} circleDashAngle 0-360
31
- */
32
- const textWriterGetOrThrow = mapGetOrThrow("BearingLine textContextInjection id does not exist in map");
33
- const radian = (degree) => degree * Math.PI / 180;
34
- const integralSec = (angle) => {
35
- return Math.log(Math.tan(angle / 2 + Math.PI / 4));
36
- };
37
- const calculateStartAngle = (long, lat, endLong, endLat) => {
38
- const dLat = (integralSec(endLat) - integralSec(lat)); // Because lines are strectes toward poles.
39
- const dLong = endLong - long;
40
- let angle = -Math.atan2(dLat, dLong);
41
- return angle;
42
- };
43
- export default class BearingLinePlugin {
44
- /**
45
- * @param {*} id
46
- * @param {Map<[key, ContextTextWriter3]>} textWritersMap
47
- */
48
- constructor(id, { opacity = 1, textWritersMap = new Map(), textDataPreAdaptor = (x) => x, drawVRM = true, drawBearingLine = true, drawAngleRing = true, drawText = true, circleFlatEdgeCount = flatCircleEdgeCount - 2 } = {}) {
49
- this.id = id;
50
- this._opacity = opacity;
51
- this.bufferOrchestrator = new BufferOrchestrator({ capacity: 10 });
52
- this._checkTextContextWriterInjectionMap(textWritersMap);
53
- this._textWritersMap = textWritersMap;
54
- this._textWritersMap.forEach((writer) => writer.keyAdaptor = (item) => item.key);
55
- this.drawVRM = drawVRM;
56
- this.drawBearingLine = drawBearingLine;
57
- this.drawAngleRing = drawAngleRing;
58
- this._textDataPreAdaptor = textDataPreAdaptor;
59
- this.drawText = drawText;
60
- this._memoryForText = new Map();
61
- this.circleFlatEdgeCount = circleFlatEdgeCount + 2;
62
- }
63
- setDoDrawVRM(bool) {
64
- isBoolean(bool);
65
- if (bool === this.drawVRM)
66
- return;
67
- this.drawVRM = bool;
68
- this.globe.DrawRender();
69
- }
70
- setDoDrawText(bool) {
71
- isBoolean(bool);
72
- if (bool === this.drawText)
73
- return;
74
- this.drawText = bool;
75
- this.globe.DrawRender();
76
- }
77
- setDoDrawText(bool) {
78
- isBoolean(bool);
79
- if (bool === this.drawText)
80
- return;
81
- this.drawText = bool;
82
- this.globe.DrawRender();
83
- }
84
- setDoDrawAngleRing(bool) {
85
- isBoolean(bool);
86
- if (bool === this.drawAngleRing)
87
- return;
88
- this.drawAngleRing = bool;
89
- this.globe.DrawRender();
90
- }
91
- setOpacity(opacity) {
92
- constraintFloat(opacity, 0, 1);
93
- this._opacity = opacity;
94
- this._textWritersMap.forEach((writer) => writer.setOpacity(opacity));
95
- this.globe.DrawRender();
96
- }
97
- /**
98
-
99
- * @param {Array<BearingLineItem>} items
100
- * @param {Array<string>} textWriterIDs | textWritersMap keys to be used for writing text.
101
- */
102
- insertBulk(items, { textWriterIDs = [] } = {}) {
103
- const { globe, bufferOrchestrator, bufferManagersCompMap } = this; // angleTextContext, distanceTextContext,
104
- const data = [];
105
- for (let item of items) {
106
- data.push(this.__insertAdaptor(item));
107
- }
108
- bufferOrchestrator.insertBulk(data, bufferManagersCompMap);
109
- this.__insertTexts(items, textWriterIDs);
110
- globe.DrawRender();
111
- }
112
- /**
113
- * @param {Array<string>} textWriterIDs | textWritersMap keys to be used for writing text.
114
- * @param {Array<string>} itemKeys | if empty, all texts will be updated.
115
- */
116
- updateText(textWriterIDs = [], itemKeys = null) {
117
- const textWritersMap = textWriterGetOrThrow(this._textWritersMap, textWriterIDs);
118
- if (itemKeys === null) {
119
- this._memoryForText.forEach((item) => {
120
- let _item = this._textDataPreAdaptor(item);
121
- textWritersMap.forEach((writer) => writer.insertText(_item));
122
- });
123
- }
124
- else {
125
- itemKeys.forEach((key) => {
126
- let item = this._memoryForText.get(key);
127
- if (item === undefined)
128
- return;
129
- let _item = this._textDataPreAdaptor(item);
130
- textWritersMap.forEach((writer) => writer.insertText(_item));
131
- });
132
- }
133
- this.globe.DrawRender();
134
- }
135
- deleteBulk(keys) {
136
- this.bufferOrchestrator.deleteBulk(keys, this.bufferManagersCompMap);
137
- for (const key of keys) {
138
- this._memoryForText.delete(key);
139
- }
140
- this._deleteTexts(keys);
141
- this.globe.DrawRender();
142
- }
143
- defrag() {
144
- this.bufferOrchestrator.defrag(this.bufferManagersCompMap);
145
- }
146
- /**
147
- * @param {Array<{key, long, lat, endLong, endLat, bearingAngle}>} items
148
- * @param {Array<string>} textWriterIDs | textWritersMap keys to be used for writing text.
149
- */
150
- updateCoordinatesBulk(items, { textWriterIDs = [] } = {}) {
151
- const { globe, bufferOrchestrator, bufferManagersCompMap, } = this;
152
- const data = [];
153
- for (let item of items) {
154
- data.push(this.__updateCoordsAdaptor(item));
155
- }
156
- this.__insertTexts(items, textWriterIDs);
157
- bufferOrchestrator.updateBulk(data, bufferManagersCompMap, ["centerCoords2d", "centerCoords3d", "targetCoords2d", "targetCoords3d",
158
- "startAngle2d", "tailAngle2d", "startAngle3d", "tailAngle3d", "bearingTargetCoords2d", "bearingTargetCoords3d", "centerCoords2dflat",
159
- "bigRadius", "radius"]);
160
- globe.DrawRender();
161
- }
162
- /**
163
- *
164
- * @param {Array<BearingLineItem>} items some colums EXCEPT positional ones
165
- * @param {string} propertyIDs
166
- * @param {string} textWriterIDs
167
- * Do NOT send empty data if property ID of this data is entered or NaN is loaded to the buffer, resulting in an unwanted behaviour.
168
- *{ textWriterIDs = []}
169
- */
170
- updatePartial(items, propertyIDs = [], { textWriterIDs = [] } = {}) {
171
- if (propertyIDs.length === 0)
172
- console.warn("updatePartial is called with no target propertyIDs");
173
- const fixedPropertyIDs = this.__fixPartialProperties(propertyIDs);
174
- const { bufferOrchestrator, bufferManagersCompMap } = this;
175
- bufferOrchestrator.updateBulk(items, bufferManagersCompMap, fixedPropertyIDs);
176
- // patch to update text opacity
177
- this.__insertTexts(items, textWriterIDs);
178
- this.globe.DrawRender();
179
- }
180
- // Private methods
181
- _checkTextContextWriterInjectionMap(textContextWriterInjectionMap) {
182
- if (!(textContextWriterInjectionMap instanceof Map))
183
- throw new Error("textContextWriterInjectionMap is not an instance of Map");
184
- textContextWriterInjectionMap.forEach((v) => {
185
- if (!(v instanceof ContextTextWriter3))
186
- throw new Error("textContextWriterInjectionMap element is not an instance of ContextTextWriter3");
187
- });
188
- }
189
- __insertTexts(items, textWriterIDs) {
190
- const textWritersMap = textWriterGetOrThrow(this._textWritersMap, textWriterIDs);
191
- for (const item of items) {
192
- const oldItem = this._memoryForText.get(item.key);
193
- let _item = oldItem !== undefined ? { ...oldItem, ...item } : item;
194
- this._memoryForText.set(item.key, _item);
195
- if (this._textDataPreAdaptor !== null)
196
- _item = this._textDataPreAdaptor(_item);
197
- textWritersMap.forEach((writer) => writer.insertText(_item));
198
- }
199
- }
200
- __insertAdaptor(item) {
201
- const rgba = item.rgba !== undefined ? item.rgba : [0, 0, 0, 0];
202
- const rgbaMode = item.rgbaMode !== undefined ? item.rgbaMode : 0;
203
- const dashRatio = item.dashRatio !== undefined ? item.dashRatio : 1.0;
204
- const dashOpacity = item.dashOpacity !== undefined ? item.dashOpacity : 0.9;
205
- const circleDashAngle = item.circleDashAngle !== undefined ? item.circleDashAngle : 360;
206
- const coordsData = this.__updateCoordsAdaptor(item);
207
- return {
208
- ...coordsData,
209
- rgba,
210
- dashRatio,
211
- dashOpacity,
212
- circleDashAngle,
213
- rgbaMode
214
- };
215
- }
216
- __updateCoordsAdaptor(item) {
217
- const { globe } = this;
218
- const lat = radian(item.lat);
219
- const long = radian(item.long);
220
- const endLat = radian(item.endLat);
221
- const endLong = radian(item.endLong);
222
- const altitude = (item.altitude ?? 0) / 1000;
223
- const bigRadius = item.bigRadius ?? globe.Math.GetDist2D(item.long, item.lat, item.endLong, item.endLat);
224
- const radius = item.radius !== undefined ? item.radius : bigRadius * 0.2;
225
- const { long: bearingLong, lat: bearingLat } = globe.Math.FindPointByPolar(item.long, item.lat, bigRadius, item.bearingAngle);
226
- const startAngle2d = calculateStartAngle(long, lat, endLong, endLat);
227
- const bearingAngle2d = calculateStartAngle(long, lat, radian(bearingLong), radian(bearingLat));
228
- let tailAngle2d = bearingAngle2d - startAngle2d;
229
- if (tailAngle2d > 0) {
230
- tailAngle2d -= Math.PI * 2;
231
- }
232
- const bearingAngle = radian(item.bearingAngle - 90);
233
- const startAngleOfCircle = globe.Math.GetAzimuthAngle(item.long, item.lat, item.endLong, item.endLat); //startAngle2d * 180 / Math.PI;
234
- const startAngle3d = radian(startAngleOfCircle) - radian(90);
235
- let tailAngle3d = bearingAngle - startAngle3d;
236
- if (tailAngle3d > 0) {
237
- tailAngle3d -= Math.PI * 2;
238
- }
239
- const centerCoords2dflat = centerCoords2dflatDataCreator(globe, item.long, item.lat, item.endLong, item.endLat, { startAngleOfCircle, edgeCount: this.circleFlatEdgeCount });
240
- return {
241
- key: item.key,
242
- lat: item.lat,
243
- long: item.long,
244
- endLat: item.endLat,
245
- endLong: item.endLong,
246
- altitude,
247
- bearingAngle,
248
- radius,
249
- bigRadius,
250
- startAngle2d,
251
- tailAngle2d,
252
- startAngle3d,
253
- tailAngle3d,
254
- bearingLong,
255
- bearingLat,
256
- centerCoords2dflat
257
- };
258
- }
259
- __fixPartialProperties(propertyIDs) {
260
- const s = new Set(["rgba", "dashOpacity", "circleDashAngle"]);
261
- const result = [];
262
- for (const item of propertyIDs) {
263
- result.push(item);
264
- if (s.has(item)) {
265
- result.push(item + "Mercator");
266
- }
267
- }
268
- return result;
269
- }
270
- // Globe API
271
- init(globe, gl) {
272
- this.gl = gl;
273
- this.globe = globe;
274
- this.lineProgram = LineOnGlobeCache.get(globe);
275
- this.pieceOfPieProgram = PieceOfPieProgramCache.get(globe);
276
- this.circleProgram = CircleCache.get(globe);
277
- this.circle3DProgram = Circle3DCache.get(globe);
278
- const circleFlatEdgeCount = this.circleFlatEdgeCount;
279
- {
280
- // createBuffers
281
- const bufferType = "DYNAMIC_DRAW";
282
- const initialCapacity = this.bufferOrchestrator.capacity;
283
- this.bufferManagersCompMap = new Map([
284
- ["centerCoords2d", {
285
- 'bufferManager': new BufferManager(gl, 2, { bufferType, initialCapacity }),
286
- 'adaptor': (item) => new Float32Array(globe.api_GetMercator2DPoint(item.long, item.lat)),
287
- }],
288
- ["centerCoords2dflat", {
289
- 'bufferManager': new BufferManager(gl, circleFlatEdgeCount * 2, { bufferType, initialCapacity }),
290
- 'adaptor': (item) => item.centerCoords2dflat,
291
- }],
292
- ["centerCoords3d", {
293
- 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
294
- 'adaptor': (item) => sphereCoord(item.long, item.lat, globe, item.altitude),
295
- }],
296
- ["targetCoords2d", {
297
- 'bufferManager': new BufferManager(gl, 2, { bufferType, initialCapacity }),
298
- 'adaptor': (item) => new Float32Array(globe.api_GetMercator2DPoint(item.endLong, item.endLat))
299
- }],
300
- ["targetCoords3d", {
301
- 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
302
- 'adaptor': (item) => sphereCoord(item.endLong, item.endLat, globe, item.altitude)
303
- }],
304
- ["bearingTargetCoords2d", {
305
- 'bufferManager': new BufferManager(gl, 2, { bufferType, initialCapacity }),
306
- 'adaptor': (item) => new Float32Array(globe.api_GetMercator2DPoint(item.bearingLong, item.bearingLat))
307
- }],
308
- ["bearingTargetCoords3d", {
309
- 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
310
- 'adaptor': (item) => sphereCoord(item.bearingLong, item.bearingLat, globe, item.altitude)
311
- }],
312
- ["startAngle2d", {
313
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
314
- 'adaptor': (item) => new Float32Array([item.startAngle2d])
315
- }],
316
- ["tailAngle2d", {
317
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
318
- 'adaptor': (item) => new Float32Array([item.tailAngle2d])
319
- }],
320
- ["startAngle3d", {
321
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
322
- 'adaptor': (item) => new Float32Array([item.startAngle3d])
323
- }],
324
- ["tailAngle3d", {
325
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
326
- 'adaptor': (item) => new Float32Array([item.tailAngle3d])
327
- }],
328
- ["bearingDashRatio", {
329
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
330
- 'adaptor': (item) => new Float32Array([0])
331
- }],
332
- ["rgba", {
333
- 'bufferManager': new BufferManager(gl, 4, { bufferType, initialCapacity }),
334
- 'adaptor': (item) => new Float32Array(item.rgba)
335
- }],
336
- ["radius", {
337
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
338
- 'adaptor': (item) => new Float32Array([item.radius])
339
- }],
340
- ["rgbaMode", {
341
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
342
- 'adaptor': (item) => new Float32Array([item.rgbaMode])
343
- }],
344
- ["dashRatio", {
345
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
346
- 'adaptor': (item) => new Float32Array([item.dashRatio])
347
- }],
348
- ["bigRadius", {
349
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
350
- 'adaptor': (item) => new Float32Array([item.bigRadius])
351
- }],
352
- ["dashOpacity", {
353
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
354
- 'adaptor': (item) => new Float32Array([item.dashOpacity]),
355
- }],
356
- ["circleDashAngle", {
357
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
358
- 'adaptor': (item) => new Float32Array([item.circleDashAngle / 360]),
359
- }],
360
- // Mercator circle properties are duplicated for the sake of performance.
361
- ["rgbaMercator", {
362
- 'bufferManager': new BufferManager(gl, 4 * circleFlatEdgeCount, { bufferType, initialCapacity }),
363
- 'adaptor': (item) => populateFloat32Array.fillWithListData(circleFlatEdgeCount, item.rgba),
364
- }],
365
- ["circleDashAngleMercator", {
366
- 'bufferManager': new BufferManager(gl, circleFlatEdgeCount, { bufferType, initialCapacity }),
367
- 'adaptor': (item) => populateFloat32Array.fillFloat32Array(circleFlatEdgeCount, item.circleDashAngle / 360),
368
- }],
369
- ["dashOpacityMercator", {
370
- 'bufferManager': new BufferManager(gl, circleFlatEdgeCount, { bufferType, initialCapacity }),
371
- 'adaptor': (item) => populateFloat32Array.fillFloat32Array(circleFlatEdgeCount, item.dashOpacity),
372
- }],
373
- ]);
374
- }
375
- const vaoOBJ = (key) => createBufferAndReadInfo(this.bufferManagersCompMap.get(key).bufferManager.buffer);
376
- this.lineVao = this.lineProgram.createVAO(...['centerCoords2d', 'centerCoords3d', 'targetCoords2d', 'targetCoords3d', 'dashOpacity', 'dashOpacity', 'rgba'].map(key => vaoOBJ(key)));
377
- this.ringVao = this.pieceOfPieProgram.createVAO(...['centerCoords2d',
378
- 'centerCoords3d',
379
- 'startAngle2d',
380
- 'tailAngle2d',
381
- 'startAngle3d',
382
- 'tailAngle3d',
383
- 'rgba',
384
- 'radius',
385
- 'rgbaMode'].map(key => vaoOBJ(key)));
386
- this.bearingLineVAO = this.lineProgram.createVAO(...['centerCoords2d', 'centerCoords3d', 'bearingTargetCoords2d', 'bearingTargetCoords3d', 'bearingDashRatio', 'dashOpacity', 'rgba'
387
- ].map(key => vaoOBJ(key)));
388
- this.circleVao = this.circleProgram.createVAO(...["centerCoords2dflat", "rgbaMercator", "circleDashAngleMercator", "dashOpacityMercator"
389
- ].map(key => vaoOBJ(key)));
390
- this.circle3DVao = this.circle3DProgram.createVAO(...["centerCoords3d", "targetCoords3d", "rgba", "circleDashAngle", "dashOpacity"
391
- ].map(key => vaoOBJ(key)));
392
- }
393
- draw3D() {
394
- const { gl } = this;
395
- gl.disable(gl.DEPTH_TEST);
396
- const is3D = this.globe.api_GetCurrentGeometry() === 0;
397
- const drawRange = { first: 0, count: this.bufferOrchestrator.length };
398
- this.lineProgram.draw(this.lineVao, { drawRange }, this._opacity);
399
- if (this.drawAngleRing) {
400
- this.pieceOfPieProgram._defaultFlexibleUBO.updateSingle("u_opacity", this._opacity * 0.8);
401
- this.pieceOfPieProgram.draw(this.bufferOrchestrator.length, this.ringVao, 360, RINGPARTIAL_DRAW_MODE.TRIANGLE_FAN);
402
- this.pieceOfPieProgram.draw(this.bufferOrchestrator.length, this.ringVao, 360, RINGPARTIAL_DRAW_MODE.LINE_STRIP);
403
- }
404
- if (this.drawBearingLine) {
405
- // this.lineProgram.draw(this.bearingLineVAO, this.bufferOrchestrator.length, this._opacity );
406
- this.lineProgram.draw(this.bearingLineVAO, { drawRange }, this._opacity);
407
- }
408
- if (this.drawVRM) {
409
- if (is3D) {
410
- this.circle3DProgram.draw(this.circle3DVao, this.bufferOrchestrator.length, this._opacity);
411
- }
412
- else {
413
- this.circleProgram.draw(this.circleVao, this.bufferOrchestrator.length, this.circleFlatEdgeCount, this._opacity);
414
- }
415
- }
416
- if (this.drawText) {
417
- this._textWritersMap.forEach((writer) => writer.draw());
418
- }
419
- gl.enable(gl.DEPTH_TEST);
420
- }
421
- free() {
422
- if (this.isFreed)
423
- return;
424
- this.bufferManagersCompMap.forEach(({ bufferManager, adaptor }) => {
425
- bufferManager.free();
426
- });
427
- const { gl, globe } = this;
428
- gl.deleteVertexArray(this.lineVao);
429
- gl.deleteVertexArray(this.ringVao);
430
- gl.deleteVertexArray(this.bearingLineVAO);
431
- gl.deleteVertexArray(this.circleVao);
432
- gl.deleteVertexArray(this.circle3DVao);
433
- LineOnGlobeCache.release(globe);
434
- PieceOfPieProgramCache.release(globe);
435
- CircleCache.release(globe);
436
- Circle3DCache.release(globe);
437
- this.isFreed = true;
438
- }
439
- _deleteTexts(keys) {
440
- this._textWritersMap.forEach((writer) => {
441
- writer.deleteTextBulk(keys);
442
- });
443
- }
444
- }
@@ -1,201 +0,0 @@
1
- /**
2
- * set and get node data
3
- * node indexes;
4
- */
5
- export class ChainListMap {
6
- constructor(keyMethod) {
7
- this._chainMap = new Map();
8
- this._chainSideProperties = new Map();
9
- this._indexMap = new Map(); // hold list index of lastly updated nodes. on add delete goes empty
10
- this.keyMethod = keyMethod;
11
- }
12
- getChain(chainKey) {
13
- return this._chainMap.get(chainKey);
14
- }
15
- /**
16
- *
17
- * @param {*} node
18
- * @param {*} chainKey
19
- * @param {string|null} theNodeKeyFront
20
- */
21
- addNode(node, chainKey, theNodeKeyFront = null) {
22
- const chain = this.getChain(chainKey);
23
- let frontIndex = null;
24
- for (let i = 0; i < chain.length; i++) {
25
- const n_ode = chain[i];
26
- if (n_ode.key === node.key) {
27
- throw new Error("Chain node already exists");
28
- }
29
- if (n_ode.key === theNodeKeyFront) {
30
- frontIndex = i;
31
- }
32
- }
33
- if (theNodeKeyFront !== null) {
34
- if (frontIndex !== null) {
35
- chain.splice(frontIndex, 0, node);
36
- }
37
- else {
38
- throw new Error("Could not find theNodeKeyFront");
39
- }
40
- }
41
- else {
42
- chain.push(node);
43
- }
44
- node.__identity__ = this.keyMethod(chainKey, node.key);
45
- this._resetIndexChain(chainKey);
46
- }
47
- deleteNodesBelongToAChain(chainKey, nodeKeys) {
48
- const chain = this._chainMap.get(chainKey);
49
- const deleteKeys = [];
50
- const removeSet = new Set(nodeKeys);
51
- const newChain = [];
52
- for (let i = 0; i < chain.length - 1; i++) {
53
- const node = chain[i];
54
- const dKey = node.__identity__;
55
- this._indexMap.delete(dKey);
56
- if (removeSet.has(node.key)) {
57
- deleteKeys.push(dKey);
58
- }
59
- else {
60
- newChain.push(node);
61
- }
62
- }
63
- { // last item case
64
- const lastItem = chain[chain.length - 1];
65
- this._indexMap.delete(lastItem.__identity__);
66
- if (removeSet.has(lastItem.key)) {
67
- if (chain.length > 1) {
68
- deleteKeys.push(chain[chain.length - 2].__identity__);
69
- deleteKeys.push(chain[chain.length - 1].__identity__);
70
- }
71
- ;
72
- }
73
- else {
74
- newChain.push(lastItem);
75
- }
76
- }
77
- this._chainMap.set(chainKey, newChain);
78
- return deleteKeys;
79
- }
80
- deleteChainAndReturnChainKeys(chainKey) {
81
- const keys = this.getNodeKeysOfChain(chainKey);
82
- this._chainMap.delete(chainKey);
83
- for (const key of keys)
84
- this._indexMap.delete(key);
85
- return keys;
86
- }
87
- updateNode(node, chainKey) {
88
- const index = this.getIndexOfNode(chainKey, node.key);
89
- const chain = this._chainMap.get(chainKey);
90
- node.__identity__ = this.keyMethod(chainKey, node.key);
91
- chain[index] = node;
92
- }
93
- updateNodesProperties(chainKey, nodes) {
94
- nodes.forEach((node) => {
95
- const index = this.getIndexOfNode(chainKey, node.key);
96
- const chainNode = this._chainMap.get(chainKey)[index];
97
- if (node.circleProperties) {
98
- if (typeof chainNode.circleProperties !== 'object')
99
- chainNode.circleProperties = {};
100
- node.circleProperties.forEach((value, key, container) => chainNode.circleProperties[key] = value);
101
- }
102
- if (node.lineProperties) {
103
- if (typeof chainNode.lineProperties !== 'object')
104
- chainNode.lineProperties = {};
105
- node.lineProperties.forEach((value, key, container) => chainNode.lineProperties[key] = value);
106
- }
107
- });
108
- }
109
- updateCoordsinatesOfNode(node, chainKey) {
110
- const index = this.getIndexOfNode(chainKey, node.key);
111
- const chain = this._chainMap.get(chainKey);
112
- chain[index].long = node.long;
113
- chain[index].lat = node.lat;
114
- }
115
- setChain(chainKey, nodeList) {
116
- if (this._chainMap.has(chainKey))
117
- this._flushIndexMap();
118
- this._chainMap.set(chainKey, nodeList);
119
- nodeList.forEach((v) => v.__identity__ = this.keyMethod(chainKey, v.key));
120
- }
121
- setChainProperties(chainKey, properties) {
122
- this._chainSideProperties.set(chainKey, properties);
123
- }
124
- /**
125
- *
126
- * @param {string} chainKey
127
- * @param {Map} properties
128
- * // after this method update text and buffer data of the chain
129
- */
130
- updateChainProperties(chainKey, properties) {
131
- const memoryProperties = this._chainSideProperties.get(chainKey);
132
- properties.forEach((value, key, m) => {
133
- memoryProperties[key] = value;
134
- });
135
- }
136
- getChainProperties(chainKey) {
137
- this._chainSideProperties.get(chainKey);
138
- }
139
- /**
140
- *
141
- * @param {*} chainKey
142
- * @param {*} callback | (value, index, array) => expexted output
143
- */
144
- calculateBufferPropertiesChain(chainKey, callback, result) {
145
- const chain = this._chainMap.get(chainKey);
146
- const props = this._chainSideProperties.get(chainKey);
147
- for (let i = 0; i < chain.length - 1; i++) {
148
- const node = callback(chain[i], i, chain, props);
149
- if (node !== null)
150
- result.push(node);
151
- }
152
- }
153
- /**
154
- * @param {*} chainKey
155
- * @param {*} textWriterObjs
156
- * @param {*} nodeKeys use nodeKeys on updateCoordinatesOnly
157
- */
158
- textUpdate(chainKey, textWriterObjs, dataPreAdaptor) {
159
- const chain = this._chainMap.get(chainKey);
160
- if (!chain)
161
- return;
162
- const data = (dataPreAdaptor) ? chain.map(dataPreAdaptor) : chain;
163
- const properties = this._chainSideProperties.get(chainKey);
164
- textWriterObjs.forEach((writer) => {
165
- writer.insertTextBulk(data, properties);
166
- });
167
- }
168
- getAllChainKeysIterator() {
169
- return this._chainMap.keys();
170
- }
171
- getIndexOfNode(chainKey, nodeKey) {
172
- const key = this.keyMethod(chainKey, nodeKey);
173
- if (this._indexMap.has(key))
174
- return this._indexMap.get(key);
175
- const chain = this._chainMap.get(chainKey);
176
- for (let i = 0; i < chain.length; i++) {
177
- const node = chain[i];
178
- this._indexMap.set(key, i);
179
- if (node.key === nodeKey) {
180
- return i;
181
- }
182
- }
183
- }
184
- _flushIndexMap() {
185
- this._indexMap.clear();
186
- }
187
- _resetIndexChain(chainKey) {
188
- const chain = this._chainMap.get(chainKey);
189
- for (let i = 0; i < chain.length; i++) {
190
- const node = chain[i];
191
- this._indexMap.set(this.keyMethod(chainKey, node.key), i);
192
- }
193
- }
194
- getNodeKeysOfChain(chainKey) {
195
- const chain = this._chainMap.get(chainKey);
196
- if (!chain)
197
- return [];
198
- const result = chain.map((v) => v.__identity__);
199
- return result;
200
- }
201
- }
@@ -1 +0,0 @@
1
- "use strict";