实现echarts地图监听缩放事件效果

echarts地图缩放事件

最近应项目要求需要做地图放大展示markpoint标记点,缩小标记点消失在这里插入图片描述
在这里插入图片描述
以上就是效果图,主要就是用到了echarts的georoam事件,官方文档没有看到这个事件,这个事件能监听缩放与拖曳事件,话不多说直接上代码
在这里插入图片描述
georoam事件可以取到zoom值,但是是一个固定值,需要变通一下,通过getOption()方法取到当前zoom值,然后就可以通过判断zoom值做你想要做的事了嘿嘿嘿(手动狗头.),当然代码肯定是要进行优化的,不然要卡顿,因为georoam能同时响应缩放和拖曳。不过我这里代码也勉强够用了,嘻嘻。在此非常感谢指导我的一位大佬。。。(ps:用这个事件注意需要结合geo)
在这里插入图片描述
最后附上一个下载阿里的geojson数据的地址:http://datav.aliyun.com/tools/atlas/#&lat=31.914867503276223&lng=104.1064453125&zoom=4
还有两个手动画geojson数据的地址:http://geojson.io/?tdsourcetag=s_pcqq_aiomsg#map=9/27.2595/110.4648、https://www.strerr.com/geojson/geojson.html#map=5/32.157/98.306(或者下载一个Arcgis)

在Vue中使用ECharts实现地图的点击事件,需要按照ECharts提供的API进行操作。首先,确保已经在Vue项目中正确安装并引入了ECharts库。然后,在Vue组件的`mounted`钩子中初始化ECharts实例,并设置相应的事件监听器。下面是一个基本的实现步骤: 1. 在Vue组件的`data`对象中定义一个ECharts图表实例变量。 2. 在`mounted`钩子中初始化ECharts实例,并使用`setOption`方法配置图表选项,其中包括事件监听器。 3. 在图表的事件监听器中定义点击事件处理函数,处理用户的点击操作,并执行相应的逻辑。 下面是一个简单的代码示例: ```javascript <template> <div ref="map" class="map"></div> </template> <script> export default { data() { return { chart: null, // ECharts实例 }; }, mounted() { this.initChart(); }, methods: { initChart() { this.chart = this.$echarts.init(this.$refs.map); // 初始化ECharts实例 const option = { geo: { map: 'china', // 地图类型 roam: false, // 是否允许缩放和平移漫游 }, // ... 其他配置项 }; this.chart.setOption(option); // 应用配置项 // 注册地图点击事件 this.chart.on('click', (params) => { // params 包含点击事件相关的参数,例如地理位置名称等 console.log('地图被点击', params); // 根据点击的地区名称或其他参数执行相应逻辑 }); }, }, }; </script> ``` 在上面的代码中,我们创建了一个名为`initChart`的方法来初始化ECharts实例,并注册了一个点击事件监听器。当用户点击地图上的某个区域时,`click`事件会被触发,并打印出相关的参数。
评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值