@pirireis/webglobeplugins 0.16.7 → 0.17.0

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 (152) 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/tessellation/hybrid-triangle-tessellation-meta.js +123 -0
  5. package/Math/tessellation/tile-merger.js +56 -0
  6. package/Math/tessellation/triangle-tessellation-meta.js +178 -32
  7. package/Math/tessellation/triangle-tessellation.js +5 -1
  8. package/compass-rose/compass-text-writer.js +39 -33
  9. package/constants.js +3 -0
  10. package/{util/heatwavedatamanager → heatwave}/datamanager.js +1 -1
  11. package/heatwave/{plugins/heatwaveglobeshell.js → heatwave.js} +8 -6
  12. package/heatwave/index.js +5 -3
  13. package/heatwave/{isobar/plugin.js → isobar.js} +6 -5
  14. package/{util/heatwavedatamanager → heatwave}/texture-point-sampler.js +24 -3
  15. package/package.json +4 -2
  16. package/programs/arrowfield/{object.js → arrow-field.js} +1 -1
  17. package/programs/arrowfield/logic.js +1 -1
  18. package/programs/data2legend/density-to-legend.js +24 -29
  19. package/programs/data2legend/point-to-density-texture.js +14 -17
  20. package/programs/float2legendwithratio/logic.js +2 -2
  21. package/programs/float2legendwithratio/object.js +1 -1
  22. package/programs/helpers/{blender/program.js → blender.js} +1 -1
  23. package/programs/helpers/{fadeaway/logic.js → fadeaway.js} +11 -2
  24. package/programs/index.js +20 -9
  25. package/programs/line-on-globe/circle-accurate-3d.js +12 -14
  26. package/programs/line-on-globe/circle-accurate-flat.js +0 -1
  27. package/programs/line-on-globe/degree-padding-around-circle-3d.js +13 -15
  28. package/programs/line-on-globe/lines-color-instanced-flat.js +15 -18
  29. package/programs/line-on-globe/naive-accurate-flexible.js +0 -1
  30. package/programs/picking/pickable-polygon-renderer.js +1 -1
  31. package/programs/picking/pickable-renderer.js +2 -2
  32. package/programs/point-on-globe/element-globe-surface-glow.js +2 -2
  33. package/programs/point-on-globe/element-point-glow.js +1 -1
  34. package/programs/point-on-globe/square-pixel-point.js +1 -1
  35. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin-triangle.js +32 -6
  36. package/programs/polygon-on-globe/texture-dem-triangles.js +32 -5
  37. package/programs/rings/partial-ring/piece-of-pie.js +26 -29
  38. package/programs/totems/camerauniformblock.js +31 -42
  39. package/programs/two-d/pixel-padding-for-compass.js +14 -24
  40. package/programs/vectorfields/logics/drawrectangleparticles.js +1 -2
  41. package/programs/vectorfields/logics/pixelbased.js +1 -2
  42. package/programs/vectorfields/pingpongbuffermanager.js +1 -1
  43. package/range-tools-on-terrain/bearing-line/adapters.js +1 -1
  44. package/range-tools-on-terrain/circle-line-chain/adapters.js +0 -5
  45. package/range-tools-on-terrain/circle-line-chain/plugin.js +1 -1
  46. package/range-tools-on-terrain/range-ring/plugin.js +4 -6
  47. package/semiplugins/lightweight/line-plugin.js +0 -1
  48. package/semiplugins/shape-on-terrain/arc-plugin.js +0 -2
  49. package/semiplugins/shape-on-terrain/circle-plugin.js +2 -2
  50. package/semiplugins/shape-on-terrain/padding-1-degree.js +1 -1
  51. package/semiplugins/shell/bbox-renderer/index.js +2 -0
  52. package/{programs/globeshell/wiggle → semiplugins/shell/bbox-renderer}/logic.js +101 -102
  53. package/{programs/globeshell/wiggle → semiplugins/shell/bbox-renderer}/object.js +6 -7
  54. package/semiplugins/utility/container-plugin.js +94 -0
  55. package/semiplugins/utility/object-pass-container-plugin.js +80 -0
  56. package/{point-heat-map → tracks/point-heat-map}/adaptors/timetracksplugin-format-to-this.js +1 -1
  57. package/{point-heat-map → tracks/point-heat-map}/plugin-webworker.js +3 -3
  58. package/{point-heat-map → tracks/point-heat-map}/point-to-heat-map-flow.js +11 -14
  59. package/{point-tracks → tracks/point-tracks}/plugin.js +5 -5
  60. package/{timetracks → tracks/timetracks}/adaptors-line-strip.js +1 -1
  61. package/{timetracks → tracks/timetracks}/program-line-strip.js +49 -49
  62. package/{timetracks → tracks/timetracks}/programpoint-line-strip.js +16 -13
  63. package/types.js +6 -0
  64. package/util/account/bufferoffsetmanager.js +1 -1
  65. package/util/account/single-attribute-buffer-management/buffer-orchestrator.js +9 -95
  66. package/util/gl-util/uniform-block/manager.js +0 -1
  67. package/util/gl-util/uniform-block/types.js +0 -7
  68. package/util/index.js +10 -13
  69. package/util/picking/fence.js +16 -18
  70. package/util/picking/picker-displayer.js +4 -6
  71. package/util/programs/{shapesonglobe.js → draw-from-pixel-coords.js} +4 -7
  72. package/util/programs/draw-texture-on-canvas.js +1 -1
  73. package/util/programs/texturetoglobe.js +3 -3
  74. package/util/webglobe/rasteroverlay.js +1 -0
  75. package/vectorfield/arrowfield/index.js +3 -0
  76. package/{arrowfield → vectorfield/arrowfield}/plugin.js +2 -2
  77. package/{waveparticles → vectorfield/waveparticles}/plugin.js +12 -12
  78. package/{wind → vectorfield/wind}/index.js +1 -1
  79. package/{wind → vectorfield/wind}/plugin.js +32 -32
  80. package/write-text/attached-text-writer.js +9 -1
  81. package/write-text/context-text3.js +0 -1
  82. package/write-text/objectarraylabels/index.js +2 -0
  83. package/Math/tessellation/tessellation-algorithm.js +0 -67
  84. package/arrowfield/index.js +0 -3
  85. package/bearing-line/index.js +0 -2
  86. package/bearing-line/plugin.js +0 -444
  87. package/circle-line-chain/chain-list-map.js +0 -201
  88. package/circle-line-chain/plugin.js +0 -411
  89. package/circle-line-chain/util.js +0 -1
  90. package/compassrose/compassrose.js +0 -293
  91. package/compassrose/index.js +0 -2
  92. package/index.js +0 -12
  93. package/partialrings/buffer-manager.js +0 -75
  94. package/partialrings/index.js +0 -2
  95. package/partialrings/plugin.js +0 -128
  96. package/partialrings/program.js +0 -279
  97. package/programs/arrowfield/index.js +0 -2
  98. package/programs/globe-util/is-globe-moved.js +0 -19
  99. package/programs/globeshell/index.js +0 -2
  100. package/programs/globeshell/wiggle/index.js +0 -2
  101. package/programs/helpers/blender/index.js +0 -1
  102. package/programs/helpers/fadeaway/index.js +0 -2
  103. package/programs/helpers/fadeaway/object.js +0 -14
  104. package/programs/helpers/index.js +0 -2
  105. package/programs/rings/distancering/circleflatprogram.js +0 -116
  106. package/programs/rings/distancering/circlepaddingfreeangleprogram.js +0 -326
  107. package/programs/rings/distancering/circlepaddysharedbuffer.js +0 -368
  108. package/programs/rings/distancering/index.js +0 -6
  109. package/programs/rings/distancering/paddyflatprogram.js +0 -127
  110. package/programs/rings/distancering/paddyflatprogram2d.js +0 -129
  111. package/programs/rings/distancering/paddyflatprogram3d.js +0 -128
  112. package/programs/two-d/pixel-circle.js +0 -1
  113. package/programs/vectorfields/index.js +0 -3
  114. package/rangerings/enum.js +0 -2
  115. package/rangerings/index.js +0 -5
  116. package/rangerings/plugin.js +0 -543
  117. package/rangerings/rangeringangletext.js +0 -326
  118. package/rangerings/ring-account.js +0 -112
  119. package/timetracks/index.js +0 -1
  120. package/util/build-strategy/general-strategy.js +0 -62
  121. package/util/gl-util/uniform-block/shader.js +0 -1
  122. package/util/heatwavedatamanager/index.js +0 -2
  123. package/util/heatwavedatamanager/pointcoordsmeta.js +0 -22
  124. package/util/jshelpers/data-filler.js +0 -17
  125. package/util/jshelpers/equality.js +0 -18
  126. package/util/jshelpers/index.js +0 -2
  127. package/util/jshelpers/timefilters.js +0 -30
  128. package/util/programs/index.js +0 -1
  129. package/util/surface-line-data/arc-bboxes.js +0 -25
  130. package/util/surface-line-data/arcs-to-cuts.js +0 -50
  131. package/util/surface-line-data/cut-arc.js +0 -1
  132. package/util/surface-line-data/flow.js +0 -28
  133. package/util/surface-line-data/rbush-manager.js +0 -1
  134. package/util/surface-line-data/types.js +0 -1
  135. package/util/surface-line-data/web-worker.js +0 -1
  136. package/write-text/context-text3old.js +0 -152
  137. package/write-text/index.js +0 -1
  138. package/write-text/writer-plugin.js +0 -8
  139. /package/{heatwave/isobar/quadtreecontours.js → Math/contour/quadtreecontours1.js} +0 -0
  140. /package/pin/{pin-object-array.js → pin-object-array1.js} +0 -0
  141. /package/pin/{pin-point-totem.js → pin-point-totem1.js} +0 -0
  142. /package/{circle-line-chain/init.js → programs/polygon-on-globe/partial-tesselation.js} +0 -0
  143. /package/{point-heat-map → tracks/point-heat-map}/index.js +0 -0
  144. /package/{point-tracks → tracks/point-tracks}/key-methods.js +0 -0
  145. /package/{timetracks → tracks/timetracks}/plugin-line-strip.js +0 -0
  146. /package/{arrowfield → vectorfield/arrowfield}/adaptor.js +0 -0
  147. /package/{waveparticles → vectorfield/waveparticles}/adaptor.js +0 -0
  148. /package/{waveparticles → vectorfield/waveparticles}/index.js +0 -0
  149. /package/{wind → vectorfield/wind}/imagetovectorfieldandmagnitude.js +0 -0
  150. /package/{wind → vectorfield/wind}/vectorfieldimage.js +0 -0
  151. /package/write-text/{context-text.js → context-textDELETE.js} +0 -0
  152. /package/{heatwave/isobar → write-text/objectarraylabels}/objectarraylabels.js +0 -0
