zoukankan      html  css  js  c++  java
  • d3力导向图聚焦

    效果描述

    双击节点,节点以及节点一度关联的节点保持高亮状态,其余节点变灰,半径变小,文字消失,并且向内收缩。

    效果展示

    正常状态 

    聚焦效果

    关键代码

    节点变化
    激活节点保持高亮的样式,其余节点应用noActive样式,且半径变小。
    nodeUpdate
    .transition()
    .attr('class', (data) => {
    return (data.hide && 'hide') || (data.nodeStatus < 0 && 'noActive') || (data.cateType === 0 && 'mainCompany') || (data.cateType === 1 && 'relativeCompany') || (data.cateType === 2 && 'relativePerson');
    })
    .attr('r', (data) => {
    if (data.nodeStatus === -2) {
    return 5;
    }
    return data.cateType < 2 ? 20 : 10;
    });
    最重要的是,在双击节点后力导向模型的参数也要根据节点半径作出相应的变化。非激活状态的节点电荷力改为50。一条线有一端的节点为非激活状态,就将它的最短距离也就是distance设为50。这样就能达到一个收缩效果。
    this.simulation
    .alpha(0.3)
    .force('charge', d3.forceManyBody().strength((data) => {
    if (data.nodeStatus === -2) {
    return -50;
    }
    return -200;
    }))
    .force('link', d3.forceLink(this.edgesData).id((data) => { return data.name; }).distance((data) => {
    if (data.target.nodeStatus === -2 || data.source.nodeStatus === -2) {
    return 50;
    }
    return 150;
    }))
    .restart();

    详细实现请查看源码

  • 相关阅读:

    2018.10.18 常用API部分测试题
    2018.10.18课堂笔记HashMap之前
    JavaScript 的 this 原理
    vue h5转换uni-app
    Vue.js 3.0 新特性预览
    ES6模块与CommonJS的区别
    同源策略和跨域问题
    一口气了解 babel
    媒体查询,移动端常见布局以及其他
  • 原文地址:https://www.cnblogs.com/baize-q/p/7687324.html
Copyright © 2011-2022 走看看