Difference between revisions of "ParaView/Python/SavePipelineAsGraph"

From KitwarePublic
Jump to navigationJump to search
(One intermediate revision by the same user not shown)
Line 39: Line 39:
       d.render(path, view=view)
       d.render(path, view=view)
Then simply call it:
<source lang="python">
  SavePipelineGraph("~/pipeline", "pdf")
Back to [[ParaView/PythonRecipes]].

Latest revision as of 14:34, 16 October 2018


The simple API provides functions to manipulate the sources, using graphviz we can save and even show the current Pipeline as a graph, in order to obtain images like this



def SavePipelineGraph(path, format="png", view=False):
    """Save the state of the pipelines (aka Sources and Filters) as a graph.
    Specify the path to save the graph to, Optionaly, specify the format to save it to,
    default is "png" but it can be "pdf" for instance. If you want to show it right away,
    set view parameter to True, default is False.
    This method is using graphviz and will save two files. One will be save in the graphviz
    format (.gv), the other one to the specified format.
      import graphviz
    except ImportError:
      print("Graphviz could not be imported", file=sys.stderr)

    d = graphviz.Digraph()
    activeSource = GetActiveSource()
    sources = GetSources()
    if len(sources) == 0:
      print("Pipeline is empty")
      for item in sources.items():
        key = item[0]
        source = item[1]
        color = "red" if source == activeSource else "black"
        d.node(key[1], label=key[0], color=color)
        proxy = source.SMProxy
        for i in range(proxy.GetNumberOfProducers()):
          prod = proxy.GetProducerProxy(i)
          if prod.IsTypeOf("vtkSMSourceProxy"):
            d.edge(str(proxy.GetProducerProxy(i).GetGlobalID()), str(key[1]))
      d.format = format
      d.render(path, view=view)

Then simply call it:

  SavePipelineGraph("~/pipeline", "pdf")

Back to ParaView/PythonRecipes.

ParaView: [Welcome | Site Map]