11

在网页上,我想动态呈现非常基本的流程图,即几个由线条连接的框。理想情况下,然后用户可以单击其中一个框(DIVs?)并被带到不同的页面。诉诸 Flash 似乎有点矫枉过正。是否有人知道任何客户端(即server agnostic)Javascript 或CSS library/technique可能有助于实现这一目标?

4

3 回答 3

2

渲染必须是客户端吗?

如果是,您可以尝试处理:

http://ejohn.org/blog/processingjs/

如果你可以在服务器端做,那么 Graphviz 是一个不错的选择。

http://www.graphviz.org/

于 2008-08-26T09:59:23.640 回答
2

我发现的最好和最简单的是js-graph.it

它还有一个有用的特性:决定流的方向。例如,在我的情况下,我有一个文档工作流程,所以我需要它向右侧流动。

一个更简单的替代方案是wz_jsGraphics。在我的例子中,我画出这样的箭头:

/**Draw an arrow made of 3 lines. 
 * Requires wz_jsGraphics (http://www.walterzorn.de/en/jsgraphics/jsgraphics_e.htm).
 * @canvas a jsGraphics object used as canvas
 * @blockFrom id of the object from which the arrow starts
 * @blockTo id of the object where the arrow ends with a arrowhead 
 */
function drawArrow(canvas, blockFrom, blockTo){

    //blocks
    var f = $("#" + blockFrom);
    var t = $("#" + blockTo);

    //lines positions and measures
    var p1 = { left: f.position().left + f.outerWidth(),    top: f.position().top + f.outerHeight()/2 };
    var p4 = { left: t.position().left,                     top: t.position().top + t.outerHeight()/2 };
    var mediumX = Math.abs(p4.left - p1.left)/2;
    var p2 = { left: p1.left + mediumX,                 top: p1.top };
    var p3 = { left: p1.left + mediumX,                 top: p4.top };

    //line A
    canvas.drawLine(p1.left, p1.top,    p2.left, p2.top);
    //line B
    canvas.drawLine(p2.left, p2.top,    p3.left, p3.top);
    //line C
    canvas.drawLine(p3.left, p3.top,    p4.left, p4.top);
    //arrowhead
    canvas.drawLine(p4.left - 7, p4.top - 4,        p4.left, p4.top);
    canvas.drawLine(p4.left - 7, p4.top + 4,        p4.left, p4.top);
}

var jg = new jsGraphics('myCanvasDiv');
drawArrow(jg, 'myFirstBlock', 'mySecondBlock');
jg.paint(); 
于 2013-06-05T08:44:51.953 回答
1

这种流程图可以使用 CSS 完成,诉诸 JavaScript 图形库(画布)可能是矫枉过正。您可能希望查看一些家谱网站如何做到这一点以获得家谱。

于 2008-08-26T11:03:59.867 回答