如何限制d3中的可拖动区域?

How to limit draggable area in d3?

我在 d3 中有一个可拖动元素,但我想将可拖动区域限制在 svg 的边界内,这样它就永远不会超出视野。这可能吗?这是一个 jsfiddle,对可以拖动元素的位置没有限制:

https://jsfiddle.net/asicfr/34TKg/

var drag1 = d3.behavior.drag()
        .origin(function() { 
            var t = d3.select(this);
            return {x: t.attr("x") + d3.transform(t.attr("transform")).translate[0],
                    y: t.attr("y") + d3.transform(t.attr("transform")).translate[1]};
        })
        .on("drag", function(d,i) {
            d3.select(this).attr("transform", function(d,i){
                return "translate(" + [ d3.event.x,d3.event.y ] + ")"
            })
        });

group.call(drag1);

干净整洁的 JSFiddle - 很容易为您提供帮助!

您可以手动执行此操作,前提是您知道容器的尺寸和要拖动的元素。

本质上,您可以检查拖动对象的潜在新位置是否会超出容器的范围。如果是这样,则将元素的位置设置为使其在容器内完全可见的值。

我制作了一个 JSFiddle 来展示它:https://jsfiddle.net/0sga1ypc/

我的大部分更新都是在 drag 事件的回调函数中进行的:

    .on("drag", function(d,i) {
        var left = d3.event.x
        if (left + groupWidth + strokeWidth > svgWidth) {
            left = svgWidth - groupWidth - strokeWidth
        } else if (d3.event.x < 0) {
            left = 0
        }
        var top = d3.event.y
        if (top + groupHeight + strokeWidth > svgHeight) {
          top = svgHeight - groupHeight - strokeWidth
        } else if (d3.event.y < 0) {
          top = 0
        }
        d3.select(this).attr("transform", function(d,i){
            return "translate(" + [ left,top ] + ")"
        })
    });

我所做的唯一其他更改是将相关维度值保存到变量中,这样它们就不会被多次写出。

希望对您有所帮助!