123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- def build_plotly_figure(self, pos=None):
- """
- Creates a Plot.ly Figure that can be view online or offline.
- Parameters
- ----------
- graph : nx.Graph
- The network of zettels to visualize
- pos : dict
- Dictionay of zettel_id : (x, y) coordinates where to draw nodes. If
- None, the Kamada Kawai layout will be used.
- Returns
- -------
- fig : plotly Figure
- """
- if pos is None:
-
-
-
- if len(self.graph) < 1000:
- pos = nx.layout.kamada_kawai_layout(self.graph)
- else:
- pos = nx.layout.random_layout(self.graph)
-
- node_trace = go.Scatter(
- x=[],
- y=[],
- text=[],
- mode="markers",
- hoverinfo="text",
- marker=dict(
- showscale=True,
-
-
-
-
- colorscale="YlGnBu",
- reversescale=True,
- color=[],
- size=10,
- colorbar=dict(
- thickness=15, title="Centrality", xanchor="left", titleside="right"
- ),
- line=dict(width=2),
- ),
- )
- for node in self.graph.nodes():
- x, y = pos[node]
- text = "<br>".join([node, self.graph.nodes[node].get("title", "")])
- node_trace["x"] += tuple([x])
- node_trace["y"] += tuple([y])
- node_trace["text"] += tuple([text])
-
- for node, centrality in nx.degree_centrality(self.graph).items():
- node_trace["marker"]["color"] += tuple([centrality])
-
- edges = []
- for from_node, to_node in self.graph.edges():
- edges.append(
- dict(
-
- ax=pos[from_node][0],
- ay=pos[from_node][1],
- axref="x",
- ayref="y",
-
- x=pos[to_node][0],
- y=pos[to_node][1],
- xref="x",
- yref="y",
-
- arrowwidth=2,
- arrowcolor="#666",
- arrowhead=2,
-
-
- standoff=5,
- )
- )
- fig = go.Figure(
- data=[node_trace],
- layout=go.Layout(
- showlegend=False,
- hovermode="closest",
- margin=dict(b=20, l=5, r=5, t=40),
- annotations=edges,
- xaxis=dict(showgrid=False, zeroline=False, showticklabels=False),
- yaxis=dict(showgrid=False, zeroline=False, showticklabels=False),
- ),
- )
- return fig
|