关于echarts地图禁止拖拽问题

虽然官方文档里有,但是我还是记一下方便自己记住

在series中将roam设置为false就可以禁用拖拽

以下是一个简单的 echarts 地图限制拖动范围的 demo: ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>ECharts Map Demo</title> <!-- 引入 echarts.js --> <script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script> </head> <body> <!-- 定义一个容器来渲染 echarts 地图 --> <div id="map" style="width: 100%; height: 500px;"></div> <script> // 初始化 echarts 实例 var myChart = echarts.init(document.getElementById('map')); // 配置 echarts 地图 var option = { // 地图类型 series: [{ type: 'map', mapType: 'china' }] }; // 设置限制拖动范围 myChart.setOption(option); var zoom = myChart.getOption().geo[0].zoom; var centerX = myChart.getOption().geo[0].center[0]; var centerY = myChart.getOption().geo[0].center[1]; var boundLeft = centerX - 20 / zoom; var boundRight = centerX + 20 / zoom; var boundTop = centerY - 10 / zoom; var boundBottom = centerY + 10 / zoom; myChart.setOption({ geo: { center: [centerX, centerY], zoom: zoom, roam: true, scaleLimit: { min: 1, max: 5 }, // 设置限制拖动范围 boundingCoords: [[boundLeft, boundTop], [boundRight, boundBottom]] } }); // 监听 echarts 地图缩放事件 myChart.on('geoRoam', function(params) { var zoom = params.zoom; var centerX = params.center[0]; var centerY = params.center[1]; var boundLeft = centerX - 20 / zoom; var boundRight = centerX + 20 / zoom; var boundTop = centerY - 10 / zoom; var boundBottom = centerY + 10 / zoom; myChart.setOption({ geo: { center: [centerX, centerY], zoom: zoom, roam: true, scaleLimit: { min: 1, max: 5 }, // 更新限制拖动范围 boundingCoords: [[boundLeft, boundTop], [boundRight, boundBottom]] } }); }); // 渲染 echarts 地图 myChart.setOption(option); </script> </body> </html> ``` 这个 demo 展示了如何使用 echarts 的 `boundingCoords` 属性来限制地图的拖动范围,在缩放地图时动态更新限制范围。具体实现方法可以参考代码注释。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值