我正在使用GraphPlot绘制大约有100个顶点的有向图。我通过定义VertexRenderingFunction将每个顶点替换为一个小的矩形或正方形图像。这些图像通常会重叠。有没有办法让Mathematica将顶点间隔得更远,以防止它们重叠?
我尝试了“方法”的各种明显选项("SpringElectricalEmbedding“、"SpringEmbedding”、"HighDimensionalEmbedding“、"CircularEmbedding”、"RandomEmbedding“、"LinearEmbedding")。
trans = {1 -> 1, 2 -> 1, 3 -> 1, 4 -> 1, 5 -> 1, 6 -> 1, 7 -> 1,
8 -> 1, 9 -> 1, 10 -> 1, 11 -> 1, 12 -> 1, 13 -> 1, 14 -> 1,
15 -> 1, 16 -> 1, 17 -> 1, 18 -> 13, 19 -> 1, 20 -> 13, 21 -> 13,
22 -> 70, 23 -> 1, 24 -> 1, 25 -> 1, 26 -> 1, 27 -> 13, 28 -> 13,
29 -> 1, 30 -> 13, 31 -> 13, 32 -> 1, 33 -> 19, 34 -> 70, 35 -> 70,
36 -> 1, 37 -> 1, 38 -> 1, 39 -> 39, 40 -> 13, 41 -> 2, 42 -> 13,
43 -> 1, 44 -> 2, 45 -> 1, 46 -> 52, 47 -> 2, 48 -> 68, 49 -> 49,
50 -> 19, 51 -> 78, 52 -> 1, 53 -> 1, 54 -> 39, 55 -> 13, 56 -> 56,
57 -> 13, 58 -> 13, 59 -> 1, 60 -> 36, 61 -> 1, 62 -> 52, 63 -> 2,
6 4 -> 68, 65 -> 19, 66 -> 56, 67 -> 4, 68 -> 76, 69 -> 19,
70 -> 78, 71 -> 1, 72 -> 39, 73 -> 52, 74 -> 56, 75 -> 23,
76 -> 76, 77 -> 56, 78 -> 78};
image = {{1, 0, 0, 0, 0}, {0, 1, 0, 0, 0}};
GraphPlot[trans, DirectedEdges -> True, VertexLabeling -> True,
VertexRenderingFunction -> (Inset[
ArrayPlot[image, ImageSize -> 15, Mesh -> True], #1] &)]

发布于 2012-01-19 23:42:49
编辑我重新开始,基于你给出的例子
使用您的trans和image,您可以尝试:
p = ArrayPlot[image, ImageSize -> 35, Mesh -> True];
Graph[trans, DirectedEdges -> True, VertexLabels -> Placed[p, Tooltip],
ImagePadding -> 10, ImageSize -> 500]当您将鼠标悬停在每个顶点上时,这些图像将显示在工具提示中。如果愿意,您可以为不同的顶点标签使用不同的图像;只需使用规则列表即可。
下图显示了它的外观(没有工具提示)。单击link查看它是如何使用工具提示的。

https://stackoverflow.com/questions/8926071
复制相似问题