繁体   English   中英

向mapbox.js添加功能

[英]Adding functionality to mapbox.js

我试图重写grid_control.jsMapBox允许从几个提示gridControl到在同一个盒子的同时一起出现。

gridControl被激活,因此:

var gridLayer = L.mapbox.gridLayer('example-map.sdfagg22gd');
var tileLayer = L.mapbox.tileLayer('example-map.sdfagg22gd')
map.addLayer(tileLayer);
map.addLayer(gridLayer);
map.addControl(L.mapbox.gridControl(gridLayer));    

但是,我不想重写源代码,而是想扩展GridControl类,并使代码与将来的mapbox.js版本更加兼容。

var GridControl = L.Control.extend({

options: {
    pinnable: true,
    follow: false,
    sanitizer: require('sanitize-caja'),
    touchTeaser: true,
    location: true
},

我应该怎么做,建议这样做吗?

另外,关于如何同时允许多个工具提示的任何想法? 我是否需要一个计数器来获取活动的工具提示并根据此操作重做所有操作? 任何指针将不胜感激。

据我了解,并发工具提示的可能性是可能的,因为带有工具提示内容的两个单独的框将显示为{follow : false}选项。 但是如何将其放入以鼠标为中心的移动工具提示(由{follow: true}激活)?

只是:

// get gridControl object and pass it for modification
var gridControl = L.mapbox.gridControl(gridLayer, {follow:true});

// modify the prototype
gridControl.__proto__._onPopupClose = function() {
   this._currentContent = null;
   this._lastContent = null;
   this._pinned = false;
};

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM