ColorEdges 动态有向图的动态渲染

一:主要的知识点

1、说明

本文只是教程内容的一小段,因博客字数限制,故进行拆分。主教程链接:vtk教程------逐行解析官网所有Python示例-CSDN博客

2、知识点纪要

本段代码主要涉及的有①有向动态图的创建,②图结构数据的可视化和布局展示

二:代码及注释

python 复制代码
import vtkmodules.vtkRenderingOpenGL2
import vtkmodules.vtkInteractionStyle
from vtkmodules.vtkCommonColor import vtkNamedColors
from vtkmodules.vtkCommonCore import vtkIntArray, vtkLookupTable
from vtkmodules.vtkCommonDataModel import vtkMutableDirectedGraph
from vtkmodules.vtkViewsInfovis import vtkGraphLayoutView
from vtkmodules.vtkViewsCore import vtkViewTheme

def main():
    colors = vtkNamedColors()

    # 创建一个动态有向图
    graph = vtkMutableDirectedGraph()

    # AddVertex添加节点(顶点)
    v1 = graph.AddVertex()
    v2 = graph.AddVertex()
    v3 = graph.AddVertex()

    # AddGraphEdge 添加有向边
    graph.AddGraphEdge(v1, v2)
    graph.AddGraphEdge(v2, v3)

    # 创建颜色数组
    edgeColors = vtkIntArray()
    edgeColors.SetNumberOfValues(1)
    edgeColors.SetName('Color')
    edgeColors.InsertNextValue(0)
    edgeColors.InsertNextValue(1)

    # 创建颜色查找表
    lookupTable = vtkLookupTable()
    lookupTable.SetNumberOfTableValues(2)
    lookupTable.SetTableValue(0, colors.GetColor4d("Red"))
    lookupTable.SetTableValue(1, colors.GetColor4d("Lime"))
    lookupTable.Build()

    graph.GetEdgeData().AddArray(edgeColors)

    """
    vtkGraphLayoutView  专门用于图(Graph)结构数据" 的可视化和布局展示
    核心功能是:把一个由节点(Vertices)和边(Edges)组成的图结构,自动排布到 2D 或 3D 空间中,并渲染出来供你交互查看
    封装了布局(layout),显示(rendering),交互(interaction)
    """
    graphLayoutView = vtkGraphLayoutView()
    graphLayoutView.AddRepresentationFromInput(graph)
    # SetLayoutStrategy 设置布局
    graphLayoutView.SetLayoutStrategy('Simple 2D')
    # graphLayoutView.GetLayoutStrategy().SetEdgeWeightField('Graphs')
    # graphLayoutView.GetLayoutStrategy().SetWeightEdges(1)

    # 按属性字段映射边颜色
    graphLayoutView.SetEdgeColorArrayName('Color')
    graphLayoutView.SetEdgeLabelVisibility(1)
    graphLayoutView.ColorEdgesOn()

    """
    vtkViewTheme 
    用于统一设置一个 View(比如 vtkGraphLayoutView、vtkTreeMapView、vtkScatterPlotMatrixView 等)的 配色、字体、线条粗细、背景等整体视觉主题
    """
    theme = vtkViewTheme()
    theme.SetCellLookupTable(lookupTable)

    graphLayoutView.ApplyViewTheme(theme)
    graphLayoutView.ResetCamera()
    graphLayoutView.GetRenderer().GetActiveCamera().Zoom(0.8)
    graphLayoutView.Render()
    # graphLayoutView.GetLayoutStrategy().SetRandomSeed(0)
    graphLayoutView.GetInteractor().Initialize()
    graphLayoutView.GetInteractor().Start()



if __name__ == '__main__':
    main()
相关推荐
java干货25 分钟前
为什么 “File 10“ 排在 “File 2“ 前面?解决文件名排序的终极算法:自然排序
开发语言·python·算法
机器懒得学习27 分钟前
智能股票分析系统
python·深度学习·金融
毕设源码-郭学长27 分钟前
【开题答辩全过程】以 基于python的二手房数据分析与可视化为例,包含答辩的问题和答案
开发语言·python·数据分析
SR_shuiyunjian30 分钟前
Python第三次作业
python
vx_biyesheji000131 分钟前
豆瓣电影推荐系统 | Python Django 协同过滤 Echarts可视化 深度学习 大数据 毕业设计源码
大数据·爬虫·python·深度学习·django·毕业设计·echarts
鸽芷咕1 小时前
DrissionPage 成 CANN 仓库爆款自动化工具:背后原因何在?
运维·python·自动化·cann
爱学习的阿磊1 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python
少云清1 小时前
【金融项目实战】7_接口测试 _代码实现接口测试(重点)
python·金融项目实战
深蓝电商API1 小时前
爬虫IP封禁后的自动切换与检测机制
爬虫·python
m0_550024631 小时前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python