@antv/l7-layers 2.17.2 → 2.17.4

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 (242) hide show
  1. package/es/Geometry/index.js +31 -9
  2. package/es/Geometry/models/billboard.js +89 -51
  3. package/es/Geometry/models/plane.js +143 -81
  4. package/es/Geometry/models/sprite.js +118 -60
  5. package/es/canvas/index.js +33 -10
  6. package/es/canvas/models/canvas.js +97 -41
  7. package/es/citybuliding/building.js +27 -8
  8. package/es/citybuliding/models/build.js +82 -57
  9. package/es/core/BaseLayer.js +478 -313
  10. package/es/core/BaseModel.js +80 -51
  11. package/es/core/CommonStyleAttribute.js +5 -2
  12. package/es/core/LayerPickService.js +32 -21
  13. package/es/core/TextureService.js +13 -0
  14. package/es/core/interface.js +24 -17
  15. package/es/core/shape/Path.js +20 -13
  16. package/es/core/shape/extrude.js +39 -27
  17. package/es/core/triangulation.js +136 -99
  18. package/es/earth/index.js +33 -9
  19. package/es/earth/models/atmosphere.js +54 -30
  20. package/es/earth/models/base.js +85 -47
  21. package/es/earth/models/bloomsphere.js +54 -30
  22. package/es/earth/utils.js +13 -9
  23. package/es/heatmap/index.js +40 -10
  24. package/es/heatmap/models/grid.js +52 -28
  25. package/es/heatmap/models/grid3d.js +52 -28
  26. package/es/heatmap/models/heatmap.js +149 -92
  27. package/es/heatmap/models/hexagon.js +52 -28
  28. package/es/heatmap/triangulation.js +4 -0
  29. package/es/image/index.js +28 -9
  30. package/es/image/models/image.js +100 -66
  31. package/es/index.js +17 -9
  32. package/es/line/index.js +35 -9
  33. package/es/line/models/arc.js +114 -64
  34. package/es/line/models/arc_3d.js +102 -58
  35. package/es/line/models/earthArc_3d.js +105 -60
  36. package/es/line/models/flow.js +60 -36
  37. package/es/line/models/great_circle.js +94 -53
  38. package/es/line/models/line.js +138 -86
  39. package/es/line/models/linearline.js +76 -43
  40. package/es/line/models/simpleLine.js +69 -39
  41. package/es/line/models/wall.js +92 -52
  42. package/es/mask/index.js +28 -9
  43. package/es/mask/models/fill.js +54 -29
  44. package/es/plugins/DataMappingPlugin.js +114 -78
  45. package/es/plugins/DataSourcePlugin.js +68 -45
  46. package/es/plugins/FeatureScalePlugin.js +122 -67
  47. package/es/plugins/LayerAnimateStylePlugin.js +5 -0
  48. package/es/plugins/LayerMaskPlugin.js +11 -3
  49. package/es/plugins/LayerModelPlugin.js +108 -69
  50. package/es/plugins/LayerStylePlugin.js +9 -3
  51. package/es/plugins/LightingPlugin.js +18 -12
  52. package/es/plugins/MultiPassRendererPlugin.js +16 -11
  53. package/es/plugins/PixelPickingPlugin.js +21 -12
  54. package/es/plugins/RegisterStyleAttributePlugin.js +12 -5
  55. package/es/plugins/ShaderUniformPlugin.js +27 -13
  56. package/es/plugins/UpdateModelPlugin.js +5 -0
  57. package/es/plugins/UpdateStyleAttributePlugin.js +11 -5
  58. package/es/point/index.js +78 -26
  59. package/es/point/models/earthExtrude.js +95 -58
  60. package/es/point/models/earthFill.js +80 -52
  61. package/es/point/models/extrude.js +94 -57
  62. package/es/point/models/fill.js +81 -56
  63. package/es/point/models/fillmage.js +100 -60
  64. package/es/point/models/image.js +83 -47
  65. package/es/point/models/index.js +2 -2
  66. package/es/point/models/normal.js +54 -30
  67. package/es/point/models/radar.js +63 -38
  68. package/es/point/models/simplePoint.js +62 -38
  69. package/es/point/models/text.js +296 -199
  70. package/es/point/shape/extrude.js +13 -4
  71. package/es/polygon/index.js +41 -11
  72. package/es/polygon/models/extrude.js +135 -87
  73. package/es/polygon/models/fill.js +79 -50
  74. package/es/polygon/models/index.js +2 -3
  75. package/es/polygon/models/ocean.js +76 -42
  76. package/es/polygon/models/water.js +71 -37
  77. package/es/raster/buffers/triangulation.js +4 -2
  78. package/es/raster/index.js +32 -9
  79. package/es/raster/models/raster.js +116 -80
  80. package/es/raster/models/rasterRgb.js +127 -84
  81. package/es/raster/models/rasterTerrainRgb.js +84 -56
  82. package/es/tile/interaction/getRasterData.js +20 -14
  83. package/es/tile/interaction/utils.js +9 -7
  84. package/es/tile/manager/base.js +96 -63
  85. package/es/tile/service/TileLayerService.js +55 -33
  86. package/es/tile/service/TilePickService.js +40 -26
  87. package/es/tile/service/TileSourceService.js +7 -3
  88. package/es/tile/tileFactory/DebugTile.js +46 -29
  89. package/es/tile/tileFactory/ImageTile.js +38 -20
  90. package/es/tile/tileFactory/MaskTile.js +43 -22
  91. package/es/tile/tileFactory/RasterRGBTile.js +42 -22
  92. package/es/tile/tileFactory/RasterTerrainRGBTile.js +38 -20
  93. package/es/tile/tileFactory/RasterTile.js +53 -30
  94. package/es/tile/tileFactory/Tile.js +97 -63
  95. package/es/tile/tileFactory/VectorTile.js +68 -41
  96. package/es/tile/tileFactory/index.js +11 -0
  97. package/es/tile/tileFactory/layers/TileDebugLayer.js +27 -6
  98. package/es/tile/tileFactory/util.js +3 -0
  99. package/es/tile/tileLayer/BaseLayer.js +146 -105
  100. package/es/tile/utils.js +1 -1
  101. package/es/utils/blend.js +2 -0
  102. package/es/utils/collision-index.js +16 -9
  103. package/es/utils/extrude_polyline.js +149 -101
  104. package/es/utils/grid-index.js +27 -2
  105. package/es/utils/identityScale.js +8 -0
  106. package/es/utils/layerData.js +44 -30
  107. package/es/utils/multiPassRender.js +13 -11
  108. package/es/utils/polylineNormal.js +37 -31
  109. package/es/utils/simpleLine.js +16 -2
  110. package/es/utils/stencil.js +3 -2
  111. package/es/utils/symbol-layout.js +53 -27
  112. package/es/wind/index.js +29 -9
  113. package/es/wind/models/utils.js +51 -26
  114. package/es/wind/models/wind.js +147 -101
  115. package/es/wind/models/windRender.js +66 -53
  116. package/lib/Geometry/index.js +38 -9
  117. package/lib/Geometry/models/billboard.js +97 -51
  118. package/lib/Geometry/models/index.js +5 -0
  119. package/lib/Geometry/models/plane.js +151 -79
  120. package/lib/Geometry/models/sprite.js +127 -60
  121. package/lib/canvas/index.js +40 -10
  122. package/lib/canvas/models/canvas.js +101 -41
  123. package/lib/canvas/models/index.js +3 -0
  124. package/lib/citybuliding/building.js +35 -8
  125. package/lib/citybuliding/models/build.js +92 -57
  126. package/lib/core/BaseLayer.js +469 -313
  127. package/lib/core/BaseModel.js +90 -51
  128. package/lib/core/CommonStyleAttribute.js +7 -2
  129. package/lib/core/LayerPickService.js +37 -21
  130. package/lib/core/TextureService.js +16 -0
  131. package/lib/core/interface.js +31 -21
  132. package/lib/core/schema.js +1 -0
  133. package/lib/core/shape/Path.js +31 -14
  134. package/lib/core/shape/extrude.js +62 -27
  135. package/lib/core/triangulation.js +177 -98
  136. package/lib/earth/index.js +43 -9
  137. package/lib/earth/models/atmosphere.js +63 -30
  138. package/lib/earth/models/base.js +90 -47
  139. package/lib/earth/models/bloomsphere.js +63 -30
  140. package/lib/earth/utils.js +31 -7
  141. package/lib/heatmap/index.js +48 -10
  142. package/lib/heatmap/models/grid.js +60 -28
  143. package/lib/heatmap/models/grid3d.js +60 -28
  144. package/lib/heatmap/models/heatmap.js +166 -92
  145. package/lib/heatmap/models/hexagon.js +60 -28
  146. package/lib/heatmap/models/index.js +6 -0
  147. package/lib/heatmap/triangulation.js +5 -0
  148. package/lib/image/index.js +36 -9
  149. package/lib/image/models/image.js +109 -66
  150. package/lib/image/models/index.js +3 -0
  151. package/lib/index.js +61 -7
  152. package/lib/line/index.js +40 -9
  153. package/lib/line/models/arc.js +124 -62
  154. package/lib/line/models/arc_3d.js +113 -56
  155. package/lib/line/models/earthArc_3d.js +115 -58
  156. package/lib/line/models/flow.js +70 -36
  157. package/lib/line/models/great_circle.js +104 -53
  158. package/lib/line/models/index.js +11 -0
  159. package/lib/line/models/line.js +146 -84
  160. package/lib/line/models/linearline.js +88 -43
  161. package/lib/line/models/simpleLine.js +79 -39
  162. package/lib/line/models/wall.js +103 -52
  163. package/lib/mask/index.js +36 -9
  164. package/lib/mask/models/fill.js +63 -29
  165. package/lib/mask/models/index.js +3 -0
  166. package/lib/plugins/DataMappingPlugin.js +125 -78
  167. package/lib/plugins/DataSourcePlugin.js +76 -45
  168. package/lib/plugins/FeatureScalePlugin.js +138 -67
  169. package/lib/plugins/LayerAnimateStylePlugin.js +10 -0
  170. package/lib/plugins/LayerMaskPlugin.js +17 -4
  171. package/lib/plugins/LayerModelPlugin.js +117 -70
  172. package/lib/plugins/LayerStylePlugin.js +14 -4
  173. package/lib/plugins/LightingPlugin.js +25 -12
  174. package/lib/plugins/MultiPassRendererPlugin.js +22 -11
  175. package/lib/plugins/PixelPickingPlugin.js +27 -12
  176. package/lib/plugins/RegisterStyleAttributePlugin.js +19 -5
  177. package/lib/plugins/ShaderUniformPlugin.js +34 -13
  178. package/lib/plugins/UpdateModelPlugin.js +10 -1
  179. package/lib/plugins/UpdateStyleAttributePlugin.js +16 -5
  180. package/lib/point/index.js +83 -26
  181. package/lib/point/models/earthExtrude.js +106 -58
  182. package/lib/point/models/earthFill.js +110 -52
  183. package/lib/point/models/extrude.js +103 -57
  184. package/lib/point/models/fill.js +90 -54
  185. package/lib/point/models/fillmage.js +107 -58
  186. package/lib/point/models/image.js +92 -47
  187. package/lib/point/models/index.js +12 -1
  188. package/lib/point/models/normal.js +64 -30
  189. package/lib/point/models/radar.js +72 -38
  190. package/lib/point/models/simplePoint.js +72 -38
  191. package/lib/point/models/text.js +305 -199
  192. package/lib/point/shape/extrude.js +20 -4
  193. package/lib/polygon/index.js +48 -11
  194. package/lib/polygon/models/extrude.js +146 -87
  195. package/lib/polygon/models/fill.js +89 -50
  196. package/lib/polygon/models/index.js +14 -2
  197. package/lib/polygon/models/ocean.js +88 -42
  198. package/lib/polygon/models/water.js +82 -37
  199. package/lib/raster/buffers/triangulation.js +7 -3
  200. package/lib/raster/index.js +40 -9
  201. package/lib/raster/models/index.js +5 -0
  202. package/lib/raster/models/raster.js +125 -80
  203. package/lib/raster/models/rasterRgb.js +139 -84
  204. package/lib/raster/models/rasterTerrainRgb.js +93 -56
  205. package/lib/tile/interaction/getRasterData.js +25 -14
  206. package/lib/tile/interaction/utils.js +19 -7
  207. package/lib/tile/manager/base.js +104 -63
  208. package/lib/tile/service/TileLayerService.js +60 -33
  209. package/lib/tile/service/TilePickService.js +48 -26
  210. package/lib/tile/service/TileSourceService.js +16 -2
  211. package/lib/tile/style/utils.js +3 -0
  212. package/lib/tile/tileFactory/DebugTile.js +54 -29
  213. package/lib/tile/tileFactory/ImageTile.js +46 -20
  214. package/lib/tile/tileFactory/MaskTile.js +51 -22
  215. package/lib/tile/tileFactory/RasterRGBTile.js +50 -22
  216. package/lib/tile/tileFactory/RasterTerrainRGBTile.js +46 -20
  217. package/lib/tile/tileFactory/RasterTile.js +63 -30
  218. package/lib/tile/tileFactory/Tile.js +102 -63
  219. package/lib/tile/tileFactory/VectorTile.js +76 -41
  220. package/lib/tile/tileFactory/index.js +25 -0
  221. package/lib/tile/tileFactory/layers/TileDebugLayer.js +32 -6
  222. package/lib/tile/tileFactory/util.js +9 -0
  223. package/lib/tile/tileLayer/BaseLayer.js +153 -105
  224. package/lib/tile/utils.js +5 -1
  225. package/lib/utils/blend.js +5 -0
  226. package/lib/utils/collision-index.js +25 -9
  227. package/lib/utils/extrude_polyline.js +181 -101
  228. package/lib/utils/grid-index.js +28 -2
  229. package/lib/utils/identityScale.js +9 -0
  230. package/lib/utils/layerData.js +49 -30
  231. package/lib/utils/multiPassRender.js +16 -11
  232. package/lib/utils/polylineNormal.js +66 -31
  233. package/lib/utils/simpleLine.js +21 -2
  234. package/lib/utils/stencil.js +4 -0
  235. package/lib/utils/symbol-layout.js +55 -27
  236. package/lib/wind/index.js +37 -9
  237. package/lib/wind/models/index.js +3 -0
  238. package/lib/wind/models/utils.js +62 -26
  239. package/lib/wind/models/wind.js +157 -101
  240. package/lib/wind/models/windRender.js +71 -53
  241. package/lib/wind/models/windShader.js +1 -0
  242. package/package.json +7 -7