@@ -1,543 +0,0 @@
1
- /**
2
- * @typedef RangeRingData
3
- * @property {number} centerX
4
- * @property {number} centerY
5
- * @property {Array<Ring>} rings
6
- *
7
- * @typedef Ring
8
- * @property {number} radius
9
- * @property {number} padding
10
- * @property {[number, number, number]} color
11
- *
12
- *
13
- * @method insertBulk
14
- * @typedef {Array<{ringID, radius, padding}>} rings
15
- * @param {Array<centerID:string, x:number, y:number, stepAngle:number, rgba:[4 numbers], rings:rings} items
16
-
17
- * @method updateCentersCoordinate @param {Array<{centerID, long,lat}>} items
18
- * @method updateCentersColor @param {Array<{centerID, rgba:[4 numbers]}>} centerColors
19
- *
20
- * @method updateCentersHide @param {Array<{centerID, hide, textHide}>} centerHides
21
- * @method removeCenters @param {Array<{centerID}>} centerIds
22
- * @method setOpacity @param {number} opacity
23
- *
24
- * @method setOneDegreePaddingOn // performance consuming, might be removed
25
- *
26
- */
27
- import { centerCoords2dflatDataCreatorWithRadius, CircleCache as CircleCache2D } from "../programs/line-on-globe/circle-accurate-flat";
28
- import { CircleCache as CircleCache3D } from "../programs/line-on-globe/circle-accurate-3d";
29
- import { LinesColorInstancedFlatCache } from "../programs/line-on-globe/lines-color-instanced-flat";
30
- import { BufferOrchestrator, BufferManager } from "../util/account";
31
- // import { mapGetOrThrow } from "../util/check/get";
32
- import { populateFloat32Array } from "../util/jshelpers/data-filler";
33
- import { RingAccount, ringBigPaddingKeyMethod, ringKeyMethod } from "./ring-account";
34
- import { CirclePadding3DCache } from "../programs/line-on-globe/degree-padding-around-circle-3d";
35
- import { LineOnGlobeCache } from '../programs/line-on-globe/naive-accurate-flexible';
36
- import RangeRingAngleText from "./rangeringangletext";
37
- import { Z_ALPHA_MODE } from "../programs/line-on-globe/util";
38
- import { ENUM_HIDE } from "./enum";
39
- import { opacityCheck, mapGetOrThrow } from "../util/check/typecheck";
40
- import { sphereCoord } from "../util/geometry/index";
41
- const CIRCLE_FLAT_EDGE_COUNT = 362; // 360 + 2 for closing the circle and a cutting point
42
- /**
43
- *
44
- *
45
- * @typedef {string} centerID
46
- *
47
- * @typedef {Object} RangeRing
48
- * @property {string} ringID
49
- * @property {number} radius in range meters
50
- * @property {number} padding badding range in meter
51
- *
52
- *
53
- * Array < centerID: string, long: number, lat: number, stepAngle: number, rgba: [4 numbers], rings: rings, hide, textHide
54
- * @typedef {Object} RangeRingsItem
55
- * @property {centerID} centerID
56
- * @property {number} long
57
- * @property {number} lat
58
- * @property {number} stepAngle
59
- * @property {number} altitude
60
- * @property {number} hide
61
- * @property {number} textHide
62
- * @property {number} rgba
63
- * @property {Array<RangeRing>} rings
64
- */
65
- class RangeRings {
66
- constructor(id, { oneDegreePadding = true, showNumbers = true, numbersStyle = null, opacity = 1, zAlphaOnDegreePadding = Z_ALPHA_MODE.ON } = {}, { textDataPreAdaptor = null, textWritersMap = new Map() } = {}) {
67
- this.id = id;
68
- this._oneDegreePadding = oneDegreePadding;
69
- this._zAlphaOnDegreePadding = zAlphaOnDegreePadding;
70
- this._showNumbers = showNumbers;
71
- this._numbersStyle = numbersStyle;
72
- this._opacity = opacity;
73
- this._ringAccount = new RingAccount();
74
- this._textWritersMap = textWritersMap;
75
- this._textDataPreAdaptor = textDataPreAdaptor;
76
- this._textWritersMap.forEach((textWriter) => textWriter.setKeyAdaptor((item) => item.__identity__));
77
- }
78
- // USER API
79
- /**
80
- * @method updateCentersCoordinate @param { Array < { centerID, long,lat } >} items
81
- */
82
- updateCentersCoordinate(items, { textWriterIDs = [] } = {}) {
83
- // Algorithm
84
- /**
85
- * 1. ask centerRingAccount for existing rings COORDINATE RELATED KEYS
86
- * 2. update centers
87
- * 3. update buffer orchestators
88
- */
89
- this._ringAccount.updateCentersCoordinate(items);
90
- const { globe, bufferOrchestrator, bufferManagersCompMap, paddingBufferOrchestrator, bufferManagersCompMapPadding } = this;
91
- for (const { centerID } of items) {
92
- const datas = this.__reconstructCentralRings(centerID);
93
- bufferOrchestrator.updateBulk(datas, bufferManagersCompMap, ["centerCoords3d", "centerCoords2dflat", "targetCoords3d", "centerCoords2dflatForPadding"]);
94
- const paddingDatas = this.__reconstructCentralRingsBigPaddings(centerID);
95
- paddingBufferOrchestrator.updateBulk(paddingDatas, bufferManagersCompMapPadding, ["circlePoint2d", "paddingPoint2d", "circlePoint3d", "paddingPoint3d"]);
96
- }
97
- this.paddingTextPlugin?.updateCentersXY(items);
98
- this.__contextTextWriterUpdate(items.map(({ centerID }) => centerID), textWriterIDs);
99
- globe.DrawRender();
100
- }
101
- /**
102
- * @method insertBulk
103
- * @param { Array < RangeRingsItem> } items
104
- */
105
- insertBulk(items, { textWriterIDs = [] } = {}) {
106
- // Algorithm
107
- /**
108
- * 1 ask centerRingAccount for existing rings
109
- * 2. delete all existing keys with buffer orchestators
110
- * 3. insert new centerRings to centerRingAccount
111
- * 4. insert new keys with buffer orchestators
112
- */
113
- const { globe, _ringAccount, bufferOrchestrator, bufferManagersCompMap, paddingBufferOrchestrator, bufferManagersCompMapPadding } = this;
114
- for (const item of items) {
115
- const existingKeys = _ringAccount.ringKeys(item.centerID);
116
- if (existingKeys.length) {
117
- bufferOrchestrator.deleteBulk(existingKeys, bufferManagersCompMap);
118
- }
119
- const paddingKeys = _ringAccount.ringBigPaddingKeys(item.centerID);
120
- if (paddingKeys.length) {
121
- paddingBufferOrchestrator.deleteBulk(paddingKeys, bufferManagersCompMapPadding);
122
- }
123
- }
124
- for (const item of items) {
125
- _ringAccount.insertCenter(item);
126
- const datas = this.__reconstructCentralRings(item.centerID);
127
- bufferOrchestrator.insertBulk(datas, bufferManagersCompMap);
128
- const paddingDatas = this.__reconstructCentralRingsBigPaddings(item.centerID);
129
- paddingBufferOrchestrator.insertBulk(paddingDatas, bufferManagersCompMapPadding);
130
- }
131
- this.paddingTextPlugin?.insertBulk(items);
132
- this.__contextTextWriterUpdate(items.map(({ centerID }) => centerID), textWriterIDs);
133
- globe.DrawRender();
134
- }
135
- /**
136
- * @method updateCentersColor @param { Array < { centerID, rgba: [4 numbers] } >} centerColors
137
- */
138
- updateCentersColor(centerColors, { textWriterIDs = [] } = {}) {
139
- // Algorithm
140
- /**
141
- * 1. ask centerRingAccount for existing rings COLOR KEYS
142
- * 2. update centers
143
- * 3. update buffer orchestators
144
- */
145
- this._ringAccount.updateCentersColor(centerColors);
146
- const { globe, bufferOrchestrator, bufferManagersCompMap, paddingBufferOrchestrator, bufferManagersCompMapPadding } = this;
147
- for (const { centerID } of centerColors) {
148
- const datas = this.__reconstructCentralProperties(centerID);
149
- bufferOrchestrator.updateBulk(datas, bufferManagersCompMap, ["rgba", "rgbaMercator"]);
150
- const paddingDatas = this.__reconstructCentralPaddingProperties(centerID);
151
- paddingBufferOrchestrator.updateBulk(paddingDatas, bufferManagersCompMapPadding, ["rgba"]);
152
- }
153
- this.__contextTextWriterUpdate(centerColors.map(({ centerID }) => centerID), textWriterIDs);
154
- globe.DrawRender();
155
- }
156
- /**
157
- *
158
- * @method updateCentersHide @param { Array < { centerID, hide, textHide } >} centerHides
159
- */
160
- updateCentersHide(centerHides, { textWriterIDs = [] } = {}) {
161
- // Algorithm
162
- /**
163
- * Simple
164
- * 1. update centers
165
- * 2. reconstruct data,
166
- * 3. update color buffer
167
- * */
168
- this._ringAccount.updateCentersHide(centerHides);
169
- const { globe, bufferOrchestrator, bufferManagersCompMap, paddingBufferOrchestrator, bufferManagersCompMapPadding } = this;
170
- for (const { centerID } of centerHides) {
171
- const datas = this.__reconstructCentralProperties(centerID);
172
- bufferOrchestrator.updateBulk(datas, bufferManagersCompMap, ["rgba", "rgbaMercator"]);
173
- const paddingDatas0 = this.__reconstructCentralRings(centerID);
174
- bufferOrchestrator.updateBulk(paddingDatas0, bufferManagersCompMap, ["radius3dsmall", "centerCoords2dflatForPadding"]);
175
- const paddingDatas = this.__reconstructCentralPaddingProperties(centerID);
176
- paddingBufferOrchestrator.updateBulk(paddingDatas, bufferManagersCompMapPadding, ["rgba"]);
177
- }
178
- this.paddingTextPlugin?.updateCentersHide(centerHides);
179
- this.__contextTextWriterUpdate(centerHides.map(({ centerID }) => centerID), textWriterIDs);
180
- globe.DrawRender();
181
- /**
182
- * Complicated
183
- * 1. ask centerRingAccount for existing rings HIDE KEYS
184
- * 2. delete from buffer orchestators
185
- * 3. mark centers as hidden
186
- */
187
- }
188
- /**
189
- * @param {Array<string>} textWriterIDs textWritersMap keys to be used for writing text.
190
- * @param {Array<string>} itemKeys if empty, all texts will be updated. Use {@link ringKeyMethod} method to get keys
191
- */
192
- updateText(textWriterIDs = [], itemKeys = null) {
193
- const textWritersMap = textWriterGetOrThrow(this._textWritersMap, textWriterIDs);
194
- if (itemKeys === null) {
195
- this._ringAccount.updateAllText(textWritersMap, this._textDataPreAdaptor);
196
- this.globe.DrawRender();
197
- }
198
- else {
199
- itemKeys.forEach((key) => {
200
- const item = this._ringAccount.getCenter(key);
201
- if (item === undefined)
202
- throw new Error("Center not found");
203
- const textData = this._textDataPreAdaptor(item);
204
- textWritersMap.forEach((textWriter) => textWriter.insertText(textData));
205
- });
206
- }
207
- this.globe.DrawRender();
208
- }
209
- /**
210
- * @method removeCenters @param { Array < { centerID } >} centerIDs
211
- */
212
- removeCenters(centerIDs) {
213
- const { globe, bufferOrchestrator, bufferManagersCompMap, paddingBufferOrchestrator, bufferManagersCompMapPadding, _ringAccount } = this;
214
- for (const centerID of centerIDs) {
215
- const existingKeys = _ringAccount.ringKeys(centerID);
216
- if (existingKeys.length) {
217
- bufferOrchestrator.deleteBulk(existingKeys, bufferManagersCompMap);
218
- this._textWritersMap.forEach((textWriter) => textWriter.deleteTextBulk(existingKeys));
219
- }
220
- }
221
- for (const centerID of centerIDs) {
222
- const paddingKeys = _ringAccount.ringBigPaddingKeys(centerID);
223
- if (paddingKeys.length) {
224
- paddingBufferOrchestrator.deleteBulk(paddingKeys, bufferManagersCompMapPadding);
225
- }
226
- }
227
- this.paddingTextPlugin?.removeCenters(centerIDs);
228
- this._ringAccount.removeCenters(centerIDs);
229
- globe.DrawRender();
230
- }
231
- /**
232
- * @method setOpacity @param { number } opacity
233
- */
234
- setOpacity(opacity) {
235
- opacityCheck(opacity);
236
- this._opacity = opacity;
237
- this.paddingTextPlugin?.setOpacity(opacity);
238
- this._textWritersMap.forEach((writer) => writer.setOpacity(opacity));
239
- this.globe.DrawRender();
240
- }
241
- /**
242
- * @method setOneDegreePaddingOn // performance consuming, might be removed
243
- */
244
- setOneDegreePaddingOn(isOneDegreePaddingOn) {
245
- if (typeof isOneDegreePaddingOn !== "boolean")
246
- throw new Error("Invalid value for one degree padding");
247
- if (this._oneDegreePadding === isOneDegreePaddingOn)
248
- return;
249
- this._oneDegreePadding = isOneDegreePaddingOn;
250
- this.globe.DrawRender();
251
- }
252
- setZAlphaOnDegreePadding(zAlphaOnDegreePadding) {
253
- if (zAlphaOnDegreePadding !== 0 && zAlphaOnDegreePadding !== 1)
254
- throw new Error("Invalid value for zAlphaOnDegreePadding");
255
- if (this._zAlphaOnDegreePadding === zAlphaOnDegreePadding)
256
- return;
257
- this._zAlphaOnDegreePadding = zAlphaOnDegreePadding;
258
- this.globe.DrawRender();
259
- }
260
- // PRIVATE METHODS
261
- _initPrograms() {
262
- const { globe } = this;
263
- this._circleProgram2D = CircleCache2D.get(globe);
264
- this._circleProgram3D = CircleCache3D.get(globe);
265
- this._padding2dProgram = LinesColorInstancedFlatCache.get(globe);
266
- this._padding3dProgram = CirclePadding3DCache.get(globe);
267
- this._lineOnGlobe_bigPadding = LineOnGlobeCache.get(globe);
268
- }
269
- _initBufferManagers() {
270
- const { gl } = this;
271
- const initialCapacity = 10;
272
- const bufferType = "DYNAMIC_DRAW";
273
- // circle2d, circle3d, 1 degree paddings,
274
- this.bufferOrchestrator = new BufferOrchestrator({ capacity: initialCapacity });
275
- this.bufferManagersCompMap = new Map([
276
- // circle 3D
277
- ["centerCoords3d", {
278
- 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
279
- 'adaptor': (item) => new Float32Array(item.centerCoords3d),
280
- }],
281
- ["targetCoords3d", {
282
- 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
283
- 'adaptor': (item) => new Float32Array(item.targetCoords3d),
284
- }],
285
- ["rgba", {
286
- 'bufferManager': new BufferManager(gl, 4, { bufferType, initialCapacity }),
287
- 'adaptor': (item) => new Float32Array(item.hide === ENUM_HIDE.HIDE ? [0, 0, 0, 0] : item.rgba)
288
- }],
289
- ["radius3d", {
290
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
291
- 'adaptor': (item) => new Float32Array([item.radius])
292
- }],
293
- ["radius3dsmall", {
294
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
295
- 'adaptor': (item) => {
296
- if (item.hide === ENUM_HIDE.HIDE_1_DEGREE_PADDINGS)
297
- return new Float32Array([item.radius]);
298
- return new Float32Array([item.radius - item.padding / 3]);
299
- }
300
- }],
301
- ["circleDashAngle", {
302
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
303
- 'adaptor': (item) => new Float32Array([1]),
304
- }],
305
- ["dashOpacity", {
306
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
307
- 'adaptor': (item) => new Float32Array([1]),
308
- }],
309
- // circle 2D
310
- ["centerCoords2dflatForPadding", {
311
- 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT * 2, { bufferType, initialCapacity }),
312
- 'adaptor': (item) => item.centerCoords2dflatForPadding,
313
- }],
314
- ["centerCoords2dflat", {
315
- 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT * 2, { bufferType, initialCapacity }),
316
- 'adaptor': (item) => item.centerCoords2dflat,
317
- }],
318
- ["rgbaMercator", {
319
- 'bufferManager': new BufferManager(gl, 4 * CIRCLE_FLAT_EDGE_COUNT, { bufferType, initialCapacity }),
320
- 'adaptor': (item) => populateFloat32Array.fillWithListData(CIRCLE_FLAT_EDGE_COUNT, item.hide === ENUM_HIDE.HIDE ? [0, 0, 0, 0] : item.rgba),
321
- }],
322
- ["circleDashAngleMercator", {
323
- 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT, { bufferType, initialCapacity }),
324
- 'adaptor': (item) => populateFloat32Array.fillFloat32Array(CIRCLE_FLAT_EDGE_COUNT, 1),
325
- }],
326
- ["dashOpacityMercator", {
327
- 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT, { bufferType, initialCapacity }),
328
- 'adaptor': (item) => populateFloat32Array.fillFloat32Array(CIRCLE_FLAT_EDGE_COUNT, 1),
329
- }],
330
- ]);
331
- const obj = function (bufferManagerComp, divisor = 1) {
332
- if (bufferManagerComp === null)
333
- return null;
334
- return { 'buffer': bufferManagerComp.bufferManager.buffer, 'stride': 0, 'offset': 0, divisor };
335
- };
336
- this._circle2DVao = this._circleProgram2D.createVAO(...["centerCoords2dflat", "rgbaMercator", "circleDashAngleMercator", "dashOpacityMercator"].map(key => obj(this.bufferManagersCompMap.get(key))));
337
- this._circle3DVao = this._circleProgram3D.createVAO(...["centerCoords3d", "targetCoords3d", "rgba", "circleDashAngle", "dashOpacity"].map(key => obj(this.bufferManagersCompMap.get(key))));
338
- this._oneDegree2DPaddingVao = this._padding2dProgram.createVAO({ buffer: this.bufferManagersCompMap.get("centerCoords2dflat").bufferManager.buffer, size: 2, stride: 0, offset: 0 }, { buffer: this.bufferManagersCompMap.get("centerCoords2dflatForPadding").bufferManager.buffer, size: 2, stride: 0, offset: 0 }, { buffer: this.bufferManagersCompMap.get("rgbaMercator").bufferManager.buffer, size: 4, stride: 0, offset: 0 });
339
- // PADDING
340
- // this one needs glue to assosiate rings and their big paddings since the count for center is not fixed
341
- this.paddingBufferOrchestrator = new BufferOrchestrator({ capacity: initialCapacity });
342
- this.bufferManagersCompMapPadding = new Map([
343
- ["circlePoint2d", {
344
- 'bufferManager': new BufferManager(gl, 2, { bufferType, initialCapacity }),
345
- 'adaptor': (item) => item.circlePoint2d,
346
- }],
347
- ["paddingPoint2d", {
348
- 'bufferManager': new BufferManager(gl, 2, { bufferType, initialCapacity }),
349
- 'adaptor': (item) => item.paddingPoint2d,
350
- }],
351
- ["circlePoint3d", {
352
- 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
353
- 'adaptor': (item) => item.circlePoint3d
354
- }],
355
- ["paddingPoint3d", {
356
- 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
357
- 'adaptor': (item) => item.paddingPoint3d
358
- }],
359
- ["rgba", {
360
- 'bufferManager': new BufferManager(gl, 4, { bufferType, initialCapacity }),
361
- 'adaptor': (item) => new Float32Array(item.rgba)
362
- }],
363
- // ["dashOpacity", {
364
- // 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
365
- // 'adaptor': (item) => new Float32Array([1]),
366
- // }],
367
- // ["dashRatio", {
368
- // 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
369
- // 'adaptor': (item) => new Float32Array([1]),
370
- // }],
371
- ]);
372
- this._bigPadding3dFlatVAO = this._lineOnGlobe_bigPadding.createVAO(//"dashRatio", "dashOpacity"
373
- ...["circlePoint2d", "circlePoint3d", "paddingPoint2d", "paddingPoint3d", null, null, "rgba",].map(key => (key === null) ? null : obj(this.bufferManagersCompMapPadding.get(key))));
374
- this._padding3dOneDegreeVao = this._padding3dProgram.createVAO(...["centerCoords3d", "radius3d", "radius3dsmall", "rgba"].map(key => obj(this.bufferManagersCompMap.get(key))));
375
- }
376
- // IMPLICIT METHODS
377
- __reconstructCentralRingsBigPaddings(centerID) {
378
- const { globe } = this;
379
- const centerItem = this._ringAccount.getCenter(centerID);
380
- if (centerItem === undefined)
381
- throw new Error("Center not found");
382
- const { long, lat, stepAngle, rgba, rings, hide = 0, textHide = 0, altitude: centerAltitude = 0 } = centerItem;
383
- const result = [];
384
- const color = hide === 1 ? new Float32Array([0, 0, 0, 0]) : new Float32Array(rgba);
385
- for (const { ringID, radius, padding, altitude = centerAltitude } of rings) {
386
- let azimuthAngle = 0;
387
- while (azimuthAngle < 360) {
388
- const circlePoint = globe.Math.FindPointByPolar(long, lat, radius, azimuthAngle); // long lat
389
- const paddingPoint = globe.Math.FindPointByPolar(long, lat, radius - padding, azimuthAngle); // long lat
390
- result.push({
391
- key: ringBigPaddingKeyMethod(centerID, ringID, azimuthAngle),
392
- circlePoint2d: new Float32Array(globe.api_GetMercator2DPoint(circlePoint.long, circlePoint.lat)),
393
- paddingPoint2d: new Float32Array(globe.api_GetMercator2DPoint(paddingPoint.long, paddingPoint.lat)),
394
- circlePoint3d: sphereCoord(circlePoint.long, circlePoint.lat, globe, altitude / 1000),
395
- paddingPoint3d: sphereCoord(paddingPoint.long, paddingPoint.lat, globe, altitude / 1000),
396
- rgba: color,
397
- hide,
398
- textHide
399
- });
400
- azimuthAngle += stepAngle;
401
- }
402
- }
403
- return result;
404
- }
405
- __reconstructCentralRings(centerID) {
406
- const { globe } = this;
407
- const centerItem = this._ringAccount.getCenter(centerID);
408
- if (centerItem === undefined)
409
- throw new Error("Center not found");
410
- const { long, lat, rgba, rings, hide = 0, textHide = 0, altitude: centralAltitude = 0 } = centerItem;
411
- const centerCoords3d = sphereCoord(long, lat, globe, centralAltitude / 1000);
412
- const result = [];
413
- for (const { ringID, radius, padding, __identity__, altitude = centralAltitude } of rings) {
414
- const key = __identity__;
415
- const centerCoords2dflat = centerCoords2dflatDataCreatorWithRadius(globe, long, lat, radius, { edgeCount: CIRCLE_FLAT_EDGE_COUNT });
416
- const radiusPadding = hide === ENUM_HIDE.HIDE_1_DEGREE_PADDINGS ? radius : radius - padding / 3;
417
- const targetPoint = globe.Math.FindPointByPolar(long, lat, radius, 0); // long lat
418
- const targetCoords3d = sphereCoord(targetPoint.long, targetPoint.lat, globe, altitude / 1000);
419
- const centerCoords2dflatForPadding = centerCoords2dflatDataCreatorWithRadius(globe, long, lat, radiusPadding, { edgeCount: CIRCLE_FLAT_EDGE_COUNT });
420
- result.push({
421
- key,
422
- centerCoords3d,
423
- targetCoords3d,
424
- centerCoords2dflat,
425
- radius,
426
- padding,
427
- rgba,
428
- centerCoords2dflatForPadding,
429
- hide,
430
- textHide
431
- });
432
- }
433
- return result;
434
- }
435
- __reconstructCentralPaddingProperties(centerID) {
436
- const centerItem = this._ringAccount.getCenter(centerID);
437
- if (centerItem === undefined)
438
- throw new Error("Center not found");
439
- const { stepAngle, rgba, rings, hide = 0, textHide = 0 } = centerItem;
440
- const result = [];
441
- for (const { ringID, } of rings) {
442
- let angle = 0;
443
- while (angle < 360) {
444
- result.push({
445
- key: ringBigPaddingKeyMethod(centerID, ringID, angle),
446
- rgba: hide === 1 ? new Float32Array([0, 0, 0, 0]) : rgba,
447
- textHide
448
- });
449
- angle += stepAngle;
450
- }
451
- }
452
- return result;
453
- }
454
- __reconstructCentralProperties(centerID) {
455
- const centerItem = this._ringAccount.getCenter(centerID);
456
- if (centerItem === undefined)
457
- throw new Error("Center not found");
458
- const { rgba, rings, hide = 0, textHide = 0 } = centerItem;
459
- const result = [];
460
- for (const { ringID, __identity__ } of rings) {
461
- const key = __identity__;
462
- result.push({
463
- key,
464
- rgba: hide === ENUM_HIDE.HIDE ? new Float32Array([0, 0, 0, 0]) : rgba,
465
- textHide
466
- });
467
- }
468
- return result;
469
- }
470
- // GLOBE API
471
- init(globe, gl) {
472
- this.globe = globe;
473
- this.gl = gl;
474
- this._initPrograms();
475
- this._initBufferManagers();
476
- if (this._showNumbers) {
477
- this.paddingTextPlugin = new RangeRingAngleText(globe, this.id + "text", { style: this._numbersStyle, opacity: this._opacity });
478
- delete this._numbersStyle;
479
- }
480
- }
481
- draw3D() {
482
- const { globe, gl, _circleProgram2D, _circleProgram3D, _padding2dProgram, _padding3dProgram, _lineOnGlobe_bigPadding, _circle2DVao, _circle3DVao, _oneDegree2DPaddingVao, _padding3dOneDegreeVao, _bigPadding3dFlatVAO, bufferOrchestrator, paddingBufferOrchestrator, _opacity, _oneDegreePadding, _zAlphaOnDegreePadding } = this;
483
- gl.disable(gl.DEPTH_TEST);
484
- const is3D = globe.api_GetCurrentGeometry() === 0;
485
- // const lod = globe.api_GetCurrentLOD();
486
- if (is3D) {
487
- _circleProgram3D.draw(_circle3DVao, bufferOrchestrator.length, _opacity);
488
- if (_oneDegreePadding)
489
- _padding3dProgram.draw(_padding3dOneDegreeVao, bufferOrchestrator.length, 360, 1, _opacity, _zAlphaOnDegreePadding);
490
- }
491
- else {
492
- _circleProgram2D.draw(_circle2DVao, bufferOrchestrator.length, CIRCLE_FLAT_EDGE_COUNT, _opacity);
493
- // _padding2dProgram.draw(bigPaddingVAO, paddingBufferOrchestrator.length, _opacity);
494
- if (_oneDegreePadding)
495
- _padding2dProgram.draw(_oneDegree2DPaddingVao, bufferOrchestrator.length * CIRCLE_FLAT_EDGE_COUNT, _opacity, _zAlphaOnDegreePadding);
496
- }
497
- const drawOptions = { drawRange: { first: 0, count: paddingBufferOrchestrator.length } };
498
- _lineOnGlobe_bigPadding.draw(_bigPadding3dFlatVAO, drawOptions, _opacity);
499
- this._textWritersMap.forEach((textWriter) => textWriter.draw());
500
- gl.enable(gl.DEPTH_TEST);
501
- }
502
- free() {
503
- if (this._isFreed)
504
- return;
505
- const { globe } = this;
506
- this.bufferManagersCompMap.forEach(({ bufferManager }) => bufferManager.free());
507
- this.bufferManagersCompMapPadding.forEach(({ bufferManager }) => bufferManager.free());
508
- // delete vaos
509
- this.gl.deleteVertexArray(this._circle2DVao);
510
- this.gl.deleteVertexArray(this._circle3DVao);
511
- this.gl.deleteVertexArray(this._oneDegree2DPaddingVao);
512
- this.gl.deleteVertexArray(this._padding3dOneDegreeVao);
513
- this.gl.deleteVertexArray(this._bigPadding3dFlatVAO);
514
- // delete programs
515
- CircleCache2D.release(globe);
516
- CircleCache3D.release(globe);
517
- LinesColorInstancedFlatCache.release(globe);
518
- CirclePadding3DCache.release(globe);
519
- LineOnGlobeCache.release(globe);
520
- this._circleProgram2D = null;
521
- this._circleProgram3D = null;
522
- this._padding2dProgram = null;
523
- this._padding3dProgram = null;
524
- this._lineOnGlobe_bigPadding = null;
525
- this.paddingTextPlugin?.free();
526
- this._isFreed = true;
527
- }
528
- __contextTextWriterUpdate(centerIDs, textWriterIDs = null) {
529
- let textWriters = null;
530
- if (textWriterIDs === null) {
531
- textWriters = Array.from(this._textWritersMap.values());
532
- }
533
- else if (textWriterIDs.length === 0) {
534
- return;
535
- }
536
- else {
537
- textWriters = textWriterGetOrThrow(this._textWritersMap, textWriterIDs);
538
- }
539
- centerIDs.forEach((centerID) => { this._ringAccount.textUpdate(centerID, textWriters, this._textDataPreAdaptor); });
540
- }
541
- }
542
- const textWriterGetOrThrow = mapGetOrThrow("textWriterIDs is invalid");
543
- export { RangeRings, Z_ALPHA_MODE };