最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

如何实现d3力导向图聚焦

来源:动视网 责编:小采 时间:2020-11-27 20:11:57
文档

如何实现d3力导向图聚焦

如何实现d3力导向图聚焦:效果描述双击节点,节点以及节点一度关联的节点保持高亮状态,其余节点变灰,半径变小,文字消失,并且向内收缩。效果展示正常状态 聚焦效果 关键代码节点变化激活节点保持高亮的样式,其余节点应用noActive样式,且半径变小。'class', (da
推荐度:
导读如何实现d3力导向图聚焦:效果描述双击节点,节点以及节点一度关联的节点保持高亮状态,其余节点变灰,半径变小,文字消失,并且向内收缩。效果展示正常状态 聚焦效果 关键代码节点变化激活节点保持高亮的样式,其余节点应用noActive样式,且半径变小。'class', (da


效果描述

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

效果展示

正常状态

聚焦效果

关键代码

节点变化

激活节点保持高亮的样式,其余节点应用noActive样式,且半径变小。

'class', (data) => (data.hide && 'hide') || (data.nodeStatus < 0 && 'noActive') || (data.cateType === 0 && 'mainCompany') || (data.cateType === 1 && 'relativeCompany') || (data.cateType === 2 && 'relativePerson''r', (data) => (data.nodeStatus === -2 5 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();

详细实现请查看源码

文档

如何实现d3力导向图聚焦

如何实现d3力导向图聚焦:效果描述双击节点,节点以及节点一度关联的节点保持高亮状态,其余节点变灰,半径变小,文字消失,并且向内收缩。效果展示正常状态 聚焦效果 关键代码节点变化激活节点保持高亮的样式,其余节点应用noActive样式,且半径变小。'class', (da
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top