package/es/earth/utils.js CHANGED
@@ -1,17 +1,16 @@
1
1
  import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
2
- import { mat4, vec3 } from 'gl-matrix';
3
- // 该文件专门记录地球模式的数值
4
-
2
+ import { mat4, vec3 } from 'gl-matrix'; // 该文件专门记录地球模式的数值
5
3
  // 地球网格半径
4
+
6
5
  export var EARTH_RADIUS = 100;
7
6
  export var EARTH_SEGMENTS = 36;
8
7
  export var EARTH_RADIUS_OUTER = 40;
9
-
10
8
  /**
11
9
  * 角度转弧度
12
10
  * @param deg
13
11
  * @returns
14
12
  */
13
+
15
14
  function torad(deg) {
16
15
  return deg / 180 * Math.acos(-1);
17
16
  }
@@ -21,25 +20,26 @@ function torad(deg) {
21
20
  * @param latitude 纬度
22
21
  * @param radius 半径
23
22
  */
23
+
24
+
24
25
  export function lglt2xyz(lnglat) {
25
26
  // TODO: + Math.PI/2 是为了对齐坐标
26
27
  var lng = torad(lnglat[0]) + Math.PI / 2;
27
- var lat = torad(lnglat[1]);
28
+ var lat = torad(lnglat[1]); // TODO: 手动增加一些偏移,减轻面的冲突
28
29
 
29
- // TODO: 手动增加一些偏移,减轻面的冲突
30
30
  var radius = EARTH_RADIUS + Math.random() * 0.4;
31
31
  var z = radius * Math.cos(lat) * Math.cos(lng);
32
32
  var x = radius * Math.cos(lat) * Math.sin(lng);
33
33
  var y = radius * Math.sin(lat);
34
34
  return [x, y, z];
35
35
  }
36
-
37
36
  /**
38
37
  * 构建地球球体网格
39
38
  * @param radius
40
39
  * @param opt
41
40
  * @returns
42
41
  */
42
+
43
43
  export function primitiveSphere(radius, opt) {
44
44
  var matRotY = mat4.create();
45
45
  var matRotZ = mat4.create();
@@ -56,9 +56,11 @@ export function primitiveSphere(radius, opt) {
56
56
  var positionsArr = [];
57
57
  var normalArr = [];
58
58
  var uvs = [];
59
+
59
60
  for (var zRotationStep = 0; zRotationStep <= totalZRotationSteps; zRotationStep++) {
60
61
  var normalizedZ = zRotationStep / totalZRotationSteps;
61
62
  var angleZ = normalizedZ * Math.PI;
63
+
62
64
  for (var yRotationStep = 0; yRotationStep <= totalYRotationSteps; yRotationStep++) {
63
65
  var normalizedY = yRotationStep / totalYRotationSteps;
64
66
  var angleY = normalizedY * Math.PI * 2;
@@ -73,14 +75,15 @@ export function primitiveSphere(radius, opt) {
73
75
  positionsArr.push.apply(positionsArr, _toConsumableArray(tmpVec3.slice()));
74
76
  vec3.normalize(tmpVec3, tmpVec3);
75
77
  normalArr.push.apply(normalArr, _toConsumableArray(tmpVec3.slice()));
76
- uvs.push([normalizedY, 1 - normalizedZ]);
78
+ uvs.push([normalizedY, 1 - normalizedZ]); // position 和 uv 一起存储
77
79
 
78
- // position 和 uv 一起存储
79
80
  positionsArr.push(normalizedY, 1 - normalizedZ);
80
81
  }
82
+
81
83
  if (zRotationStep > 0) {
82
84
  var verticesCount = positions.length;
83
85
  var firstIndex = verticesCount - 2 * (totalYRotationSteps + 1);
86
+
84
87
  for (; firstIndex + totalYRotationSteps + 2 < verticesCount; firstIndex++) {
85
88
  indices.push([firstIndex, firstIndex + 1, firstIndex + totalYRotationSteps + 1]);
86
89
  indicesArr.push(firstIndex, firstIndex + 1, firstIndex + totalYRotationSteps + 1);
@@ -89,6 +92,7 @@ export function primitiveSphere(radius, opt) {
89
92
  }
90
93
  }
91
94
  }
95
+
92
96
  return {
93
97
  cells: indices,
94
98
  positions: positions,
@@ -7,52 +7,71 @@ import _possibleConstructorReturn from "@babel/runtime/helpers/esm/possibleConst
7
7
  import _getPrototypeOf from "@babel/runtime/helpers/esm/getPrototypeOf";
8
8
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
9
9
  import _regeneratorRuntime from "@babel/runtime/regenerator";
10
+
10
11
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
12
+
11
13
  function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
14
+
12
15
  import BaseLayer from "../core/BaseLayer";
13
16
  import HeatMapModels from "./models";
17
+
14
18
  var HeatMapLayer = /*#__PURE__*/function (_BaseLayer) {
15
19
  _inherits(HeatMapLayer, _BaseLayer);
20
+
16
21
  var _super = _createSuper(HeatMapLayer);
22
+
17
23
  function HeatMapLayer() {
18
24
  var _this;
25
+
19
26
  _classCallCheck(this, HeatMapLayer);
27
+
20
28
  for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
21
29
  args[_key] = arguments[_key];
22
30
  }
31
+
23
32
  _this = _super.call.apply(_super, [this].concat(args));
33
+
24
34
  _defineProperty(_assertThisInitialized(_this), "type", 'HeatMapLayer');
35
+
25
36
  return _this;
26
37
  }
38
+
27
39
  _createClass(HeatMapLayer, [{
28
40
  key: "buildModels",
29
41
  value: function () {
30
42
  var _buildModels = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
31
43
  var shape;
32
44
  return _regeneratorRuntime.wrap(function _callee$(_context) {
33
- while (1) switch (_context.prev = _context.next) {
34
- case 0:
35
- shape = this.getModelType();
36
- this.layerModel = new HeatMapModels[shape](this);
37
- _context.next = 4;
38
- return this.initLayerModels();
39
- case 4:
40
- case "end":
41
- return _context.stop();
45
+ while (1) {
46
+ switch (_context.prev = _context.next) {
47
+ case 0:
48
+ shape = this.getModelType();
49
+ this.layerModel = new HeatMapModels[shape](this);
50
+ _context.next = 4;
51
+ return this.initLayerModels();
52
+
53
+ case 4:
54
+ case "end":
55
+ return _context.stop();
56
+ }
42
57
  }
43
58
  }, _callee, this);
44
59
  }));
60
+
45
61
  function buildModels() {
46
62
  return _buildModels.apply(this, arguments);
47
63
  }
64
+
48
65
  return buildModels;
49
66
  }()
50
67
  }, {
51
68
  key: "renderModels",
52
69
  value: function renderModels() {
53
70
  var _this2 = this;
71
+
54
72
  var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
55
73
  var shape = this.getModelType();
74
+
56
75
  if (shape === 'heatmap') {
57
76
  if (this.layerModel) {
58
77
  this.layerModel.render(options); // 独立的渲染流程
@@ -60,9 +79,11 @@ var HeatMapLayer = /*#__PURE__*/function (_BaseLayer) {
60
79
 
61
80
  return this;
62
81
  }
82
+
63
83
  if (this.encodeDataLength <= 0 && !this.forceRender) {
64
84
  return this;
65
85
  }
86
+
66
87
  this.hooks.beforeRender.call();
67
88
  this.models.forEach(function (model) {
68
89
  return model.draw({
@@ -87,24 +108,33 @@ var HeatMapLayer = /*#__PURE__*/function (_BaseLayer) {
87
108
  key: "getModelType",
88
109
  value: function getModelType() {
89
110
  var _shapeAttribute$scale;
111
+
90
112
  var shapeAttribute = this.styleAttributeService.getLayerStyleAttribute('shape');
113
+
91
114
  var _this$getLayerConfig = this.getLayerConfig(),
92
- shape3d = _this$getLayerConfig.shape3d;
115
+ shape3d = _this$getLayerConfig.shape3d;
116
+
93
117
  var source = this.getSource();
94
118
  var sourceType = source.data.type;
95
119
  var shape = (shapeAttribute === null || shapeAttribute === void 0 ? void 0 : (_shapeAttribute$scale = shapeAttribute.scale) === null || _shapeAttribute$scale === void 0 ? void 0 : _shapeAttribute$scale.field) || 'heatmap';
120
+
96
121
  if (shape === 'heatmap' || shape === 'heatmap3d') {
97
122
  return 'heatmap';
98
123
  }
124
+
99
125
  if (sourceType === 'hexagon') {
100
126
  return (shape3d === null || shape3d === void 0 ? void 0 : shape3d.indexOf(shape)) === -1 ? 'hexagon' : 'grid3d';
101
127
  }
128
+
102
129
  if (sourceType === 'grid') {
103
130
  return (shape3d === null || shape3d === void 0 ? void 0 : shape3d.indexOf(shape)) === -1 ? 'grid' : 'grid3d';
104
131
  }
132
+
105
133
  return 'heatmap';
106
134
  }
107
135
  }]);
136
+
108
137
  return HeatMapLayer;
109
138
  }(BaseLayer);
139
+
110
140
  export { HeatMapLayer as default };
@@ -5,29 +5,40 @@ import _inherits from "@babel/runtime/helpers/esm/inherits";
5
5
  import _possibleConstructorReturn from "@babel/runtime/helpers/esm/possibleConstructorReturn";
6
6
  import _getPrototypeOf from "@babel/runtime/helpers/esm/getPrototypeOf";
7
7
  import _regeneratorRuntime from "@babel/runtime/regenerator";
8
+
8
9
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
10
+
9
11
  function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
12
+
10
13
  import { AttributeType, gl } from '@antv/l7-core';
11
14
  import BaseModel from "../../core/BaseModel";
12
15
  import { HeatmapGridTriangulation } from "../../core/triangulation";
16
+
13
17
  /* babel-plugin-inline-import '../shaders/grid_vert.glsl' */
14
18
  var heatmapGridVert = "precision highp float;\r\n// \u591A\u8FB9\u5F62\u9876\u70B9\u5750\u6807\r\nattribute vec3 a_Position;\r\n// \u591A\u8FB9\u5F62\u7ECF\u7EAC\u5EA6\u5750\u6807\r\nattribute vec3 a_Pos;\r\nattribute float a_Size;\r\nattribute vec4 a_Color;\r\nuniform vec2 u_radius;\r\nuniform float u_coverage: 0.9;\r\nuniform float u_angle: 0;\r\nuniform mat4 u_ModelMatrix;\r\nuniform mat4 u_Mvp;\r\nvarying vec4 v_color;\r\n\r\nuniform vec2 u_sceneCenterMercator;\r\n\r\n#pragma include \"projection\"\r\n#pragma include \"project\"\r\n#pragma include \"picking\"\r\n\r\nvoid main() {\r\n v_color = a_Color;\r\n\r\n mat2 rotationMatrix = mat2(cos(u_angle), sin(u_angle), -sin(u_angle), cos(u_angle));\r\n vec2 offset = a_Position.xy * u_radius * rotationMatrix * u_coverage ;\r\n // vec2 lnglat = unProjectFlat(a_Pos.xy + offset);\r\n // vec4 project_pos = project_position(vec4(lnglat, 0, 1.0));\r\n // gl_Position = project_common_position_to_clipspace(project_pos);\r\n\r\n if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x\r\n vec2 lnglat = unProjectFlat(a_Pos.xy + offset);\r\n vec2 customLnglat = customProject(lnglat) - u_sceneCenterMercator; // \u5C06\u7ECF\u7EAC\u5EA6\u8F6C\u6362\u4E3A\u9AD8\u5FB72.0\u9700\u8981\u7684\u5E73\u9762\u5750\u6807\r\n vec4 project_pos = project_position(vec4(customLnglat, 0, 1.0));\r\n gl_Position = u_Mvp * (project_pos);\r\n } else {\r\n vec2 lnglat = unProjectFlat(a_Pos.xy + offset);\r\n vec4 project_pos = project_position(vec4(lnglat, 0, 1.0));\r\n gl_Position = project_common_position_to_clipspace(project_pos);\r\n }\r\n\r\n setPickingColor(a_PickingColor);\r\n}\r\n";
19
+
15
20
  /* babel-plugin-inline-import '../shaders/hexagon_frag.glsl' */
16
21
  var heatmapGridFrag = "precision highp float;\nvarying vec4 v_color;\nuniform float u_opacity: 1;\n\n#pragma include \"picking\"\n\nvoid main() {\n gl_FragColor = v_color;\n gl_FragColor.a *= u_opacity;\n\n gl_FragColor = filterColor(gl_FragColor);\n}\n";
22
+
17
23
  var GridModel = /*#__PURE__*/function (_BaseModel) {
18
24
  _inherits(GridModel, _BaseModel);
25
+
19
26
  var _super = _createSuper(GridModel);
27
+
20
28
  function GridModel() {
21
29
  _classCallCheck(this, GridModel);
30
+
22
31
  return _super.apply(this, arguments);
23
32
  }
33
+
24
34
  _createClass(GridModel, [{
25
35
  key: "getUninforms",
26
36
  value: function getUninforms() {
27
37
  var _ref = this.layer.getLayerConfig(),
28
- opacity = _ref.opacity,
29
- coverage = _ref.coverage,
30
- angle = _ref.angle;
38
+ opacity = _ref.opacity,
39
+ coverage = _ref.coverage,
40
+ angle = _ref.angle;
41
+
31
42
  return {
32
43
  u_opacity: opacity || 1.0,
33
44
  u_coverage: coverage || 0.9,
@@ -40,18 +51,23 @@ var GridModel = /*#__PURE__*/function (_BaseModel) {
40
51
  value: function () {
41
52
  var _initModels = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
42
53
  return _regeneratorRuntime.wrap(function _callee$(_context) {
43
- while (1) switch (_context.prev = _context.next) {
44
- case 0:
45
- return _context.abrupt("return", this.buildModels());
46
- case 1:
47
- case "end":
48
- return _context.stop();
54
+ while (1) {
55
+ switch (_context.prev = _context.next) {
56
+ case 0:
57
+ return _context.abrupt("return", this.buildModels());
58
+
59
+ case 1:
60
+ case "end":
61
+ return _context.stop();
62
+ }
49
63
  }
50
64
  }, _callee, this);
51
65
  }));
66
+
52
67
  function initModels() {
53
68
  return _initModels.apply(this, arguments);
54
69
  }
70
+
55
71
  return initModels;
56
72
  }()
57
73
  }, {
@@ -60,31 +76,37 @@ var GridModel = /*#__PURE__*/function (_BaseModel) {
60
76
  var _buildModels = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2() {
61
77
  var model;
62
78
  return _regeneratorRuntime.wrap(function _callee2$(_context2) {
63
- while (1) switch (_context2.prev = _context2.next) {
64
- case 0:
65
- _context2.next = 2;
66
- return this.layer.buildLayerModel({
67
- moduleName: 'heatmapGrid',
68
- vertexShader: heatmapGridVert,
69
- fragmentShader: heatmapGridFrag,
70
- triangulation: HeatmapGridTriangulation,
71
- primitive: gl.TRIANGLES,
72
- depth: {
73
- enable: false
74
- }
75
- });
76
- case 2:
77
- model = _context2.sent;
78
- return _context2.abrupt("return", [model]);
79
- case 4:
80
- case "end":
81
- return _context2.stop();
79
+ while (1) {
80
+ switch (_context2.prev = _context2.next) {
81
+ case 0:
82
+ _context2.next = 2;
83
+ return this.layer.buildLayerModel({
84
+ moduleName: 'heatmapGrid',
85
+ vertexShader: heatmapGridVert,
86
+ fragmentShader: heatmapGridFrag,
87
+ triangulation: HeatmapGridTriangulation,
88
+ primitive: gl.TRIANGLES,
89
+ depth: {
90
+ enable: false
91
+ }
92
+ });
93
+
94
+ case 2:
95
+ model = _context2.sent;
96
+ return _context2.abrupt("return", [model]);
97
+
98
+ case 4:
99
+ case "end":
100
+ return _context2.stop();
101
+ }
82
102
  }
83
103
  }, _callee2, this);
84
104
  }));
105
+
85
106
  function buildModels() {
86
107
  return _buildModels.apply(this, arguments);
87
108
  }
109
+
88
110
  return buildModels;
89
111
  }()
90
112
  }, {
@@ -110,6 +132,8 @@ var GridModel = /*#__PURE__*/function (_BaseModel) {
110
132
  });
111
133
  }
112
134
  }]);
135
+
113
136
  return GridModel;
114
137
  }(BaseModel);
138
+
115
139
  export { GridModel as default };
@@ -5,29 +5,40 @@ import _inherits from "@babel/runtime/helpers/esm/inherits";
5
5
  import _possibleConstructorReturn from "@babel/runtime/helpers/esm/possibleConstructorReturn";
6
6
  import _getPrototypeOf from "@babel/runtime/helpers/esm/getPrototypeOf";
7
7
  import _regeneratorRuntime from "@babel/runtime/regenerator";
8
+
8
9
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
10
+
9
11
  function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
12
+
10
13
  import { AttributeType, gl } from '@antv/l7-core';
11
14
  import BaseModel from "../../core/BaseModel";
12
15
  import { PointExtrudeTriangulation } from "../../core/triangulation";
16
+
13
17
  /* babel-plugin-inline-import '../shaders/hexagon_3d_vert.glsl' */
14
18
  var heatmapGrid3dVert = "precision highp float;\n// \u591A\u8FB9\u5F62\u9876\u70B9\u5750\u6807\nattribute vec3 a_Position;\n// \u591A\u8FB9\u5F62\u7ECF\u7EAC\u5EA6\u5750\u6807\nattribute vec3 a_Pos;\n\nattribute vec3 a_Normal;\nattribute float a_Size;\nattribute vec4 a_Color;\nuniform vec2 u_radius;\nuniform float u_coverage: 0.9;\nuniform float u_angle: 0;\nuniform mat4 u_ModelMatrix;\nuniform mat4 u_Mvp;\nvarying vec4 v_color;\n\nuniform vec2 u_sceneCenterMercator;\n\n#pragma include \"projection\"\n#pragma include \"project\"\n#pragma include \"light\"\n#pragma include \"picking\"\n\n\nvoid main() {\n mat2 rotationMatrix = mat2(cos(u_angle), sin(u_angle), -sin(u_angle), cos(u_angle));\n vec2 offset =(vec2(a_Position.xy * u_radius * rotationMatrix * u_coverage));\n\n\n if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x\n \n vec2 lnglat = unProjectFlat(a_Pos.xy + offset); // \u7ECF\u7EAC\u5EA6\n vec2 customLnglat = customProject(lnglat) - u_sceneCenterMercator; // \u5C06\u7ECF\u7EAC\u5EA6\u8F6C\u6362\u4E3A\u9AD8\u5FB72.0\u9700\u8981\u7684\u5E73\u9762\u5750\u6807\n vec4 project_pos = project_position(vec4(customLnglat, a_Position.z * a_Size, 1.0));\n\n float lightWeight = calc_lighting(project_pos);\n v_color =vec4(a_Color.rgb*lightWeight, a_Color.w);\n \n gl_Position = u_Mvp * vec4(customLnglat , a_Position.z * a_Size, 1.0);\n } else {\n vec2 lnglat = unProjectFlat(a_Pos.xy + offset); // \u5B9E\u9645\u7684\u7ECF\u7EAC\u5EA6\n vec4 project_pos = project_position(vec4(lnglat, a_Position.z * a_Size, 1.0));\n \n float lightWeight = calc_lighting(project_pos);\n v_color =vec4(a_Color.rgb*lightWeight, a_Color.w);\n \n gl_Position = project_common_position_to_clipspace(project_pos);\n }\n\n\n\n setPickingColor(a_PickingColor);\n}\n";
19
+
15
20
  /* babel-plugin-inline-import '../shaders/hexagon_frag.glsl' */
16
21
  var heatmapGridFrag = "precision highp float;\nvarying vec4 v_color;\nuniform float u_opacity: 1;\n\n#pragma include \"picking\"\n\nvoid main() {\n gl_FragColor = v_color;\n gl_FragColor.a *= u_opacity;\n\n gl_FragColor = filterColor(gl_FragColor);\n}\n";
22
+
17
23
  var Grid3DModel = /*#__PURE__*/function (_BaseModel) {
18
24
  _inherits(Grid3DModel, _BaseModel);
25
+
19
26
  var _super = _createSuper(Grid3DModel);
27
+
20
28
  function Grid3DModel() {
21
29
  _classCallCheck(this, Grid3DModel);
30
+
22
31
  return _super.apply(this, arguments);
23
32
  }
33
+
24
34
  _createClass(Grid3DModel, [{
25
35
  key: "getUninforms",
26
36
  value: function getUninforms() {
27
37
  var _ref = this.layer.getLayerConfig(),
28
- opacity = _ref.opacity,
29
- coverage = _ref.coverage,
30
- angle = _ref.angle;
38
+ opacity = _ref.opacity,
39
+ coverage = _ref.coverage,
40
+ angle = _ref.angle;
41
+
31
42
  return {
32
43
  u_opacity: opacity || 1.0,
33
44
  u_coverage: coverage || 1.0,
@@ -40,18 +51,23 @@ var Grid3DModel = /*#__PURE__*/function (_BaseModel) {
40
51
  value: function () {
41
52
  var _initModels = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
42
53
  return _regeneratorRuntime.wrap(function _callee$(_context) {
43
- while (1) switch (_context.prev = _context.next) {
44
- case 0:
45
- return _context.abrupt("return", this.buildModels());
46
- case 1:
47
- case "end":
48
- return _context.stop();
54
+ while (1) {
55
+ switch (_context.prev = _context.next) {
56
+ case 0:
57
+ return _context.abrupt("return", this.buildModels());
58
+
59
+ case 1:
60
+ case "end":
61
+ return _context.stop();
62
+ }
49
63
  }
50
64
  }, _callee, this);
51
65
  }));
66
+
52
67
  function initModels() {
53
68
  return _initModels.apply(this, arguments);
54
69
  }
70
+
55
71
  return initModels;
56
72
  }()
57
73
  }, {
@@ -60,31 +76,37 @@ var Grid3DModel = /*#__PURE__*/function (_BaseModel) {
60
76
  var _buildModels = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2() {
61
77
  var model;
62
78
  return _regeneratorRuntime.wrap(function _callee2$(_context2) {
63
- while (1) switch (_context2.prev = _context2.next) {
64
- case 0:
65
- _context2.next = 2;
66
- return this.layer.buildLayerModel({
67
- moduleName: 'heatmapGrid3d',
68
- vertexShader: heatmapGrid3dVert,
69
- fragmentShader: heatmapGridFrag,
70
- triangulation: PointExtrudeTriangulation,
71
- primitive: gl.TRIANGLES,
72
- depth: {
73
- enable: true
74
- }
75
- });
76
- case 2:
77
- model = _context2.sent;
78
- return _context2.abrupt("return", [model]);
79
- case 4:
80
- case "end":
81
- return _context2.stop();
79
+ while (1) {
80
+ switch (_context2.prev = _context2.next) {
81
+ case 0:
82
+ _context2.next = 2;
83
+ return this.layer.buildLayerModel({
84
+ moduleName: 'heatmapGrid3d',
85
+ vertexShader: heatmapGrid3dVert,
86
+ fragmentShader: heatmapGridFrag,
87
+ triangulation: PointExtrudeTriangulation,
88
+ primitive: gl.TRIANGLES,
89
+ depth: {
90
+ enable: true
91
+ }
92
+ });
93
+
94
+ case 2:
95
+ model = _context2.sent;
96
+ return _context2.abrupt("return", [model]);
97
+
98
+ case 4:
99
+ case "end":
100
+ return _context2.stop();
101
+ }
82
102
  }
83
103
  }, _callee2, this);
84
104
  }));
105
+
85
106
  function buildModels() {
86
107
  return _buildModels.apply(this, arguments);
87
108
  }
109
+
88
110
  return buildModels;
89
111
  }()
90
112
  }, {
@@ -143,6 +165,8 @@ var Grid3DModel = /*#__PURE__*/function (_BaseModel) {
143
165
  });
144
166
  }
145
167
  }]);
168
+
146
169
  return Grid3DModel;
147
170
  }(BaseModel);
171
+
148
172
  export { Grid3DModel as default };