@antv/l7-layers 2.9.1 → 2.9.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.
- package/es/point/models/radar.js +2 -6
- package/es/point/models/radar.js.map +1 -1
- package/es/tile/manager/tilePickerManager.d.ts +1 -0
- package/es/tile/manager/tilePickerManager.js +25 -3
- package/es/tile/manager/tilePickerManager.js.map +1 -1
- package/es/tile/tileFactory/base.d.ts +5 -2
- package/es/tile/tileFactory/base.js +71 -10
- package/es/tile/tileFactory/base.js.map +1 -1
- package/es/tile/tileFactory/rasterData.js +1 -1
- package/es/tile/tileFactory/rasterData.js.map +1 -1
- package/es/tile/utils.js +18 -13
- package/es/tile/utils.js.map +1 -1
- package/lib/point/models/radar.js +1 -5
- package/lib/point/models/radar.js.map +1 -1
- package/lib/tile/manager/tilePickerManager.js +25 -3
- package/lib/tile/manager/tilePickerManager.js.map +1 -1
- package/lib/tile/tileFactory/base.js +69 -9
- package/lib/tile/tileFactory/base.js.map +1 -1
- package/lib/tile/tileFactory/rasterData.js +1 -1
- package/lib/tile/tileFactory/rasterData.js.map +1 -1
- package/lib/tile/utils.js +18 -13
- package/lib/tile/utils.js.map +1 -1
- package/package.json +5 -5
package/es/tile/utils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/tile/utils.ts"],"names":["createLayerContainer","DOM","registerLayers","parentLayer","layers","map","layer","container","sceneContainer","setContainer","init","getLayerShape","layerType","layerShape","getAttribute","scale","field","values","getMaskValue","mask","getContainerSize","getContext","width","DPR","height","getBoundingClientRect","readRasterValue","tile","mapService","x","y","bbox","bboxPolygon","
|
|
1
|
+
{"version":3,"sources":["../../src/tile/utils.ts"],"names":["createLayerContainer","DOM","registerLayers","parentLayer","layers","map","layer","container","sceneContainer","setContainer","init","getLayerShape","layerType","layerShape","getAttribute","scale","field","values","getMaskValue","mask","getContainerSize","getContext","width","DPR","height","getBoundingClientRect","readRasterValue","tile","mapService","x","y","bbox","bboxPolygon","minLng","minLat","maxLng","maxLat","tileXY","lngLatToContainer","tileMaxXY","tilePixelWidth","tilePixelHeight","pos","tileWidth","data","tileHeight","indexX","Math","floor","indexY","index","max","readPixel","rendererService","readPixels","getContainer","xInDevicePixel","yInDevicePixel","pickedColors","Uint8Array"],"mappings":"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","sourcesContent":["import {\n createLayerContainer,\n ILayer,\n IMapService,\n IRendererService,\n} from '@antv/l7-core';\nimport { DOM, Tile } from '@antv/l7-utils';\nimport { Container } from 'inversify';\nexport function registerLayers(parentLayer: ILayer, layers: ILayer[]) {\n layers.map((layer) => {\n const container = createLayerContainer(\n parentLayer.sceneContainer as Container,\n );\n layer.setContainer(container, parentLayer.sceneContainer as Container);\n layer.init();\n });\n}\n\nexport function getLayerShape(layerType: string, layer: ILayer) {\n const layerShape = layer.getAttribute('shape');\n if (layerShape && layerShape.scale?.field) {\n if (layerShape.scale?.values === 'text') {\n return [layerShape.scale.field, layerShape.scale.values] as string[];\n }\n return layerShape.scale.field as string;\n }\n switch (layerType) {\n case 'PolygonLayer':\n return 'fill';\n case 'LineLayer':\n return 'tileline';\n case 'PointLayer':\n return 'circle';\n case 'RasterLayer':\n return 'image';\n default:\n return '';\n }\n}\n\nexport function getMaskValue(layerType: string, mask: boolean) {\n switch (layerType) {\n case 'PolygonLayer':\n return true;\n case 'LineLayer':\n return true;\n case 'PointLayer':\n return false;\n case 'RasterLayer':\n return mask;\n default:\n return mask;\n }\n}\n\nexport function getContainerSize(container: HTMLCanvasElement | HTMLElement) {\n if (!!(container as HTMLCanvasElement).getContext) {\n return {\n width: (container as HTMLCanvasElement).width / DOM.DPR,\n height: (container as HTMLCanvasElement).height / DOM.DPR,\n };\n } else {\n return container.getBoundingClientRect();\n }\n}\n\nexport function readRasterValue(\n tile: Tile,\n mapService: IMapService,\n x: number,\n y: number,\n) {\n const bbox = tile?.bboxPolygon?.bbox || [0, 0, 10, -10];\n\n const [minLng = 0, minLat = 0, maxLng = 10, maxLat = -10] = bbox;\n\n const tileXY = mapService.lngLatToContainer([minLng, minLat]);\n const tileMaxXY = mapService.lngLatToContainer([maxLng, maxLat]);\n\n const tilePixelWidth = tileMaxXY.x - tileXY.x;\n const tilePixelHeight = tileXY.y - tileMaxXY.y;\n const pos = [\n (x - tileXY.x) / tilePixelWidth, // x\n (y - tileMaxXY.y) / tilePixelHeight, // y\n ];\n\n const tileWidth = tile?.data?.width || 1;\n const tileHeight = tile?.data?.height || 1;\n\n const indexX = Math.floor(pos[0] * tileWidth);\n const indexY = Math.floor(pos[1] * tileHeight);\n const index = Math.max(0, indexY - 1) * tileWidth + indexX;\n\n const data = tile?.data?.data[index];\n\n return data;\n}\n\nexport function readPixel(\n x: number,\n y: number,\n rendererService: IRendererService,\n) {\n const { readPixels, getContainer } = rendererService;\n const xInDevicePixel = x * DOM.DPR;\n const yInDevicePixel = y * DOM.DPR;\n let { width, height } = getContainerSize(\n getContainer() as HTMLCanvasElement | HTMLElement,\n );\n width *= DOM.DPR;\n height *= DOM.DPR;\n if (\n xInDevicePixel > width - 1 * DOM.DPR ||\n xInDevicePixel < 0 ||\n yInDevicePixel > height - 1 * DOM.DPR ||\n yInDevicePixel < 0\n ) {\n return false;\n }\n\n const pickedColors = readPixels({\n x: Math.floor(xInDevicePixel),\n // 视口坐标系原点在左上,而 WebGL 在左下,需要翻转 Y 轴\n y: Math.floor(height - (y + 1) * DOM.DPR),\n width: 1,\n height: 1,\n data: new Uint8Array(1 * 1 * 4),\n });\n return pickedColors;\n}\n"],"file":"utils.js"}
|
|
@@ -208,11 +208,7 @@ var RadarModel = function (_BaseModel) {
|
|
|
208
208
|
enable: false
|
|
209
209
|
},
|
|
210
210
|
blend: this.getBlend(),
|
|
211
|
-
stencil: (0, _l7Utils.getMask)(mask, maskInside)
|
|
212
|
-
cull: {
|
|
213
|
-
enable: true,
|
|
214
|
-
face: (0, _l7Utils.getCullFace)(this.mapService.version)
|
|
215
|
-
}
|
|
211
|
+
stencil: (0, _l7Utils.getMask)(mask, maskInside)
|
|
216
212
|
})];
|
|
217
213
|
}
|
|
218
214
|
}, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/point/models/radar.ts"],"names":["RadarModel","layer","getLayerConfig","opacity","offsets","blend","speed","dataTextureTest","dataTextureNeedUpdate","judgeStyleAttributes","encodeData","getEncodedData","calDataFrame","cellLength","cellProperties","data","width","height","rowCount","dataTexture","length","createTexture2D","flipY","format","gl","LUMINANCE","type","FLOAT","u_isMeter","Number","isMeter","u_speed","u_additive","u_dataTexture","u_cellTypeLayout","getCellTypeLayout","u_opacity","u_offsets","isOffsetStatic","animateOption","enable","u_aimate","animateOption2Array","u_time","getLayerAnimateTime","styleAttributeService","createAttributesAndIndices","PointFillTriangulation","unit","version","mapService","Version","L7MAP","GLOBEL","calMeter2Coord","buildModels","getSource","extent","minLng","minLat","maxLng","maxLat","center","MAPBOX","window","mapboxgl","MercatorCoordinate","coord","fromLngLat","lng","lat","offsetInMeters","offsetInMercatorCoordinateUnits","meterInMercatorCoordinateUnits","westCoord","x","y","z","westLnglat","toLngLat","meter2coord","m1","meterToCoord","m2","Boolean","mask","maskInside","getShaders","frag","vert","buildLayerModel","moduleName","vertexShader","fragmentShader","triangulation","depth","getBlend","stencil","cull","face","pointFillFrag","pointFillVert","destroy","option","rings","registerStyleAttribute","name","AttributeType","Attribute","descriptor","buffer","usage","DYNAMIC_DRAW","size","update","feature","featureIdx","vertex","attributeIdx","extrude","extrudeIndex","Array","isArray","shape","shape2d","shapeIndex","indexOf","BaseModel"],"mappings":"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","sourcesContent":["import {\n AttributeType,\n gl,\n IAnimateOption,\n IAttribute,\n IElements,\n IEncodeFeature,\n ILayerConfig,\n IModel,\n IModelUniform,\n} from '@antv/l7-core';\nimport { getCullFace, getMask } from '@antv/l7-utils';\nimport { isNumber } from 'lodash';\nimport BaseModel from '../../core/BaseModel';\nimport { IPointLayerStyleOptions } from '../../core/interface';\nimport { PointFillTriangulation } from '../../core/triangulation';\n\nimport pointFillFrag from '../shaders/radar/radar_frag.glsl';\nimport pointFillVert from '../shaders/radar/radar_vert.glsl';\n\nimport { Version } from '@antv/l7-maps';\n\nexport default class RadarModel extends BaseModel {\n public meter2coord: number = 1;\n private isMeter: boolean = false;\n public getUninforms(): IModelUniform {\n const {\n opacity = 1,\n offsets = [0, 0],\n blend,\n speed = 1,\n } = this.layer.getLayerConfig() as IPointLayerStyleOptions;\n\n if (\n this.dataTextureTest &&\n this.dataTextureNeedUpdate({\n opacity,\n offsets,\n })\n ) {\n // 判断当前的样式中哪些是需要进行数据映射的,哪些是常量,同时计算用于构建数据纹理的一些中间变量\n this.judgeStyleAttributes({\n opacity,\n offsets,\n });\n\n const encodeData = this.layer.getEncodedData();\n const { data, width, height } = this.calDataFrame(\n this.cellLength,\n encodeData,\n this.cellProperties,\n );\n this.rowCount = height; // 当前数据纹理有多少行\n\n this.dataTexture =\n this.cellLength > 0 && data.length > 0\n ? this.createTexture2D({\n flipY: true,\n data,\n format: gl.LUMINANCE,\n type: gl.FLOAT,\n width,\n height,\n })\n : this.createTexture2D({\n flipY: true,\n data: [1],\n format: gl.LUMINANCE,\n type: gl.FLOAT,\n width: 1,\n height: 1,\n });\n }\n return {\n u_isMeter: Number(this.isMeter),\n u_speed: speed,\n u_additive: blend === 'additive' ? 1.0 : 0.0,\n u_dataTexture: this.dataTexture, // 数据纹理 - 有数据映射的时候纹理中带数据,若没有任何数据映射时纹理是 [1]\n u_cellTypeLayout: this.getCellTypeLayout(),\n\n u_opacity: isNumber(opacity) ? opacity : 1.0,\n u_offsets: this.isOffsetStatic(offsets)\n ? (offsets as [number, number])\n : [0, 0],\n };\n }\n public getAnimateUniforms(): IModelUniform {\n const {\n animateOption = { enable: false },\n } = this.layer.getLayerConfig() as ILayerConfig;\n return {\n u_aimate: this.animateOption2Array(animateOption),\n u_time: this.layer.getLayerAnimateTime(),\n };\n }\n\n public getAttribute(): {\n attributes: {\n [attributeName: string]: IAttribute;\n };\n elements: IElements;\n } {\n return this.styleAttributeService.createAttributesAndIndices(\n this.layer.getEncodedData(),\n PointFillTriangulation,\n );\n }\n\n public initModels(): IModel[] {\n const {\n unit = 'l7size',\n } = this.layer.getLayerConfig() as IPointLayerStyleOptions;\n const { version } = this.mapService;\n if (\n unit === 'meter' &&\n version !== Version.L7MAP &&\n version !== Version.GLOBEL\n ) {\n this.isMeter = true;\n this.calMeter2Coord();\n }\n\n return this.buildModels();\n }\n\n /**\n * 计算等面积点图层(unit meter)笛卡尔坐标标度与世界坐标标度的比例\n * @returns\n */\n public calMeter2Coord() {\n const [minLng, minLat, maxLng, maxLat] = this.layer.getSource().extent;\n const center = [(minLng + maxLng) / 2, (minLat + maxLat) / 2];\n\n const { version } = this.mapService;\n if (version === Version.MAPBOX && window.mapboxgl.MercatorCoordinate) {\n const coord = window.mapboxgl.MercatorCoordinate.fromLngLat(\n { lng: center[0], lat: center[1] },\n 0,\n );\n const offsetInMeters = 1;\n const offsetInMercatorCoordinateUnits =\n offsetInMeters * coord.meterInMercatorCoordinateUnits();\n const westCoord = new window.mapboxgl.MercatorCoordinate(\n coord.x - offsetInMercatorCoordinateUnits,\n coord.y,\n coord.z,\n );\n const westLnglat = westCoord.toLngLat();\n\n this.meter2coord = center[0] - westLnglat.lng;\n return;\n }\n\n // @ts-ignore\n const m1 = this.mapService.meterToCoord(center, [minLng, minLat]);\n // @ts-ignore\n const m2 = this.mapService.meterToCoord(center, [\n maxLng === minLng ? maxLng + 0.1 : maxLng,\n maxLat === minLat ? minLat + 0.1 : maxLat,\n ]);\n this.meter2coord = (m1 + m2) / 2;\n if (!Boolean(this.meter2coord)) {\n // Tip: 兼容单个数据导致的 m1、m2 为 NaN\n this.meter2coord = 7.70681090738883;\n }\n }\n\n public buildModels(): IModel[] {\n const {\n mask = false,\n maskInside = true,\n } = this.layer.getLayerConfig() as IPointLayerStyleOptions;\n const { frag, vert, type } = this.getShaders();\n\n return [\n this.layer.buildLayerModel({\n moduleName: type,\n vertexShader: vert,\n fragmentShader: frag,\n triangulation: PointFillTriangulation,\n depth: { enable: false },\n blend: this.getBlend(),\n stencil: getMask(mask, maskInside),\n cull: {\n enable: true,\n face: getCullFace(this.mapService.version),\n },\n }),\n ];\n }\n\n /**\n * 根据 animateOption 的值返回对应的 shader 代码\n * @returns\n */\n public getShaders(): { frag: string; vert: string; type: string } {\n return {\n frag: pointFillFrag,\n vert: pointFillVert,\n type: 'point_radar',\n };\n }\n\n public clearModels() {\n this.dataTexture?.destroy();\n }\n\n // overwrite baseModel func\n protected animateOption2Array(option: Partial<IAnimateOption>): number[] {\n return [option.enable ? 0 : 1.0, option.speed || 1, option.rings || 3, 0];\n }\n protected registerBuiltinAttributes() {\n this.styleAttributeService.registerStyleAttribute({\n name: 'extrude',\n type: AttributeType.Attribute,\n descriptor: {\n name: 'a_Extrude',\n buffer: {\n // give the WebGL driver a hint that this buffer may change\n usage: gl.DYNAMIC_DRAW,\n data: [],\n type: gl.FLOAT,\n },\n size: 3,\n update: (\n feature: IEncodeFeature,\n featureIdx: number,\n vertex: number[],\n attributeIdx: number,\n ) => {\n let extrude;\n extrude = [1, 1, 0, -1, 1, 0, -1, -1, 0, 1, -1, 0];\n\n const extrudeIndex = (attributeIdx % 4) * 3;\n return [\n extrude[extrudeIndex],\n extrude[extrudeIndex + 1],\n extrude[extrudeIndex + 2],\n ];\n },\n },\n });\n\n // point layer size;\n this.styleAttributeService.registerStyleAttribute({\n name: 'size',\n type: AttributeType.Attribute,\n descriptor: {\n name: 'a_Size',\n buffer: {\n // give the WebGL driver a hint that this buffer may change\n usage: gl.DYNAMIC_DRAW,\n data: [],\n type: gl.FLOAT,\n },\n size: 1,\n update: (\n feature: IEncodeFeature,\n featureIdx: number,\n vertex: number[],\n attributeIdx: number,\n ) => {\n const { size = 5 } = feature;\n return Array.isArray(size)\n ? [size[0] * this.meter2coord]\n : [(size as number) * this.meter2coord];\n },\n },\n });\n\n // point layer size;\n this.styleAttributeService.registerStyleAttribute({\n name: 'shape',\n type: AttributeType.Attribute,\n descriptor: {\n name: 'a_Shape',\n buffer: {\n // give the WebGL driver a hint that this buffer may change\n usage: gl.DYNAMIC_DRAW,\n data: [],\n type: gl.FLOAT,\n },\n size: 1,\n update: (\n feature: IEncodeFeature,\n featureIdx: number,\n vertex: number[],\n attributeIdx: number,\n ) => {\n const { shape = 2 } = feature;\n const shape2d = this.layer.getLayerConfig().shape2d as string[];\n const shapeIndex = shape2d.indexOf(shape as string);\n return [shapeIndex];\n },\n },\n });\n }\n}\n"],"file":"radar.js"}
|
|
1
|
+
{"version":3,"sources":["../../../src/point/models/radar.ts"],"names":["RadarModel","layer","getLayerConfig","opacity","offsets","blend","speed","dataTextureTest","dataTextureNeedUpdate","judgeStyleAttributes","encodeData","getEncodedData","calDataFrame","cellLength","cellProperties","data","width","height","rowCount","dataTexture","length","createTexture2D","flipY","format","gl","LUMINANCE","type","FLOAT","u_isMeter","Number","isMeter","u_speed","u_additive","u_dataTexture","u_cellTypeLayout","getCellTypeLayout","u_opacity","u_offsets","isOffsetStatic","animateOption","enable","u_aimate","animateOption2Array","u_time","getLayerAnimateTime","styleAttributeService","createAttributesAndIndices","PointFillTriangulation","unit","version","mapService","Version","L7MAP","GLOBEL","calMeter2Coord","buildModels","getSource","extent","minLng","minLat","maxLng","maxLat","center","MAPBOX","window","mapboxgl","MercatorCoordinate","coord","fromLngLat","lng","lat","offsetInMeters","offsetInMercatorCoordinateUnits","meterInMercatorCoordinateUnits","westCoord","x","y","z","westLnglat","toLngLat","meter2coord","m1","meterToCoord","m2","Boolean","mask","maskInside","getShaders","frag","vert","buildLayerModel","moduleName","vertexShader","fragmentShader","triangulation","depth","getBlend","stencil","pointFillFrag","pointFillVert","destroy","option","rings","registerStyleAttribute","name","AttributeType","Attribute","descriptor","buffer","usage","DYNAMIC_DRAW","size","update","feature","featureIdx","vertex","attributeIdx","extrude","extrudeIndex","Array","isArray","shape","shape2d","shapeIndex","indexOf","BaseModel"],"mappings":"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","sourcesContent":["import {\n AttributeType,\n gl,\n IAnimateOption,\n IAttribute,\n IElements,\n IEncodeFeature,\n ILayerConfig,\n IModel,\n IModelUniform,\n} from '@antv/l7-core';\nimport { getCullFace, getMask } from '@antv/l7-utils';\nimport { isNumber } from 'lodash';\nimport BaseModel from '../../core/BaseModel';\nimport { IPointLayerStyleOptions } from '../../core/interface';\nimport { PointFillTriangulation } from '../../core/triangulation';\n\nimport pointFillFrag from '../shaders/radar/radar_frag.glsl';\nimport pointFillVert from '../shaders/radar/radar_vert.glsl';\n\nimport { Version } from '@antv/l7-maps';\n\nexport default class RadarModel extends BaseModel {\n public meter2coord: number = 1;\n private isMeter: boolean = false;\n public getUninforms(): IModelUniform {\n const {\n opacity = 1,\n offsets = [0, 0],\n blend,\n speed = 1,\n } = this.layer.getLayerConfig() as IPointLayerStyleOptions;\n\n if (\n this.dataTextureTest &&\n this.dataTextureNeedUpdate({\n opacity,\n offsets,\n })\n ) {\n // 判断当前的样式中哪些是需要进行数据映射的,哪些是常量,同时计算用于构建数据纹理的一些中间变量\n this.judgeStyleAttributes({\n opacity,\n offsets,\n });\n\n const encodeData = this.layer.getEncodedData();\n const { data, width, height } = this.calDataFrame(\n this.cellLength,\n encodeData,\n this.cellProperties,\n );\n this.rowCount = height; // 当前数据纹理有多少行\n\n this.dataTexture =\n this.cellLength > 0 && data.length > 0\n ? this.createTexture2D({\n flipY: true,\n data,\n format: gl.LUMINANCE,\n type: gl.FLOAT,\n width,\n height,\n })\n : this.createTexture2D({\n flipY: true,\n data: [1],\n format: gl.LUMINANCE,\n type: gl.FLOAT,\n width: 1,\n height: 1,\n });\n }\n return {\n u_isMeter: Number(this.isMeter),\n u_speed: speed,\n u_additive: blend === 'additive' ? 1.0 : 0.0,\n u_dataTexture: this.dataTexture, // 数据纹理 - 有数据映射的时候纹理中带数据,若没有任何数据映射时纹理是 [1]\n u_cellTypeLayout: this.getCellTypeLayout(),\n\n u_opacity: isNumber(opacity) ? opacity : 1.0,\n u_offsets: this.isOffsetStatic(offsets)\n ? (offsets as [number, number])\n : [0, 0],\n };\n }\n public getAnimateUniforms(): IModelUniform {\n const {\n animateOption = { enable: false },\n } = this.layer.getLayerConfig() as ILayerConfig;\n return {\n u_aimate: this.animateOption2Array(animateOption),\n u_time: this.layer.getLayerAnimateTime(),\n };\n }\n\n public getAttribute(): {\n attributes: {\n [attributeName: string]: IAttribute;\n };\n elements: IElements;\n } {\n return this.styleAttributeService.createAttributesAndIndices(\n this.layer.getEncodedData(),\n PointFillTriangulation,\n );\n }\n\n public initModels(): IModel[] {\n const {\n unit = 'l7size',\n } = this.layer.getLayerConfig() as IPointLayerStyleOptions;\n const { version } = this.mapService;\n if (\n unit === 'meter' &&\n version !== Version.L7MAP &&\n version !== Version.GLOBEL\n ) {\n this.isMeter = true;\n this.calMeter2Coord();\n }\n\n return this.buildModels();\n }\n\n /**\n * 计算等面积点图层(unit meter)笛卡尔坐标标度与世界坐标标度的比例\n * @returns\n */\n public calMeter2Coord() {\n const [minLng, minLat, maxLng, maxLat] = this.layer.getSource().extent;\n const center = [(minLng + maxLng) / 2, (minLat + maxLat) / 2];\n\n const { version } = this.mapService;\n if (version === Version.MAPBOX && window.mapboxgl.MercatorCoordinate) {\n const coord = window.mapboxgl.MercatorCoordinate.fromLngLat(\n { lng: center[0], lat: center[1] },\n 0,\n );\n const offsetInMeters = 1;\n const offsetInMercatorCoordinateUnits =\n offsetInMeters * coord.meterInMercatorCoordinateUnits();\n const westCoord = new window.mapboxgl.MercatorCoordinate(\n coord.x - offsetInMercatorCoordinateUnits,\n coord.y,\n coord.z,\n );\n const westLnglat = westCoord.toLngLat();\n\n this.meter2coord = center[0] - westLnglat.lng;\n return;\n }\n\n // @ts-ignore\n const m1 = this.mapService.meterToCoord(center, [minLng, minLat]);\n // @ts-ignore\n const m2 = this.mapService.meterToCoord(center, [\n maxLng === minLng ? maxLng + 0.1 : maxLng,\n maxLat === minLat ? minLat + 0.1 : maxLat,\n ]);\n this.meter2coord = (m1 + m2) / 2;\n if (!Boolean(this.meter2coord)) {\n // Tip: 兼容单个数据导致的 m1、m2 为 NaN\n this.meter2coord = 7.70681090738883;\n }\n }\n\n public buildModels(): IModel[] {\n const {\n mask = false,\n maskInside = true,\n } = this.layer.getLayerConfig() as IPointLayerStyleOptions;\n const { frag, vert, type } = this.getShaders();\n\n return [\n this.layer.buildLayerModel({\n moduleName: type,\n vertexShader: vert,\n fragmentShader: frag,\n triangulation: PointFillTriangulation,\n depth: { enable: false },\n blend: this.getBlend(),\n stencil: getMask(mask, maskInside),\n }),\n ];\n }\n\n /**\n * 根据 animateOption 的值返回对应的 shader 代码\n * @returns\n */\n public getShaders(): { frag: string; vert: string; type: string } {\n return {\n frag: pointFillFrag,\n vert: pointFillVert,\n type: 'point_radar',\n };\n }\n\n public clearModels() {\n this.dataTexture?.destroy();\n }\n\n // overwrite baseModel func\n protected animateOption2Array(option: Partial<IAnimateOption>): number[] {\n return [option.enable ? 0 : 1.0, option.speed || 1, option.rings || 3, 0];\n }\n protected registerBuiltinAttributes() {\n this.styleAttributeService.registerStyleAttribute({\n name: 'extrude',\n type: AttributeType.Attribute,\n descriptor: {\n name: 'a_Extrude',\n buffer: {\n // give the WebGL driver a hint that this buffer may change\n usage: gl.DYNAMIC_DRAW,\n data: [],\n type: gl.FLOAT,\n },\n size: 3,\n update: (\n feature: IEncodeFeature,\n featureIdx: number,\n vertex: number[],\n attributeIdx: number,\n ) => {\n let extrude;\n extrude = [1, 1, 0, -1, 1, 0, -1, -1, 0, 1, -1, 0];\n\n const extrudeIndex = (attributeIdx % 4) * 3;\n return [\n extrude[extrudeIndex],\n extrude[extrudeIndex + 1],\n extrude[extrudeIndex + 2],\n ];\n },\n },\n });\n\n // point layer size;\n this.styleAttributeService.registerStyleAttribute({\n name: 'size',\n type: AttributeType.Attribute,\n descriptor: {\n name: 'a_Size',\n buffer: {\n // give the WebGL driver a hint that this buffer may change\n usage: gl.DYNAMIC_DRAW,\n data: [],\n type: gl.FLOAT,\n },\n size: 1,\n update: (\n feature: IEncodeFeature,\n featureIdx: number,\n vertex: number[],\n attributeIdx: number,\n ) => {\n const { size = 5 } = feature;\n return Array.isArray(size)\n ? [size[0] * this.meter2coord]\n : [(size as number) * this.meter2coord];\n },\n },\n });\n\n // point layer size;\n this.styleAttributeService.registerStyleAttribute({\n name: 'shape',\n type: AttributeType.Attribute,\n descriptor: {\n name: 'a_Shape',\n buffer: {\n // give the WebGL driver a hint that this buffer may change\n usage: gl.DYNAMIC_DRAW,\n data: [],\n type: gl.FLOAT,\n },\n size: 1,\n update: (\n feature: IEncodeFeature,\n featureIdx: number,\n vertex: number[],\n attributeIdx: number,\n ) => {\n const { shape = 2 } = feature;\n const shape2d = this.layer.getLayerConfig().shape2d as string[];\n const shapeIndex = shape2d.indexOf(shape as string);\n return [shapeIndex];\n },\n },\n });\n }\n}\n"],"file":"radar.js"}
|
|
@@ -88,7 +88,7 @@ var TilePickManager = function (_EventEmitter) {
|
|
|
88
88
|
var _this3 = this;
|
|
89
89
|
|
|
90
90
|
if (this.parent.type === 'RasterLayer') {
|
|
91
|
-
this.
|
|
91
|
+
this.renderMask(this.parent);
|
|
92
92
|
}
|
|
93
93
|
|
|
94
94
|
var isPicked = layers.filter(function (layer) {
|
|
@@ -115,7 +115,7 @@ var TilePickManager = function (_EventEmitter) {
|
|
|
115
115
|
|
|
116
116
|
var layerPicked = _this3.pickingService.pickFromPickingFBO(layer, target);
|
|
117
117
|
|
|
118
|
-
if (layerPicked) {
|
|
118
|
+
if (layerPicked && _this3.parent.type !== 'RasterLayer') {
|
|
119
119
|
_this3.emit('pick', {
|
|
120
120
|
type: target.type,
|
|
121
121
|
pickedColors: _this3.pickingService.pickedColors,
|
|
@@ -128,7 +128,7 @@ var TilePickManager = function (_EventEmitter) {
|
|
|
128
128
|
return layerPicked;
|
|
129
129
|
});
|
|
130
130
|
|
|
131
|
-
if (!isPicked && this.isLastPicked && target.type !== 'click') {
|
|
131
|
+
if (this.parent.type !== 'RasterLayer' && !isPicked && this.isLastPicked && target.type !== 'click') {
|
|
132
132
|
this.pickingService.pickedTileLayers = [];
|
|
133
133
|
this.emit('unpick', {});
|
|
134
134
|
this.beforeHighlight([0, 0, 0]);
|
|
@@ -165,6 +165,28 @@ var TilePickManager = function (_EventEmitter) {
|
|
|
165
165
|
layer.hooks.beforeSelect.call(pickedColors);
|
|
166
166
|
});
|
|
167
167
|
}
|
|
168
|
+
}, {
|
|
169
|
+
key: "renderMask",
|
|
170
|
+
value: function renderMask(layer) {
|
|
171
|
+
if (layer.inited && layer.isVisible()) {
|
|
172
|
+
layer.hooks.beforeRender.call();
|
|
173
|
+
|
|
174
|
+
if (layer.masks.length > 0) {
|
|
175
|
+
this.rendererService.clear({
|
|
176
|
+
stencil: 0,
|
|
177
|
+
depth: 1,
|
|
178
|
+
framebuffer: null
|
|
179
|
+
});
|
|
180
|
+
layer.masks.map(function (m) {
|
|
181
|
+
m.hooks.beforeRender.call();
|
|
182
|
+
m.render();
|
|
183
|
+
m.hooks.afterRender.call();
|
|
184
|
+
});
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
layer.hooks.afterRender.call();
|
|
188
|
+
}
|
|
189
|
+
}
|
|
168
190
|
}]);
|
|
169
191
|
return TilePickManager;
|
|
170
192
|
}(_eventemitter.EventEmitter);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/tile/manager/tilePickerManager.ts"],"names":["TilePickManager","parent","rendererService","pickingService","children","layerService","layers","filter","layer","inited","isVisible","map","hooks","beforeRenderData","call","beforeRender","masks","length","clear","stencil","depth","framebuffer","m","render","afterRender","target","type","
|
|
1
|
+
{"version":3,"sources":["../../../src/tile/manager/tilePickerManager.ts"],"names":["TilePickManager","parent","rendererService","pickingService","children","layerService","layers","filter","layer","inited","isVisible","map","hooks","beforeRenderData","call","beforeRender","masks","length","clear","stencil","depth","framebuffer","m","render","afterRender","target","type","renderMask","isPicked","needPick","some","beforePickingEncode","renderModels","afterPickingEncode","layerPicked","pickFromPickingFBO","emit","pickedColors","pickedTileLayers","isLastPicked","beforeHighlight","child","beforeSelect","EventEmitter"],"mappings":"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","sourcesContent":["import {\n IInteractionTarget,\n ILayer,\n ILayerService,\n IPickingService,\n IRendererService,\n ITilePickManager,\n} from '@antv/l7-core';\nimport { EventEmitter } from 'eventemitter3';\nexport default class TilePickManager extends EventEmitter\n implements ITilePickManager {\n public isLastPicked: boolean = false;\n private rendererService: IRendererService;\n private pickingService: IPickingService;\n private layerService: ILayerService;\n private children: ILayer[];\n private parent: ILayer;\n\n constructor(\n parent: ILayer,\n rendererService: IRendererService,\n pickingService: IPickingService,\n children: ILayer[],\n layerService: ILayerService,\n ) {\n super();\n this.parent = parent;\n this.rendererService = rendererService;\n this.pickingService = pickingService;\n this.layerService = layerService;\n this.children = children;\n }\n\n /**\n *\n * @param layers\n */\n public normalRender(layers: ILayer[]) {\n layers\n .filter((layer) => layer.inited)\n .filter((layer) => layer.isVisible())\n .map((layer) => {\n layer.hooks.beforeRenderData.call();\n layer.hooks.beforeRender.call();\n if (layer.masks.length > 0) {\n // 清除上一次的模版缓存\n this.rendererService.clear({\n stencil: 0,\n depth: 1,\n framebuffer: null,\n });\n layer.masks.map((m: ILayer) => {\n m.hooks.beforeRender.call();\n m.render();\n m.hooks.afterRender.call();\n });\n }\n layer.render();\n layer.hooks.afterRender.call();\n });\n }\n\n public pickRender(layers: ILayer[], target: IInteractionTarget) {\n // Tip: 在进行拾取渲染的时候也需要先渲染一遍父组件然后再渲染子组件\n // 如需要在 栅格瓦片存在 Mask 的时候发生的拾取,那么就需要先渲染父组件(渲染父组件的帧缓冲)\n if (this.parent.type === 'RasterLayer') {\n this.renderMask(this.parent);\n }\n const isPicked = layers\n .filter(\n (layer) =>\n this.parent.needPick(target.type) &&\n layer.inited &&\n layer.isVisible(),\n )\n .some((layer) => {\n layer.hooks.beforePickingEncode.call();\n if (layer.masks.length > 0) {\n // 清除上一次的模版缓存\n this.rendererService.clear({\n stencil: 0,\n depth: 1,\n framebuffer: null,\n });\n\n layer.masks.map((m: ILayer) => {\n m.hooks.beforeRender.call();\n m.render();\n m.hooks.afterRender.call();\n });\n }\n layer.renderModels(true);\n layer.hooks.afterPickingEncode.call();\n const layerPicked = this.pickingService.pickFromPickingFBO(\n layer,\n target,\n );\n // RasterLayer 不参与拾取后的 shader 计算\n if (layerPicked && this.parent.type !== 'RasterLayer') {\n this.emit('pick', {\n type: target.type,\n pickedColors: this.pickingService.pickedColors,\n layer,\n });\n this.pickingService.pickedTileLayers = [this.parent];\n }\n\n return layerPicked;\n });\n if (\n this.parent.type !== 'RasterLayer' &&\n !isPicked &&\n this.isLastPicked &&\n target.type !== 'click'\n ) {\n // 只有上一次有被高亮选中,本次未选中的时候才需要清除选中状态\n this.pickingService.pickedTileLayers = [];\n this.emit('unpick', {});\n this.beforeHighlight([0, 0, 0]);\n }\n this.isLastPicked = isPicked;\n return isPicked;\n }\n\n public clearPick() {\n this.children\n .filter((child) => child.inited && child.isVisible())\n .map((layer) => {\n layer.hooks.beforeSelect.call([0, 0, 0]);\n });\n this.pickingService.pickedTileLayers = [];\n }\n\n public beforeHighlight(pickedColors: any) {\n this.children\n .filter((child) => child.inited && child.isVisible())\n .map((child) => {\n child.hooks.beforeHighlight.call(pickedColors);\n });\n }\n\n public beforeSelect(pickedColors: any) {\n this.children\n .filter((child) => child.inited && child.isVisible())\n .map((layer) => {\n layer.hooks.beforeSelect.call(pickedColors);\n });\n }\n\n protected renderMask(layer: ILayer) {\n if (layer.inited && layer.isVisible()) {\n layer.hooks.beforeRender.call();\n if (layer.masks.length > 0) {\n this.rendererService.clear({\n stencil: 0,\n depth: 1,\n framebuffer: null,\n });\n layer.masks.map((m: ILayer) => {\n m.hooks.beforeRender.call();\n m.render();\n m.hooks.afterRender.call();\n });\n }\n layer.hooks.afterRender.call();\n }\n }\n}\n"],"file":"tilePickerManager.js"}
|
|
@@ -19,6 +19,8 @@ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/de
|
|
|
19
19
|
|
|
20
20
|
var _l7Source = _interopRequireDefault(require("@antv/l7-source"));
|
|
21
21
|
|
|
22
|
+
var _l7Utils = require("@antv/l7-utils");
|
|
23
|
+
|
|
22
24
|
var _mask = _interopRequireDefault(require("../../mask"));
|
|
23
25
|
|
|
24
26
|
var _utils = require("../utils");
|
|
@@ -45,6 +47,8 @@ var TileFactory = function () {
|
|
|
45
47
|
(0, _defineProperty2.default)(this, "mapService", void 0);
|
|
46
48
|
(0, _defineProperty2.default)(this, "rendererService", void 0);
|
|
47
49
|
(0, _defineProperty2.default)(this, "outSideEventTimer", null);
|
|
50
|
+
(0, _defineProperty2.default)(this, "zoomOffset", void 0);
|
|
51
|
+
(0, _defineProperty2.default)(this, "tilesetManager", void 0);
|
|
48
52
|
(0, _defineProperty2.default)(this, "layers", void 0);
|
|
49
53
|
(0, _defineProperty2.default)(this, "eventCache", {
|
|
50
54
|
click: 0,
|
|
@@ -56,6 +60,9 @@ var TileFactory = function () {
|
|
|
56
60
|
this.parentLayer = option.parent;
|
|
57
61
|
this.mapService = option.mapService;
|
|
58
62
|
this.rendererService = option.rendererService;
|
|
63
|
+
var source = this.parentLayer.getSource();
|
|
64
|
+
this.zoomOffset = source.parser.zoomOffset || 0;
|
|
65
|
+
this.tilesetManager = source.tileset;
|
|
59
66
|
}
|
|
60
67
|
|
|
61
68
|
(0, _createClass2.default)(TileFactory, [{
|
|
@@ -228,9 +235,21 @@ var TileFactory = function () {
|
|
|
228
235
|
|
|
229
236
|
return [];
|
|
230
237
|
}
|
|
238
|
+
}, {
|
|
239
|
+
key: "getTile",
|
|
240
|
+
value: function getTile(lng, lat) {
|
|
241
|
+
var zoom = this.mapService.getZoom();
|
|
242
|
+
var z = Math.ceil(zoom) + this.zoomOffset;
|
|
243
|
+
var xy = (0, _l7Utils.osmLonLat2TileXY)(lng, lat, z);
|
|
244
|
+
var tiles = this.tilesetManager.tiles.filter(function (t) {
|
|
245
|
+
return t.key === "".concat(xy[0], ",").concat(xy[1], ",").concat(z);
|
|
246
|
+
});
|
|
247
|
+
var tile = tiles[0];
|
|
248
|
+
return tile;
|
|
249
|
+
}
|
|
231
250
|
}, {
|
|
232
251
|
key: "emitEvent",
|
|
233
|
-
value: function emitEvent(layers, isVector
|
|
252
|
+
value: function emitEvent(layers, isVector) {
|
|
234
253
|
var _this = this;
|
|
235
254
|
|
|
236
255
|
layers.map(function (layer) {
|
|
@@ -238,12 +257,32 @@ var TileFactory = function () {
|
|
|
238
257
|
layer.on('click', function (e) {
|
|
239
258
|
_this.eventCache.click = 1;
|
|
240
259
|
|
|
241
|
-
_this.
|
|
260
|
+
if (_this.parentLayer.type === 'RasterLayer') {
|
|
261
|
+
var _e$lngLat = e.lngLat,
|
|
262
|
+
lng = _e$lngLat.lng,
|
|
263
|
+
lat = _e$lngLat.lat;
|
|
264
|
+
|
|
265
|
+
var tile = _this.getTile(lng, lat);
|
|
266
|
+
|
|
267
|
+
_this.getFeatureAndEmitEvent(layer, 'subLayerClick', e, isVector, tile);
|
|
268
|
+
} else {
|
|
269
|
+
_this.getFeatureAndEmitEvent(layer, 'subLayerClick', e);
|
|
270
|
+
}
|
|
242
271
|
});
|
|
243
272
|
layer.on('mousemove', function (e) {
|
|
244
273
|
_this.eventCache.mousemove = 1;
|
|
245
274
|
|
|
246
|
-
_this.
|
|
275
|
+
if (_this.parentLayer.type === 'RasterLayer') {
|
|
276
|
+
var _e$lngLat2 = e.lngLat,
|
|
277
|
+
lng = _e$lngLat2.lng,
|
|
278
|
+
lat = _e$lngLat2.lat;
|
|
279
|
+
|
|
280
|
+
var tile = _this.getTile(lng, lat);
|
|
281
|
+
|
|
282
|
+
_this.getFeatureAndEmitEvent(layer, 'subLayerMouseMove', e, isVector, tile);
|
|
283
|
+
} else {
|
|
284
|
+
_this.getFeatureAndEmitEvent(layer, 'subLayerMouseMove', e);
|
|
285
|
+
}
|
|
247
286
|
});
|
|
248
287
|
layer.on('mouseup', function (e) {
|
|
249
288
|
_this.eventCache.mouseup = 1;
|
|
@@ -251,7 +290,17 @@ var TileFactory = function () {
|
|
|
251
290
|
_this.getFeatureAndEmitEvent(layer, 'subLayerMouseUp', e);
|
|
252
291
|
});
|
|
253
292
|
layer.on('mouseenter', function (e) {
|
|
254
|
-
_this.
|
|
293
|
+
if (_this.parentLayer.type === 'RasterLayer') {
|
|
294
|
+
var _e$lngLat3 = e.lngLat,
|
|
295
|
+
lng = _e$lngLat3.lng,
|
|
296
|
+
lat = _e$lngLat3.lat;
|
|
297
|
+
|
|
298
|
+
var tile = _this.getTile(lng, lat);
|
|
299
|
+
|
|
300
|
+
_this.getFeatureAndEmitEvent(layer, 'subLayerMouseMove', e, isVector, tile);
|
|
301
|
+
} else {
|
|
302
|
+
_this.getFeatureAndEmitEvent(layer, 'subLayerMouseEnter', e);
|
|
303
|
+
}
|
|
255
304
|
});
|
|
256
305
|
layer.on('mouseout', function (e) {
|
|
257
306
|
_this.getFeatureAndEmitEvent(layer, 'subLayerMouseOut', e);
|
|
@@ -285,6 +334,7 @@ var TileFactory = function () {
|
|
|
285
334
|
key: "getCombineFeature",
|
|
286
335
|
value: function getCombineFeature(features) {
|
|
287
336
|
var p = null;
|
|
337
|
+
var properties = features[0];
|
|
288
338
|
features.map(function (feature) {
|
|
289
339
|
var polygon = turf.polygon(feature.coordinates);
|
|
290
340
|
|
|
@@ -296,18 +346,28 @@ var TileFactory = function () {
|
|
|
296
346
|
p = (0, _union.default)(p, polygon);
|
|
297
347
|
}
|
|
298
348
|
});
|
|
349
|
+
|
|
350
|
+
if (properties) {
|
|
351
|
+
p.properties = _objectSpread({}, properties);
|
|
352
|
+
}
|
|
353
|
+
|
|
299
354
|
return p;
|
|
300
355
|
}
|
|
301
356
|
}, {
|
|
302
357
|
key: "getFeatureAndEmitEvent",
|
|
303
358
|
value: function getFeatureAndEmitEvent(layer, eventName, e, isVector, tile) {
|
|
304
|
-
var featureId = e.featureId;
|
|
305
|
-
var features = this.getAllFeatures(featureId);
|
|
306
|
-
e.feature = this.getCombineFeature(features);
|
|
307
|
-
|
|
308
359
|
if (isVector === false) {
|
|
309
|
-
e.pickedColors = (0, _utils.readPixel)(e.x, e.y, this.rendererService);
|
|
310
360
|
e.value = (0, _utils.readRasterValue)(tile, this.mapService, e.x, e.y);
|
|
361
|
+
} else {
|
|
362
|
+
var featureId = e.featureId;
|
|
363
|
+
var features = this.getAllFeatures(featureId);
|
|
364
|
+
|
|
365
|
+
try {
|
|
366
|
+
e.feature = this.getCombineFeature(features);
|
|
367
|
+
} catch (err) {
|
|
368
|
+
console.warn('Combine Featuer Err! Return First Feature!');
|
|
369
|
+
e.feature = features[0];
|
|
370
|
+
}
|
|
311
371
|
}
|
|
312
372
|
|
|
313
373
|
this.parentLayer.emit(eventName, e);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/tile/tileFactory/base.ts"],"names":["TileFactory","option","click","mousemove","mouseup","mousedown","contextmenu","parentLayer","parent","mapService","rendererService","tile","initOptions","layers","layerIDList","emptyData","features","featureId","vectorTileLayer","source","sourceLayer","data","Array","isArray","length","Source","type","parser","tileLayerOption","L7Layer","mask","color","layerType","size","shape","FactoryTileLayer","VectorLayer","layer","visible","isVisible","tileOrigin","l7TileOrigin","coord","l7TileCoord","getLayerInitOption","isVector","emitEvent","select","setStyleAttributeField","masklayer","MaskLayer","bboxPolygon","push","addMaskLayer","styles","value","defaultValue","getDefautStyleAttributeField","params","parseScaleValue","field","values","callback","map","once","on","e","eventCache","getFeatureAndEmitEvent","handleOutsideEvent","p","feature","polygon","turf","coordinates","eventName","getAllFeatures","getCombineFeature","pickedColors","x","y","emit","allLayers","tileLayer","children","getSource","dataArray","_id","coords","emitType","outSideEventTimer","clearTimeout","setTimeout"],"mappings":"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","sourcesContent":["import {\n ILayer,\n IMapService,\n IParseDataItem,\n IRendererService,\n IScaleValue,\n ISubLayerInitOptions,\n ScaleAttributeType,\n} from '@antv/l7-core';\nimport Source from '@antv/l7-source';\nimport { Tile } from '@antv/l7-utils';\nimport MaskLayer from '../../mask';\nimport {\n getLayerShape,\n readPixel,\n readRasterValue,\n registerLayers,\n} from '../utils';\nimport VectorLayer from './vectorLayer';\n\nimport * as turf from '@turf/helpers';\nimport union from '@turf/union';\nimport {\n CacheEvent,\n ILayerTileConfig,\n ITileFactory,\n ITileFactoryOptions,\n ITileStyles,\n Timeout,\n} from '../interface';\n\nexport default class TileFactory implements ITileFactory {\n public type: string;\n public parentLayer: ILayer;\n public mapService: IMapService;\n public rendererService: IRendererService;\n public outSideEventTimer: Timeout | null = null;\n protected layers: ILayer[];\n // 用于记录图层内事件,辅助判断图层外事件逻辑\n private eventCache = {\n click: 0,\n mousemove: 0,\n mouseup: 0,\n mousedown: 0,\n contextmenu: 0,\n };\n constructor(option: ITileFactoryOptions) {\n this.parentLayer = option.parent;\n this.mapService = option.mapService;\n this.rendererService = option.rendererService;\n }\n\n public createTile(tile: Tile, initOptions: ISubLayerInitOptions) {\n return {\n layers: [] as ILayer[],\n layerIDList: [] as string[],\n };\n }\n\n public getFeatureData(tile: Tile, initOptions: ISubLayerInitOptions) {\n const emptyData = {\n features: [],\n featureId: null,\n vectorTileLayer: null,\n source: null,\n };\n const { sourceLayer, featureId } = initOptions;\n if (!sourceLayer) {\n return emptyData;\n }\n const vectorTileLayer = tile.data.layers[sourceLayer];\n const features = vectorTileLayer?.features;\n if (!(Array.isArray(features) && features.length > 0)) {\n return emptyData;\n } else {\n const source = new Source(\n {\n type: 'FeatureCollection',\n features,\n },\n {\n parser: {\n type: 'geojson',\n featureId,\n },\n },\n );\n\n return {\n features,\n featureId,\n vectorTileLayer,\n source,\n };\n }\n }\n\n public createLayer(tileLayerOption: ILayerTileConfig) {\n const {\n L7Layer,\n tile,\n initOptions,\n vectorTileLayer,\n source,\n } = tileLayerOption;\n const { mask, color, layerType, size, shape } = initOptions;\n const FactoryTileLayer = L7Layer ? L7Layer : VectorLayer;\n const layer = new FactoryTileLayer({\n visible: tile.isVisible,\n tileOrigin: vectorTileLayer?.l7TileOrigin,\n coord: vectorTileLayer?.l7TileCoord,\n ...this.getLayerInitOption(initOptions),\n });\n // vector layer set config\n if (layer.isVector) {\n this.emitEvent([layer]);\n layer.type = layerType;\n layer.select(true);\n }\n\n // set source\n layer.source(source);\n\n // set scale attribute field\n this.setStyleAttributeField(layer, 'shape', shape);\n this.setStyleAttributeField(layer, 'color', color);\n this.setStyleAttributeField(layer, 'size', size);\n\n // set mask\n const layers = [layer];\n if (mask && layer.isVector) {\n const masklayer = new MaskLayer()\n .source({\n type: 'FeatureCollection',\n features: [tile.bboxPolygon],\n })\n .shape('fill');\n\n layers.push(masklayer as VectorLayer);\n\n layer.addMaskLayer(masklayer);\n }\n // regist layer\n registerLayers(this.parentLayer, layers);\n\n this.layers = [layer];\n\n return layer;\n }\n\n public updateStyle(styles: ITileStyles) {\n return '';\n }\n\n public getDefautStyleAttributeField(layer: ILayer, type: string) {\n switch (type) {\n case 'size':\n return 2;\n case 'color':\n return '#fff';\n case 'shape':\n return getLayerShape(this.parentLayer.type, layer);\n default:\n return '';\n }\n }\n\n public setStyleAttributeField(\n layer: ILayer,\n type: ScaleAttributeType,\n value: IScaleValue | undefined | string | string[],\n ) {\n if (Array.isArray(value)) {\n // @ts-ignore\n layer[type](...value);\n return;\n }\n if (typeof value === 'string') {\n layer[type](value);\n return;\n }\n const defaultValue = this.getDefautStyleAttributeField(layer, type);\n if (!value) {\n layer[type](defaultValue);\n return layer;\n }\n const params = this.parseScaleValue(value, type);\n if (params.length === 0) {\n layer[type](defaultValue);\n } else {\n // @ts-ignore\n layer[type](...params);\n }\n }\n\n protected parseScaleValue(value: IScaleValue | string, type: string) {\n if (type === 'shape') {\n if (typeof value === 'string') {\n return [value];\n } else if (value?.field) {\n return [value?.field];\n } else {\n return [];\n }\n }\n const { field, values, callback } = value as IScaleValue;\n if (field && values && Array.isArray(values)) {\n return [field, values];\n } else if (field && callback) {\n return [field, callback];\n } else if (field) {\n return [field];\n }\n return [];\n }\n\n protected emitEvent(layers: ILayer[], isVector?: boolean, tile?: any) {\n layers.map((layer) => {\n layer.once('inited', () => {\n layer.on('click', (e) => {\n this.eventCache.click = 1;\n this.getFeatureAndEmitEvent(\n layer,\n 'subLayerClick',\n e,\n isVector,\n tile,\n );\n });\n layer.on('mousemove', (e) => {\n this.eventCache.mousemove = 1;\n this.getFeatureAndEmitEvent(\n layer,\n 'subLayerMouseMove',\n e,\n isVector,\n tile,\n );\n });\n layer.on('mouseup', (e) => {\n this.eventCache.mouseup = 1;\n this.getFeatureAndEmitEvent(layer, 'subLayerMouseUp', e);\n });\n layer.on('mouseenter', (e) => {\n this.getFeatureAndEmitEvent(layer, 'subLayerMouseEnter', e);\n });\n layer.on('mouseout', (e) => {\n this.getFeatureAndEmitEvent(layer, 'subLayerMouseOut', e);\n });\n layer.on('mousedown', (e) => {\n this.eventCache.mousedown = 1;\n this.getFeatureAndEmitEvent(layer, 'subLayerMouseDown', e);\n });\n layer.on('contextmenu', (e) => {\n this.eventCache.contextmenu = 1;\n this.getFeatureAndEmitEvent(layer, 'subLayerContextmenu', e);\n });\n\n // out side\n layer.on('unclick', (e) =>\n this.handleOutsideEvent('click', 'subLayerUnClick', layer, e),\n );\n layer.on('unmouseup', (e) =>\n this.handleOutsideEvent('mouseup', 'subLayerUnMouseUp', layer, e),\n );\n layer.on('unmousedown', (e) =>\n this.handleOutsideEvent('mousedown', 'subLayerUnMouseDown', layer, e),\n );\n layer.on('uncontextmenu', (e) =>\n this.handleOutsideEvent(\n 'contextmenu',\n 'subLayerUnContextmenu',\n layer,\n e,\n ),\n );\n });\n });\n }\n\n protected getCombineFeature(features: IParseDataItem[]) {\n let p: any = null;\n features.map((feature) => {\n const polygon = turf.polygon(feature.coordinates);\n if (p === null) {\n p = polygon;\n }\n {\n p = union(p, polygon);\n }\n });\n return p;\n }\n\n protected getFeatureAndEmitEvent(\n layer: ILayer,\n eventName: string,\n e: any,\n isVector?: boolean,\n tile?: any,\n ) {\n const featureId = e.featureId;\n const features = this.getAllFeatures(featureId);\n e.feature = this.getCombineFeature(features);\n\n if (isVector === false) {\n // raster tile get rgb\n e.pickedColors = readPixel(e.x, e.y, this.rendererService);\n // raster tile origin value\n e.value = readRasterValue(tile, this.mapService, e.x, e.y);\n }\n this.parentLayer.emit(eventName, e);\n }\n\n private getAllFeatures(featureId: number) {\n const allLayers: ILayer[] = this.parentLayer.tileLayer.children;\n const features: IParseDataItem[] = [];\n allLayers.map((layer) => {\n const source = layer.getSource();\n source.data.dataArray.map((feature) => {\n if (feature._id === featureId) {\n features.push(feature);\n }\n });\n });\n return features;\n }\n\n private getLayerInitOption(initOptions: ISubLayerInitOptions) {\n const option = { ...initOptions };\n delete option.color;\n delete option.shape;\n delete option.size;\n delete option.coords;\n delete option.sourceLayer;\n delete option.coords;\n return option;\n }\n\n private handleOutsideEvent(\n type: CacheEvent,\n emitType: string,\n layer: ILayer,\n e: any,\n ) {\n if (this.outSideEventTimer) {\n clearTimeout(this.outSideEventTimer);\n this.outSideEventTimer = null;\n }\n this.outSideEventTimer = setTimeout(() => {\n if (this.eventCache[type] > 0) {\n this.eventCache[type] = 0;\n } else {\n this.getFeatureAndEmitEvent(layer, emitType, e);\n }\n }, 64);\n }\n}\n"],"file":"base.js"}
|
|
1
|
+
{"version":3,"sources":["../../../src/tile/tileFactory/base.ts"],"names":["TileFactory","option","click","mousemove","mouseup","mousedown","contextmenu","parentLayer","parent","mapService","rendererService","source","getSource","zoomOffset","parser","tilesetManager","tileset","tile","initOptions","layers","layerIDList","emptyData","features","featureId","vectorTileLayer","sourceLayer","data","Array","isArray","length","Source","type","tileLayerOption","L7Layer","mask","color","layerType","size","shape","FactoryTileLayer","VectorLayer","layer","visible","isVisible","tileOrigin","l7TileOrigin","coord","l7TileCoord","getLayerInitOption","isVector","emitEvent","select","setStyleAttributeField","masklayer","MaskLayer","bboxPolygon","push","addMaskLayer","styles","value","defaultValue","getDefautStyleAttributeField","params","parseScaleValue","field","values","callback","lng","lat","zoom","getZoom","z","Math","ceil","xy","tiles","filter","t","key","map","once","on","e","eventCache","lngLat","getTile","getFeatureAndEmitEvent","handleOutsideEvent","p","properties","feature","polygon","turf","coordinates","eventName","x","y","getAllFeatures","getCombineFeature","err","console","warn","emit","allLayers","tileLayer","children","dataArray","_id","coords","emitType","outSideEventTimer","clearTimeout","setTimeout"],"mappings":"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","sourcesContent":["import {\n ILayer,\n IMapService,\n IParseDataItem,\n IRendererService,\n IScaleValue,\n ISubLayerInitOptions,\n ScaleAttributeType,\n} from '@antv/l7-core';\nimport Source from '@antv/l7-source';\nimport { osmLonLat2TileXY, Tile, TilesetManager } from '@antv/l7-utils';\nimport MaskLayer from '../../mask';\nimport {\n getLayerShape,\n readPixel,\n readRasterValue,\n registerLayers,\n} from '../utils';\nimport VectorLayer from './vectorLayer';\n\nimport * as turf from '@turf/helpers';\nimport union from '@turf/union';\nimport {\n CacheEvent,\n ILayerTileConfig,\n ITileFactory,\n ITileFactoryOptions,\n ITileStyles,\n Timeout,\n} from '../interface';\n\nexport default class TileFactory implements ITileFactory {\n public type: string;\n public parentLayer: ILayer;\n public mapService: IMapService;\n public rendererService: IRendererService;\n public outSideEventTimer: Timeout | null = null;\n protected zoomOffset: number;\n protected tilesetManager: TilesetManager;\n protected layers: ILayer[];\n // 用于记录图层内事件,辅助判断图层外事件逻辑\n private eventCache = {\n click: 0,\n mousemove: 0,\n mouseup: 0,\n mousedown: 0,\n contextmenu: 0,\n };\n constructor(option: ITileFactoryOptions) {\n this.parentLayer = option.parent;\n this.mapService = option.mapService;\n this.rendererService = option.rendererService;\n\n const source = this.parentLayer.getSource();\n this.zoomOffset = source.parser.zoomOffset || 0;\n this.tilesetManager = source.tileset as TilesetManager;\n }\n\n public createTile(tile: Tile, initOptions: ISubLayerInitOptions) {\n return {\n layers: [] as ILayer[],\n layerIDList: [] as string[],\n };\n }\n\n public getFeatureData(tile: Tile, initOptions: ISubLayerInitOptions) {\n const emptyData = {\n features: [],\n featureId: null,\n vectorTileLayer: null,\n source: null,\n };\n const { sourceLayer, featureId } = initOptions;\n if (!sourceLayer) {\n return emptyData;\n }\n const vectorTileLayer = tile.data.layers[sourceLayer];\n const features = vectorTileLayer?.features;\n if (!(Array.isArray(features) && features.length > 0)) {\n return emptyData;\n } else {\n const source = new Source(\n {\n type: 'FeatureCollection',\n features,\n },\n {\n parser: {\n type: 'geojson',\n featureId,\n },\n },\n );\n\n return {\n features,\n featureId,\n vectorTileLayer,\n source,\n };\n }\n }\n\n public createLayer(tileLayerOption: ILayerTileConfig) {\n const {\n L7Layer,\n tile,\n initOptions,\n vectorTileLayer,\n source,\n } = tileLayerOption;\n const { mask, color, layerType, size, shape } = initOptions;\n const FactoryTileLayer = L7Layer ? L7Layer : VectorLayer;\n const layer = new FactoryTileLayer({\n visible: tile.isVisible,\n tileOrigin: vectorTileLayer?.l7TileOrigin,\n coord: vectorTileLayer?.l7TileCoord,\n ...this.getLayerInitOption(initOptions),\n });\n // vector layer set config\n if (layer.isVector) {\n this.emitEvent([layer]);\n layer.type = layerType;\n layer.select(true);\n }\n\n // set source\n layer.source(source);\n\n // set scale attribute field\n this.setStyleAttributeField(layer, 'shape', shape);\n this.setStyleAttributeField(layer, 'color', color);\n this.setStyleAttributeField(layer, 'size', size);\n\n // set mask\n const layers = [layer];\n if (mask && layer.isVector) {\n const masklayer = new MaskLayer()\n .source({\n type: 'FeatureCollection',\n features: [tile.bboxPolygon],\n })\n .shape('fill');\n\n layers.push(masklayer as VectorLayer);\n\n layer.addMaskLayer(masklayer);\n }\n // regist layer\n registerLayers(this.parentLayer, layers);\n\n this.layers = [layer];\n\n return layer;\n }\n\n public updateStyle(styles: ITileStyles) {\n return '';\n }\n\n public getDefautStyleAttributeField(layer: ILayer, type: string) {\n switch (type) {\n case 'size':\n return 2;\n case 'color':\n return '#fff';\n case 'shape':\n return getLayerShape(this.parentLayer.type, layer);\n default:\n return '';\n }\n }\n\n public setStyleAttributeField(\n layer: ILayer,\n type: ScaleAttributeType,\n value: IScaleValue | undefined | string | string[],\n ) {\n if (Array.isArray(value)) {\n // @ts-ignore\n layer[type](...value);\n return;\n }\n if (typeof value === 'string') {\n layer[type](value);\n return;\n }\n const defaultValue = this.getDefautStyleAttributeField(layer, type);\n if (!value) {\n layer[type](defaultValue);\n return layer;\n }\n const params = this.parseScaleValue(value, type);\n if (params.length === 0) {\n layer[type](defaultValue);\n } else {\n // @ts-ignore\n layer[type](...params);\n }\n }\n\n protected parseScaleValue(value: IScaleValue | string, type: string) {\n if (type === 'shape') {\n if (typeof value === 'string') {\n return [value];\n } else if (value?.field) {\n return [value?.field];\n } else {\n return [];\n }\n }\n const { field, values, callback } = value as IScaleValue;\n if (field && values && Array.isArray(values)) {\n return [field, values];\n } else if (field && callback) {\n return [field, callback];\n } else if (field) {\n return [field];\n }\n return [];\n }\n\n protected getTile(lng: number, lat: number) {\n const zoom = this.mapService.getZoom();\n const z = Math.ceil(zoom) + this.zoomOffset;\n const xy = osmLonLat2TileXY(lng, lat, z);\n\n const tiles = this.tilesetManager.tiles.filter(\n (t) => t.key === `${xy[0]},${xy[1]},${z}`,\n );\n const tile = tiles[0];\n return tile;\n }\n\n protected emitEvent(layers: ILayer[], isVector?: boolean) {\n layers.map((layer) => {\n layer.once('inited', () => {\n layer.on('click', (e) => {\n this.eventCache.click = 1;\n if (this.parentLayer.type === 'RasterLayer') {\n const { lng, lat } = e.lngLat;\n const tile = this.getTile(lng, lat);\n this.getFeatureAndEmitEvent(\n layer,\n 'subLayerClick',\n e,\n isVector,\n tile,\n );\n } else {\n this.getFeatureAndEmitEvent(layer, 'subLayerClick', e);\n }\n });\n\n layer.on('mousemove', (e) => {\n this.eventCache.mousemove = 1;\n if (this.parentLayer.type === 'RasterLayer') {\n const { lng, lat } = e.lngLat;\n const tile = this.getTile(lng, lat);\n this.getFeatureAndEmitEvent(\n layer,\n 'subLayerMouseMove',\n e,\n isVector,\n tile,\n );\n } else {\n this.getFeatureAndEmitEvent(layer, 'subLayerMouseMove', e);\n }\n });\n layer.on('mouseup', (e) => {\n this.eventCache.mouseup = 1;\n this.getFeatureAndEmitEvent(layer, 'subLayerMouseUp', e);\n });\n layer.on('mouseenter', (e) => {\n if (this.parentLayer.type === 'RasterLayer') {\n const { lng, lat } = e.lngLat;\n const tile = this.getTile(lng, lat);\n this.getFeatureAndEmitEvent(\n layer,\n 'subLayerMouseMove',\n e,\n isVector,\n tile,\n );\n } else {\n this.getFeatureAndEmitEvent(layer, 'subLayerMouseEnter', e);\n }\n });\n layer.on('mouseout', (e) => {\n this.getFeatureAndEmitEvent(layer, 'subLayerMouseOut', e);\n });\n layer.on('mousedown', (e) => {\n this.eventCache.mousedown = 1;\n this.getFeatureAndEmitEvent(layer, 'subLayerMouseDown', e);\n });\n layer.on('contextmenu', (e) => {\n this.eventCache.contextmenu = 1;\n this.getFeatureAndEmitEvent(layer, 'subLayerContextmenu', e);\n });\n\n // out side\n layer.on('unclick', (e) =>\n this.handleOutsideEvent('click', 'subLayerUnClick', layer, e),\n );\n layer.on('unmouseup', (e) =>\n this.handleOutsideEvent('mouseup', 'subLayerUnMouseUp', layer, e),\n );\n layer.on('unmousedown', (e) =>\n this.handleOutsideEvent('mousedown', 'subLayerUnMouseDown', layer, e),\n );\n layer.on('uncontextmenu', (e) =>\n this.handleOutsideEvent(\n 'contextmenu',\n 'subLayerUnContextmenu',\n layer,\n e,\n ),\n );\n });\n });\n }\n\n protected getCombineFeature(features: IParseDataItem[]) {\n let p: any = null;\n const properties = features[0];\n features.map((feature) => {\n const polygon = turf.polygon(feature.coordinates);\n if (p === null) {\n p = polygon;\n }\n {\n p = union(p, polygon);\n }\n });\n if (properties) {\n p.properties = { ...properties };\n }\n return p;\n }\n\n protected getFeatureAndEmitEvent(\n layer: ILayer,\n eventName: string,\n e: any,\n isVector?: boolean,\n tile?: any,\n ) {\n if (isVector === false) {\n // raster tile get rgb\n // e.pickedColors = readPixel(e.x, e.y, this.rendererService);\n // raster tile origin value\n e.value = readRasterValue(tile, this.mapService, e.x, e.y);\n } else {\n // VectorLayer\n const featureId = e.featureId;\n const features = this.getAllFeatures(featureId);\n try {\n e.feature = this.getCombineFeature(features);\n } catch (err) {\n console.warn('Combine Featuer Err! Return First Feature!');\n e.feature = features[0];\n }\n }\n this.parentLayer.emit(eventName, e);\n }\n\n private getAllFeatures(featureId: number) {\n const allLayers: ILayer[] = this.parentLayer.tileLayer.children;\n const features: IParseDataItem[] = [];\n allLayers.map((layer) => {\n const source = layer.getSource();\n source.data.dataArray.map((feature) => {\n if (feature._id === featureId) {\n features.push(feature);\n }\n });\n });\n return features;\n }\n\n private getLayerInitOption(initOptions: ISubLayerInitOptions) {\n const option = { ...initOptions };\n delete option.color;\n delete option.shape;\n delete option.size;\n delete option.coords;\n delete option.sourceLayer;\n delete option.coords;\n return option;\n }\n\n private handleOutsideEvent(\n type: CacheEvent,\n emitType: string,\n layer: ILayer,\n e: any,\n ) {\n if (this.outSideEventTimer) {\n clearTimeout(this.outSideEventTimer);\n this.outSideEventTimer = null;\n }\n this.outSideEventTimer = setTimeout(() => {\n if (this.eventCache[type] > 0) {\n this.eventCache[type] = 0;\n } else {\n this.getFeatureAndEmitEvent(layer, emitType, e);\n }\n }, 64);\n }\n}\n"],"file":"base.js"}
|
|
@@ -73,7 +73,7 @@ var RasterTiffTile = function (_TileFactory) {
|
|
|
73
73
|
clampLow: clampLow,
|
|
74
74
|
rampColors: rampColors
|
|
75
75
|
});
|
|
76
|
-
this.emitEvent([layer], false
|
|
76
|
+
this.emitEvent([layer], false);
|
|
77
77
|
(0, _utils.registerLayers)(this.parentLayer, [layer]);
|
|
78
78
|
return {
|
|
79
79
|
layers: [layer],
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/tile/tileFactory/rasterData.ts"],"names":["RasterTiffTile","option","parentLayer","parent","tile","initOptions","opacity","domain","clampHigh","clampLow","rampColors","mask","tiffdata","data","layer","RasterDataLayer","visible","isVisible","source","parser","type","width","height","extent","bboxPolygon","bbox","style","emitEvent","layers","layerIDList","id","TileFactory"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAGA;;AACA;;AACA;;;;;;IAEqBA,c;;;;;AAGnB,0BAAYC,MAAZ,EAAyC;AAAA;;AAAA;AACvC,8BAAMA,MAAN;AADuC;AAEvC,UAAKC,WAAL,GAAmBD,MAAM,CAACE,MAA1B;AAFuC;AAGxC;;;;WAED,oBAAkBC,IAAlB,EAA8BC,WAA9B,EAAiE;AAC/D,UACEC,OADF,GAOID,WAPJ,CACEC,OADF;AAAA,UAEEC,MAFF,GAOIF,WAPJ,CAEEE,MAFF;AAAA,UAGEC,SAHF,GAOIH,WAPJ,CAGEG,SAHF;AAAA,UAIEC,QAJF,GAOIJ,WAPJ,CAIEI,QAJF;AAAA,UAKEC,UALF,GAOIL,WAPJ,CAKEK,UALF;AAAA,UAMEC,IANF,GAOIN,WAPJ,CAMEM,IANF;AAQA,UAAMC,QAAQ,GAAGR,IAAI,CAACS,IAAtB;AACA,UAAMC,KAAK,GAAG,IAAIC,wBAAJ,CAAoB;AAChCC,QAAAA,OAAO,EAAEZ,IAAI,CAACa,SADkB;AAEhCN,QAAAA,IAAI,EAAJA;AAFgC,OAApB,EAIXO,MAJW,CAIJN,QAAQ,CAACC,IAJL,EAIW;AACrBM,QAAAA,MAAM,EAAE;AACNC,UAAAA,IAAI,EAAE,QADA;AAENC,UAAAA,KAAK,EAAET,QAAQ,CAACS,KAFV;AAGNC,UAAAA,MAAM,EAAEV,QAAQ,CAACU,MAHX;AAINC,UAAAA,MAAM,EAAEnB,IAAI,CAACoB,WAAL,CAAiBC;AAJnB;AADa,OAJX,EAYXC,KAZW,CAYL;AACLpB,QAAAA,OAAO,EAAPA,OADK;AAELC,QAAAA,MAAM,EAANA,MAFK;AAGLC,QAAAA,SAAS,EAATA,SAHK;AAILC,QAAAA,QAAQ,EAARA,QAJK;AAKLC,QAAAA,UAAU,EAAVA;AALK,OAZK,CAAd;AAmBA,WAAKiB,SAAL,CAAe,CAACb,KAAD,CAAf,EAAwB,KAAxB
|
|
1
|
+
{"version":3,"sources":["../../../src/tile/tileFactory/rasterData.ts"],"names":["RasterTiffTile","option","parentLayer","parent","tile","initOptions","opacity","domain","clampHigh","clampLow","rampColors","mask","tiffdata","data","layer","RasterDataLayer","visible","isVisible","source","parser","type","width","height","extent","bboxPolygon","bbox","style","emitEvent","layers","layerIDList","id","TileFactory"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAGA;;AACA;;AACA;;;;;;IAEqBA,c;;;;;AAGnB,0BAAYC,MAAZ,EAAyC;AAAA;;AAAA;AACvC,8BAAMA,MAAN;AADuC;AAEvC,UAAKC,WAAL,GAAmBD,MAAM,CAACE,MAA1B;AAFuC;AAGxC;;;;WAED,oBAAkBC,IAAlB,EAA8BC,WAA9B,EAAiE;AAC/D,UACEC,OADF,GAOID,WAPJ,CACEC,OADF;AAAA,UAEEC,MAFF,GAOIF,WAPJ,CAEEE,MAFF;AAAA,UAGEC,SAHF,GAOIH,WAPJ,CAGEG,SAHF;AAAA,UAIEC,QAJF,GAOIJ,WAPJ,CAIEI,QAJF;AAAA,UAKEC,UALF,GAOIL,WAPJ,CAKEK,UALF;AAAA,UAMEC,IANF,GAOIN,WAPJ,CAMEM,IANF;AAQA,UAAMC,QAAQ,GAAGR,IAAI,CAACS,IAAtB;AACA,UAAMC,KAAK,GAAG,IAAIC,wBAAJ,CAAoB;AAChCC,QAAAA,OAAO,EAAEZ,IAAI,CAACa,SADkB;AAEhCN,QAAAA,IAAI,EAAJA;AAFgC,OAApB,EAIXO,MAJW,CAIJN,QAAQ,CAACC,IAJL,EAIW;AACrBM,QAAAA,MAAM,EAAE;AACNC,UAAAA,IAAI,EAAE,QADA;AAENC,UAAAA,KAAK,EAAET,QAAQ,CAACS,KAFV;AAGNC,UAAAA,MAAM,EAAEV,QAAQ,CAACU,MAHX;AAINC,UAAAA,MAAM,EAAEnB,IAAI,CAACoB,WAAL,CAAiBC;AAJnB;AADa,OAJX,EAYXC,KAZW,CAYL;AACLpB,QAAAA,OAAO,EAAPA,OADK;AAELC,QAAAA,MAAM,EAANA,MAFK;AAGLC,QAAAA,SAAS,EAATA,SAHK;AAILC,QAAAA,QAAQ,EAARA,QAJK;AAKLC,QAAAA,UAAU,EAAVA;AALK,OAZK,CAAd;AAmBA,WAAKiB,SAAL,CAAe,CAACb,KAAD,CAAf,EAAwB,KAAxB;AAEA,iCAAe,KAAKZ,WAApB,EAAiC,CAACY,KAAD,CAAjC;AAEA,aAAO;AACLc,QAAAA,MAAM,EAAE,CAACd,KAAD,CADH;AAELe,QAAAA,WAAW,EAAE,CAACf,KAAK,CAACgB,EAAP;AAFR,OAAP;AAID;;;EA7CyCC,a","sourcesContent":["import { ILayer, ISubLayerInitOptions } from '@antv/l7-core';\nimport { Tile } from '@antv/l7-utils';\nimport { ITileFactoryOptions } from '../interface';\nimport { registerLayers } from '../utils';\nimport TileFactory from './base';\nimport RasterDataLayer from './rasterDataLayer';\n\nexport default class RasterTiffTile extends TileFactory {\n public parentLayer: ILayer;\n\n constructor(option: ITileFactoryOptions) {\n super(option);\n this.parentLayer = option.parent;\n }\n\n public createTile(tile: Tile, initOptions: ISubLayerInitOptions) {\n const {\n opacity,\n domain,\n clampHigh,\n clampLow,\n rampColors,\n mask,\n } = initOptions;\n const tiffdata = tile.data;\n const layer = new RasterDataLayer({\n visible: tile.isVisible,\n mask,\n })\n .source(tiffdata.data, {\n parser: {\n type: 'raster',\n width: tiffdata.width,\n height: tiffdata.height,\n extent: tile.bboxPolygon.bbox,\n },\n })\n .style({\n opacity,\n domain,\n clampHigh,\n clampLow,\n rampColors,\n });\n this.emitEvent([layer], false);\n\n registerLayers(this.parentLayer, [layer]);\n\n return {\n layers: [layer],\n layerIDList: [layer.id],\n };\n }\n}\n"],"file":"rasterData.js"}
|
package/lib/tile/utils.js
CHANGED
|
@@ -90,26 +90,31 @@ function getContainerSize(container) {
|
|
|
90
90
|
}
|
|
91
91
|
|
|
92
92
|
function readRasterValue(tile, mapService, x, y) {
|
|
93
|
-
var _tile$bboxPolygon, _tile$data;
|
|
93
|
+
var _tile$bboxPolygon, _tile$data, _tile$data2, _tile$data3;
|
|
94
94
|
|
|
95
|
-
var bbox = ((_tile$bboxPolygon = tile.bboxPolygon) === null || _tile$bboxPolygon === void 0 ? void 0 : _tile$bboxPolygon.bbox) || [0, 0, 10, -10];
|
|
95
|
+
var bbox = (tile === null || tile === void 0 ? void 0 : (_tile$bboxPolygon = tile.bboxPolygon) === null || _tile$bboxPolygon === void 0 ? void 0 : _tile$bboxPolygon.bbox) || [0, 0, 10, -10];
|
|
96
96
|
|
|
97
97
|
var _bbox = (0, _slicedToArray2.default)(bbox, 4),
|
|
98
98
|
_bbox$ = _bbox[0],
|
|
99
|
-
|
|
99
|
+
minLng = _bbox$ === void 0 ? 0 : _bbox$,
|
|
100
100
|
_bbox$2 = _bbox[1],
|
|
101
|
-
|
|
101
|
+
minLat = _bbox$2 === void 0 ? 0 : _bbox$2,
|
|
102
102
|
_bbox$3 = _bbox[2],
|
|
103
|
-
|
|
103
|
+
maxLng = _bbox$3 === void 0 ? 10 : _bbox$3,
|
|
104
104
|
_bbox$4 = _bbox[3],
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
var tileXY = mapService.lngLatToContainer([
|
|
108
|
-
var tileMaxXY = mapService.lngLatToContainer([
|
|
109
|
-
var
|
|
110
|
-
var
|
|
111
|
-
var
|
|
112
|
-
var
|
|
105
|
+
maxLat = _bbox$4 === void 0 ? -10 : _bbox$4;
|
|
106
|
+
|
|
107
|
+
var tileXY = mapService.lngLatToContainer([minLng, minLat]);
|
|
108
|
+
var tileMaxXY = mapService.lngLatToContainer([maxLng, maxLat]);
|
|
109
|
+
var tilePixelWidth = tileMaxXY.x - tileXY.x;
|
|
110
|
+
var tilePixelHeight = tileXY.y - tileMaxXY.y;
|
|
111
|
+
var pos = [(x - tileXY.x) / tilePixelWidth, (y - tileMaxXY.y) / tilePixelHeight];
|
|
112
|
+
var tileWidth = (tile === null || tile === void 0 ? void 0 : (_tile$data = tile.data) === null || _tile$data === void 0 ? void 0 : _tile$data.width) || 1;
|
|
113
|
+
var tileHeight = (tile === null || tile === void 0 ? void 0 : (_tile$data2 = tile.data) === null || _tile$data2 === void 0 ? void 0 : _tile$data2.height) || 1;
|
|
114
|
+
var indexX = Math.floor(pos[0] * tileWidth);
|
|
115
|
+
var indexY = Math.floor(pos[1] * tileHeight);
|
|
116
|
+
var index = Math.max(0, indexY - 1) * tileWidth + indexX;
|
|
117
|
+
var data = tile === null || tile === void 0 ? void 0 : (_tile$data3 = tile.data) === null || _tile$data3 === void 0 ? void 0 : _tile$data3.data[index];
|
|
113
118
|
return data;
|
|
114
119
|
}
|
|
115
120
|
|