火星地图插件

HTML

<!-- 地图容器 -->
<div id='GEOVISContainer'></div>

初始化地图、给图层添加单击事件

<script>
import hxMap from "@/utils/hxMap"
export default {
    name: "GeovisMap",
    data() {
        return {
            
        }
    },
    mounted() {
        this.initMap();
    },
    methods: {
        //初始化地图
        initMap() {
            // 初始化地图方法
	        hxMap.initMap("GEOVISContainer", () => {
		    HaynGlobe.Layer.addLayerWTMS("http://t0.tianditu.gov.cn/cia_c/wmts?service=wmts&request=GetTile&version=1.0.0&LAYER=cia&tileMatrixSet=c&TileMatrix={TileMatrix}&TileRow={TileRow}&TileCol={TileCol}&style=default&format=tiles&tk=51b509975686843c6e10e05785d00a49")
            // 加载地形数据
		    hxMap.addDemLayer()
            // 批量添加图层
            // 我添加了一个myLayer的图层,后续所有this.myLayer都是对这个图层的操作
		    hxMap.addLayer(this, ['myLayer', 'equNameLayer'])
            hxMap.resgister.graphicClick(this.pointGroup,(graphicItem)=>{
                // 图形转换为json串=>graphicItem 图形
                let signJson = hxMap.conversion.toJson(graphicItem)
                if(signJson.properties.data&&signJson.properties.data.iconType=='alarm'){
                    this.$refs.details.openDetail(signJson.properties.data);
                }
                // 获取添加到图形中的自定义内容,参考exhibit回显方法中自定义添加的data
	            let data = hxMap.edit.getGraphicMain(graphicItem).data
	            if (data) {
	              this.jumpTo(data)
	            }
})
	}, true);
}
    },

 地图上添加标记和文字

if (item.wktPoint) {
    // 画圆点
    // layer 加入图层
    // coordinates 位置 [lon,lat,0]
    // flag 是否图形居中 1为不居中
    // keyId 设置图形keyId
    // color 颜色
    // size 圆点大小
    // data 设定图形自定义属性
    hxMap.exhibit.point(this.myLayer, shapeVal.coordinates,0,item.id,'','',item)
    // 画图片
    // layer 加入图层
    // coordinates 位置 [lon,lat,0]
    // img 图片路径
    // keyId 设置图形keyId
    // width 图形宽度
    // height 图形高度
    // data 设定图形自定义属性
    // flag 是否图形居中 1为不居中
    hxMap.exhibit.pic(this.myLayer, shapeVal.coordinates, img, data.id, 55, 55, data)
    // 画文本
    // layer 加入图层
    // coordinates 位置 [lon,lat,0]
    // text 文字内容
    // keyId 设置图形keyId
    // x x轴偏移量
    // y y轴偏移量
    // data 设定图形自定义属性
    hxMap.exhibit.text(this.myLayer, shapeVal.coordinates, data.name, '名称' + data.id)
    // 波动亮点
    // layer 加入图层
    // coordinates 位置 [lon,lat,0]
    // keyId 设置图形keyId
    // color 颜色
    // size 圆点大小
    // flag 是否图形居中 1为不居中
    // data 设定图形自定义属性
    hxMap.specialGraphics.lightPoint(this.newAlarmLayer, shapeVal.coordinates, '', '#FF0000', 20, true, data,1)
}

根据keyId删除图层中图形=>layer图层

hxMap.edit.delByKeyId(this.myLayer,"告警-"+ data.srcIndex);

为图层添加点击事件

hxMap.resgister.graphicClick(this.pointGroup,(graphicItem)=>{
	let data = hxMap.edit.getGraphicMain(graphicItem).data
	if (data) {
	  this.loadPresetByEquId(data)
	}
})

清除图层

clearMap(){
    // 清除测量数据
    hxMap.measure.measureClear();
    // 批量清空图层数据
    hxMap.clearLayer(this, ['myLayer','signGroup'])
}

移动镜头

let shapeVal = hxMap.conversion.toGeoJson(wktPoint)
hxMap.fly.flyToCenter(shapeVal.coordinates[0], shapeVal.coordinates[1],4000)

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-20 12:22:03       57 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-20 12:22:03       60 阅读
  3. 在Django里面运行非项目文件

    2024-07-20 12:22:03       48 阅读
  4. Python语言-面向对象

    2024-07-20 12:22:03       59 阅读

热门阅读

  1. 白骑士的PyCharm教学目录

    2024-07-20 12:22:03       19 阅读
  2. Mathematical Problem

    2024-07-20 12:22:03       17 阅读
  3. 第六章 Spring框架深入学习(2023版本IDEA)

    2024-07-20 12:22:03       15 阅读
  4. IO文件流

    2024-07-20 12:22:03       16 阅读
  5. 游戏外挂的技术实现与五年脚本开发经验分享

    2024-07-20 12:22:03       17 阅读
  6. mysql高阶知识梳理

    2024-07-20 12:22:03       17 阅读
  7. 3.设计模式--创建者模式--工厂模式

    2024-07-20 12:22:03       16 阅读
  8. npm下载的依赖包版本号怎么看

    2024-07-20 12:22:03       17 阅读