传单 - 鼠标悬停,单击并取消选中

时间:2015-01-28 10:02:20

标签: javascript leaflet mouseover highlight

以下是我的工作示例http://members.upcpoczta.pl/w.racek/mapa.html

我想实现的是:

  1. 在鼠标悬停时保持高亮显示,就像现在一样,

  2. 当我点击突出显示的自行车路线时,我想保持缩放到功能,但当它放大到路线时,我想继续突出显示,直到我点击所选路线外面或移动地图。

  3. 现在它可以很好地放大,但是当你移动时,鼠标突出显示消失,而你却不知道你点击了哪条路线。

1 个答案:

答案 0 :(得分:2)

好吧,有点hacky但是把它视为如何完成这样的事情的演示。创建变量selected,并在click处理程序被触发时将突出显示的功能存储在那里。现在,在mouseout处理程序中,您需要检查是否进行了选择,看看它是否与触发mouseout的图层相对应,如果是,则不要删除突出显示的样式。此外,您需要在click处理程序中编写一些逻辑,如果已经进行了选择,则会从中删除突出显示。

代码示例:

    function highlight (layer) {
        layer.setStyle({
            weight: 5,
            dashArray: ''
        });
        if (!L.Browser.ie && !L.Browser.opera) {
            layer.bringToFront();
        }
    }

    function dehighlight (layer) {
        if (selected === null || selected._leaflet_id !== layer._leaflet_id) {
            geojson.resetStyle(layer);
        }
    }

    // Variable to store selection
    var selected = null;

    function select (layer) {
        // See if there is already a selection
        if (selected !== null) {
            // Store for now
            var previous = selected;
        }
        map.fitBounds(layer.getBounds());
        // Set new selection
        selected = layer;
        // If there was a previous selection
        if (previous) {
            // Dehighlight previous
            dehighlight(previous);
        }
    }

    var geojson = L.geoJson(rower, {
        style: function (feature) {
            return {
                weight: 2,
                opacity: 1,
                color: feature.properties.colour,
                dashArray: 3,
            };
        },
        onEachFeature: function (feature, layer) {
        layer.on({
            'mouseover': function (e) {
                highlight(e.target);
            },
            'mouseout': function (e) {
                dehighlight(e.target);
            },
            'click': function (e) {
              select(e.target);
            }
        });
    }
}).addTo(map);

以下是关于Plunker的工作示例:http://plnkr.co/edit/fdTnA9CyJdJejiPq2q8M?p=preview

您还需要为地图clickmoveend或您尝试完成的任何内容编写处理程序,并在那里检查是否有选择,然后删除突出显示它,但是一旦你掌握了这个概念,那就相当简单了。