d3.js – 如何找出强制布局是否完成放置节点?

前端之家收集整理的这篇文章主要介绍了d3.js – 如何找出强制布局是否完成放置节点?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有基于力布局的图.我想放一个’加载’覆盖直到图完成放置节点.可以使用哪些事件/属性来找出该图形?

我检查了API,找不到任何东西..

解决方法

当布局收敛时,force.alpha()将被设置为0.设置一个计时器来轮询(不经常!),你会知道什么时候完成.

此示例应该重试每个间隔毫秒,直到布局停止.变量定时器保持当前的定时器,如果您不想等待布局完成任务,则可以重置该定时器.

var timer = null;
function onCompletion(force,callback,interval) {
    interval = interval || 300;

    function retryIfRunning() {
        if (force.alpha() != 0)
            timer = setTimeout(checkAndRetry,interval);
        else {
            timer = null;
            callback();
        }
    }

    retryIfRunning();
}
原文链接:https://www.f2er.com/js/152845.html

猜你在找的JavaScript相关文章