echarts-gl和Maptalks(1.0.0-rc.6)使用问题

634 阅读1分钟

研究背景

    最近看看echarts-gl发现有些效果挺好的,就是使用Echarts5和最近版Maptalks(1.0.0-rc.6)有些问题,地图居然不能进行缩放。

问题原因

    研究一番,发现Maptalks(0.38.0)版本是可以,于是一个个版本来试,发现在(Maptalks0.47.5)更新之后就出现问题了,发现是滚轮事件监听修改了,当时为了修复火狐的滚轮事件异常(老的鼠标事件标准已经废弃)。 image.png image.png github.com/maptalks/ma… 8ANNK{YP{$N47@@U5I$2T.png

修复问题

    修改以下代码发现恢复正常,但是在火狐上使用后又发现新问题,滚轮事件一触发那就会报illegal constror。
    后来经过和广大-拖延症晚期的讨论发现,只要事件中加入'wheel'并且在滚轮事件使用WheelEvent就能搞定。

//增加鼠标事件
var EVENTS = ['mousedown', 'mouseup', 'click', 'dblclick', 'mousemove',
    'mousewheel', 'DOMMouseScroll','wheel',
    'touchstart', 'touchend', 'touchmove', 'touchcancel'
];
//创建鼠标事件
let newE=new WheelEvent(eName,  obj);

echarts-gl 中maptalks案例图

image.png image.png

参考资料:
developer.mozilla.org/en-US/docs/…
github.com/maptalks/ma…
github.com/ecomfe/echa…