@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.
- package/Math/angle-calculation.js +1 -0
- package/Math/contour/quadtreecontours.js +300 -0
- package/Math/finite-line-2d.js +58 -0
- package/Math/tessellation/hybrid-triangle-tessellation-meta.js +123 -0
- package/Math/tessellation/tile-merger.js +56 -0
- package/Math/tessellation/triangle-tessellation-meta.js +178 -32
- package/Math/tessellation/triangle-tessellation.js +5 -1
- package/compass-rose/compass-text-writer.js +39 -33
- package/constants.js +3 -0
- package/{util/heatwavedatamanager → heatwave}/datamanager.js +1 -1
- package/heatwave/{plugins/heatwaveglobeshell.js → heatwave.js} +8 -6
- package/heatwave/index.js +5 -3
- package/heatwave/{isobar/plugin.js → isobar.js} +6 -5
- package/{util/heatwavedatamanager → heatwave}/texture-point-sampler.js +24 -3
- package/package.json +4 -2
- package/programs/arrowfield/{object.js → arrow-field.js} +1 -1
- package/programs/arrowfield/logic.js +1 -1
- package/programs/data2legend/density-to-legend.js +24 -29
- package/programs/data2legend/point-to-density-texture.js +14 -17
- package/programs/float2legendwithratio/logic.js +2 -2
- package/programs/float2legendwithratio/object.js +1 -1
- package/programs/helpers/{blender/program.js → blender.js} +1 -1
- package/programs/helpers/{fadeaway/logic.js → fadeaway.js} +11 -2
- package/programs/index.js +20 -9
- package/programs/line-on-globe/circle-accurate-3d.js +12 -14
- package/programs/line-on-globe/circle-accurate-flat.js +0 -1
- package/programs/line-on-globe/degree-padding-around-circle-3d.js +13 -15
- package/programs/line-on-globe/lines-color-instanced-flat.js +15 -18
- package/programs/line-on-globe/naive-accurate-flexible.js +0 -1
- package/programs/picking/pickable-polygon-renderer.js +1 -1
- package/programs/picking/pickable-renderer.js +2 -2
- package/programs/point-on-globe/element-globe-surface-glow.js +2 -2
- package/programs/point-on-globe/element-point-glow.js +1 -1
- package/programs/point-on-globe/square-pixel-point.js +1 -1
- package/programs/polygon-on-globe/texture-dem-triangle-test-plugin-triangle.js +32 -6
- package/programs/polygon-on-globe/texture-dem-triangles.js +32 -5
- package/programs/rings/partial-ring/piece-of-pie.js +26 -29
- package/programs/totems/camerauniformblock.js +31 -42
- package/programs/two-d/pixel-padding-for-compass.js +14 -24
- package/programs/vectorfields/logics/drawrectangleparticles.js +1 -2
- package/programs/vectorfields/logics/pixelbased.js +1 -2
- package/programs/vectorfields/pingpongbuffermanager.js +1 -1
- package/range-tools-on-terrain/bearing-line/adapters.js +1 -1
- package/range-tools-on-terrain/circle-line-chain/adapters.js +0 -5
- package/range-tools-on-terrain/circle-line-chain/plugin.js +1 -1
- package/range-tools-on-terrain/range-ring/plugin.js +4 -6
- package/semiplugins/lightweight/line-plugin.js +0 -1
- package/semiplugins/shape-on-terrain/arc-plugin.js +0 -2
- package/semiplugins/shape-on-terrain/circle-plugin.js +2 -2
- package/semiplugins/shape-on-terrain/padding-1-degree.js +1 -1
- package/semiplugins/shell/bbox-renderer/index.js +2 -0
- package/{programs/globeshell/wiggle → semiplugins/shell/bbox-renderer}/logic.js +101 -102
- package/{programs/globeshell/wiggle → semiplugins/shell/bbox-renderer}/object.js +6 -7
- package/semiplugins/utility/container-plugin.js +94 -0
- package/semiplugins/utility/object-pass-container-plugin.js +80 -0
- package/{point-heat-map → tracks/point-heat-map}/adaptors/timetracksplugin-format-to-this.js +1 -1
- package/{point-heat-map → tracks/point-heat-map}/plugin-webworker.js +3 -3
- package/{point-heat-map → tracks/point-heat-map}/point-to-heat-map-flow.js +11 -14
- package/{point-tracks → tracks/point-tracks}/plugin.js +5 -5
- package/{timetracks → tracks/timetracks}/adaptors-line-strip.js +1 -1
- package/{timetracks → tracks/timetracks}/program-line-strip.js +49 -49
- package/{timetracks → tracks/timetracks}/programpoint-line-strip.js +16 -13
- package/types.js +6 -0
- package/util/account/bufferoffsetmanager.js +1 -1
- package/util/account/single-attribute-buffer-management/buffer-orchestrator.js +9 -95
- package/util/gl-util/uniform-block/manager.js +0 -1
- package/util/gl-util/uniform-block/types.js +0 -7
- package/util/index.js +10 -13
- package/util/picking/fence.js +16 -18
- package/util/picking/picker-displayer.js +4 -6
- package/util/programs/{shapesonglobe.js → draw-from-pixel-coords.js} +4 -7
- package/util/programs/draw-texture-on-canvas.js +1 -1
- package/util/programs/texturetoglobe.js +3 -3
- package/util/webglobe/rasteroverlay.js +1 -0
- package/vectorfield/arrowfield/index.js +3 -0
- package/{arrowfield → vectorfield/arrowfield}/plugin.js +2 -2
- package/{waveparticles → vectorfield/waveparticles}/plugin.js +12 -12
- package/{wind → vectorfield/wind}/index.js +1 -1
- package/{wind → vectorfield/wind}/plugin.js +32 -32
- package/write-text/attached-text-writer.js +9 -1
- package/write-text/context-text3.js +0 -1
- package/write-text/objectarraylabels/index.js +2 -0
- package/Math/tessellation/tessellation-algorithm.js +0 -67
- package/arrowfield/index.js +0 -3
- package/bearing-line/index.js +0 -2
- package/bearing-line/plugin.js +0 -444
- package/circle-line-chain/chain-list-map.js +0 -201
- package/circle-line-chain/plugin.js +0 -411
- package/circle-line-chain/util.js +0 -1
- package/compassrose/compassrose.js +0 -293
- package/compassrose/index.js +0 -2
- package/index.js +0 -12
- package/partialrings/buffer-manager.js +0 -75
- package/partialrings/index.js +0 -2
- package/partialrings/plugin.js +0 -128
- package/partialrings/program.js +0 -279
- package/programs/arrowfield/index.js +0 -2
- package/programs/globe-util/is-globe-moved.js +0 -19
- package/programs/globeshell/index.js +0 -2
- package/programs/globeshell/wiggle/index.js +0 -2
- package/programs/helpers/blender/index.js +0 -1
- package/programs/helpers/fadeaway/index.js +0 -2
- package/programs/helpers/fadeaway/object.js +0 -14
- package/programs/helpers/index.js +0 -2
- package/programs/rings/distancering/circleflatprogram.js +0 -116
- package/programs/rings/distancering/circlepaddingfreeangleprogram.js +0 -326
- package/programs/rings/distancering/circlepaddysharedbuffer.js +0 -368
- package/programs/rings/distancering/index.js +0 -6
- package/programs/rings/distancering/paddyflatprogram.js +0 -127
- package/programs/rings/distancering/paddyflatprogram2d.js +0 -129
- package/programs/rings/distancering/paddyflatprogram3d.js +0 -128
- package/programs/two-d/pixel-circle.js +0 -1
- package/programs/vectorfields/index.js +0 -3
- package/rangerings/enum.js +0 -2
- package/rangerings/index.js +0 -5
- package/rangerings/plugin.js +0 -543
- package/rangerings/rangeringangletext.js +0 -326
- package/rangerings/ring-account.js +0 -112
- package/timetracks/index.js +0 -1
- package/util/build-strategy/general-strategy.js +0 -62
- package/util/gl-util/uniform-block/shader.js +0 -1
- package/util/heatwavedatamanager/index.js +0 -2
- package/util/heatwavedatamanager/pointcoordsmeta.js +0 -22
- package/util/jshelpers/data-filler.js +0 -17
- package/util/jshelpers/equality.js +0 -18
- package/util/jshelpers/index.js +0 -2
- package/util/jshelpers/timefilters.js +0 -30
- package/util/programs/index.js +0 -1
- package/util/surface-line-data/arc-bboxes.js +0 -25
- package/util/surface-line-data/arcs-to-cuts.js +0 -50
- package/util/surface-line-data/cut-arc.js +0 -1
- package/util/surface-line-data/flow.js +0 -28
- package/util/surface-line-data/rbush-manager.js +0 -1
- package/util/surface-line-data/types.js +0 -1
- package/util/surface-line-data/web-worker.js +0 -1
- package/write-text/context-text3old.js +0 -152
- package/write-text/index.js +0 -1
- package/write-text/writer-plugin.js +0 -8
- /package/{heatwave/isobar/quadtreecontours.js → Math/contour/quadtreecontours1.js} +0 -0
- /package/pin/{pin-object-array.js → pin-object-array1.js} +0 -0
- /package/pin/{pin-point-totem.js → pin-point-totem1.js} +0 -0
- /package/{circle-line-chain/init.js → programs/polygon-on-globe/partial-tesselation.js} +0 -0
- /package/{point-heat-map → tracks/point-heat-map}/index.js +0 -0
- /package/{point-tracks → tracks/point-tracks}/key-methods.js +0 -0
- /package/{timetracks → tracks/timetracks}/plugin-line-strip.js +0 -0
- /package/{arrowfield → vectorfield/arrowfield}/adaptor.js +0 -0
- /package/{waveparticles → vectorfield/waveparticles}/adaptor.js +0 -0
- /package/{waveparticles → vectorfield/waveparticles}/index.js +0 -0
- /package/{wind → vectorfield/wind}/imagetovectorfieldandmagnitude.js +0 -0
- /package/{wind → vectorfield/wind}/vectorfieldimage.js +0 -0
- /package/write-text/{context-text.js → context-textDELETE.js} +0 -0
- /package/{heatwave/isobar → write-text/objectarraylabels}/objectarraylabels.js +0 -0
package/bearing-line/plugin.js
DELETED
|
@@ -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
|
-
}
|