快速绘制流程图
绘制流程图是很常见的任务。这种小事却困扰了我很久,不管是在线的、APP、代码形式如 flow 等等,总是特别麻烦,而我对这样的小事又极其没耐心。今天终于用 OmniGraffle 解决了这个痛点。
Why not
- 线上:需要网络,并且功能比较弱;速度慢
- 其他 APP:功能比较弱;速度慢
- 代码:线条的走向不可控
准备
- OmniGraffle:Mac 绘图必备
- 一份流程图的模板
流程图模板
这份模板我们需要自己制作,只需要绘制一次,永远都可以用,制作完之后是这样的:
红色的椭圆是代表流程图开始的那个节点。当然,作为一个超强的绘图 APP,自动化功能当然是必不可少的。OmniGraffle 提供了 API,根据 API 我们可以操纵 OmniGraffle 进行绘图。
当然,我知道你很懒,手动画这么一个图太麻烦了,所以我给你代码了 :P
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50console.clear();
canvas = document.windows[0].selection.canvas;
canvas.name = "流程图模板"
canvas.layers[0].name = "基础节点"
canvas.newLayer().name = "连线"
canvas.newLayer().name = "文字"
// 长方形的长和宽
var length = 140;
var width = 50;
//2个图形的上下距离
var x_distance = 140;
var y_distance = 70;
var magnets = [ // 磁极
new Point(0.0, 1.0),
new Point(0.0, -0.5),
new Point(1.0, 0.0),
new Point(-1.0, 0.0)
]
// 绘制多个图形
for (var x=0; x < 13; x++) // 这里的 5 是列数
{
for (var y=0; y < 30; y++) // 这里的 5 是行数
{
attribute = new Rect(
x*(length+x_distance),
y*(width+y_distance),
length,
width
); // 新建一个长方形
if(x==6 && y==0) // 如果是中间的那个就新建一个椭圆形
{
the_new = canvas.addShape("RoundRect", attribute)
the_new.fillColor = Color.red
}
else // 新建一个长方形
the_new = canvas.addShape("Rectangle", attribute);
the_new.shadowColor = null // 清除图形的阴影
the_new.strokeThickness = 3 // 框的厚度设为 3 点
the_new.magnets = magnets // 设置上下左右四个磁极
}
}
代码怎么运行呢?在菜单里点击 自动化
,点击 显示控制台
然后把代码粘贴进入,回车即可运行。
接下来说一下手动绘制的步骤,其实很简单,不过你要是不关心的话,可以直接跳过:
- 先整理一下图层,将第一个图层命名为 “基础格”,名字随意,自己知道是啥就好:
这一层图层用于存放基础的节点 - 右键再新建 2 个图层,命名自定,分别用于存放连接线与连接线的文字:
结果类似这样:
- 选中基础格,我们在里面绘制节点,数量随意,够用就行,我一共画了 390 个节点,够我用了。然后点击形状工具开始绘制节点:
至于大小,我选择的是140*50
,这个自定,能适应多种字数就行,不要太长不要太宽。
- 按住 option,点击第一个节点,拖动即可复制
- 由于 OmniGraffle 提供了完美拖动时的对齐提示,所以我们很容易就能把这两个节点对齐
至于两个节点相差多远,自定,上下我选择70
个像素点
差不多就行。 - 同理,我们可以复制出 n 个一样的节点:
拖动的时候会有相同距离提示,真的是太友好了。然后我们可以一次性选中 2 个,再重复之前的复制过程,并使它们与之前的节点距离相同
- 然后如法炮制列,左右距离我选择
140
像素
然后我们把字消除一下:
1
2
3
4graphics = document.windows[0].selection.canvas.graphics
graphics.forEach(function(graphic, index){
graphic.text = ""
})
回车运行后字就没了。
然后为了方便找到中间的那个节点作为流程图的起始节点,我们把它的弄成红色的椭圆。最后为了方便我们连线,ctrl+a 后,将所有的节点设置为 4 个磁极
这样模板就绘制好了。
使用模板
使用就很简单了,首先点选 “连线” 这个图层,这样后续的连线都会自动放进去。直接使用线条工具将所需要的节点连接在一起。注意,点击一下只能使用一次线条工具,双击后就可以持续使用。由于有磁极的存在,连接是很快的:
连接完之后,再将形状修改为正确的形状:
然后我们在第一个节点右击,选择所有被使用的对象:
这样被我们使用的节点就都选中了,然后我们再右击,选择:
然后就能将这些节点放入一个新的图层:
然后我们点击图层上的眼镜就可以把基础节点给隐藏起来:
结果如下:
如果文字太多溢出节点的话,需要调整一下节点的大小。
剩下的就是加上文字,点选 “文字” 这个图层,然后加上文字即可
一些小技巧
文字在连线上的位置
加文字的时候注意把光标放在田字格上:
这样文字位置在中间,好看一些。或者可以通过 几何形状
来调:
文字过多溢出节点
如:
首先留出足够的空间给节点放大:
然后点击需要调整的节点,再点击这个,使得图形自动扩大适应文字:
结果如下:
接下来选中这三个,进行水平对齐:
结果如下:
然后调整连线长度就行了。
其实如果你提前发现了某个节点文字会比较多,完全可以在连线的时候跨几个节点,然后把连线穿过的节点删掉,这样就会留很多的空白地方用于调整。
- By:tr0y.wang
推荐站内搜索:最好用的开发软件、免费开源系统、渗透测试工具云盘下载、最新渗透测试资料、最新黑客工具下载……
还没有评论,来说两句吧...