我是FE,也是Fe

前端来源于不断的点滴积累。我一直在努力。

统计

留言簿(15)

阅读排行榜

评论排行榜

基于raphaeljs的web图实现-rgraph2

xRelation by RGraph2

RGraph2

RGraph是一个基于Raphaeljs完整的点->线图的web实现。

online demo :RGraph2 Demo

github地址 :

git clone https://github.com/hafeyang/rgraph2.git

RGraph2已经支持bower包规范,可以直接使用bower安装

bower install rgraph2

由于Raphaeljs目前不支持bower规范,所以没有引入Raphaeljs依赖

RGraph包含特性:

  • 点->线图布局算法(2.0新增)
  • 基本画布拖拽
  • 点拖动,鼠标hover高亮相关点
  • 支持放大/缩小/鼠标滚轮事件
  • 提供API增/删/改节点

Quick Demo

<script type="text/javascript" src="https://raw.github.com/hafeyang/rgraph2/master/lib/raphael-min.js"></script>
<script type="text/javascript" src="https://raw.github.com/hafeyang/rgraph2/master/lib/rgraph2.js"></script>
<script type="text/javascript">
var graph = new RGraph("canvas");
//加载数据
graph.loadData({
nodes:{
//label:显示文字,支持Raphael.fullfill格式。
//rectStyle,textStyle 文本框的颜色,文字颜色
"1":{"label":"{name}",name:"节点1",rectStyle:{fill:"#616130",stroke:"#616130"},textStyle:{fill:"#fff"}},
"2":{"label":"节点2"}
},
edges:[
//source,target 是节点的ID ,箭头由source->target
//arrowStyle,指定箭头颜色
{source:"1",target:"2",label:"1->2",arrowStyle:{fill:"#ab4",stroke:"#ab4"}}
]
});
//将ID为1的节点移至视口中央
graph.center("1");
</script>

初始化参数

var graph = new RGraph("canvas",opts);

opts.drawNodeFn

绘制节点的Raphaeljs扩展方法,默认为rgraphnode,RGraph2内部默认实现,自定义节点绘制方法为:

(!Raphael.fn.rgraphnode ) && (Raphael.fn.rgraphnode=function(node){
// your implementation
return {
//移动节点时会调用该方法
move:function(dx,dy){},
//高亮节点时会调用该方法
highlight:function(){},
//清除高亮
unhighlight:function(){},
//更新节点文本
update:function(){}
}
});

具体可以参见RGraph2内部实现

opts.onnodeclick(e,node)

节点节点触发function,参数event,node

opts.onnodemouseover(e,node)

节点mouseover触发function,参数event,node

opts.onnodemouseout(e,node)

节点mouseout触发function,参数event,node

opts.nnodestartdrag(e,node)

节点开始拖拽触发function,参数event,node

opts.onnodedragging(e,node)

节点拖拽中触发function,参数event,node

opts.onnodeenddrag(e,node)

节点拖拽结束触发function,参数event,node

API

调用方法:graphInstance.method()

instance.removeNode(nodeId)

删除节点以及节点相关的线

instance.updateNode(nodeId)

更新节点文本

var node = graphInstance.getNode("nodeId");
node.label = "{name} after update";
graphInstance.updateNode(node.nodeId);

instance.getNode(nodeId)

根据节点ID获取节点对象

instance.addNode(node)

添加节点,节点必须有nodeId,label属性,rectStyle用于定义节点边框样式,样式格式详见Raphaeljs Element.attrtextStyle定义文字样式。

新增文字节点位置视口内随机。

graphInstance.addNode({nodeId:"nodeId---",label:"{nodename}",nodename:"Name"});

instance.existEdge(sourceNodeId,targetNodeId)

是否存在sourceNode与targetNode之间的线,如果有返回该Edge对象,否则返回false

instance.addEdge(edge)

添加一条线,edge必须有source,target属性箭头由source->target,label属性定义箭头上的label文字。arrowStyle定义箭头的颜色样式,格式以及可以设置的属性参见 Raphaeljs Element.attr

instance.loadData(graphData)

加载图数据,数据格式见demo

instance.relayout()

重新布局点->线位置

instance.getNodeEdges(nodeId)

根据nodeId获取节点相关的边

instane.reset()

方法倍数设置成1。视口还原。

instance.center(nodeId)

将nodeId节点移至视口中央

References

Raphaeljs

Graph JavaScript framework

Graph visualization code in javascript

JavaScript Graph Library Showcase

Knows Issues

Raphaeljs Element.getBBox方法在IE<9下获取值不正确导致IE9下不能兼容


Thanks,any questions ,contact me freely!

posted on 2012-12-11 20:08 衡锋 阅读(4458) 评论(12)  编辑  收藏 所属分类: javascriptWeb开发

评论

# re: 基于raphaeljs的web图实现-rgraph2[未登录] 2014-05-29 14:53 chris

您好,我想问下,如果我想要两个节点之间有两条连线而已不重合,应该怎么办?  回复  更多评论   

# re: 基于raphaeljs的web图实现-rgraph2 2014-05-29 17:55 衡锋

@chris
估计要在两个店之间找两个不同关键点,然后分别连线就不会重合吧。  回复  更多评论   

# re: 基于raphaeljs的web图实现-rgraph2[未登录] 2014-06-12 11:15 chris

@衡锋
多谢您!还有就是您这个画布放大然后可以拖拽画布是怎么实现的呢?  回复  更多评论   

# re: 基于raphaeljs的web图实现-rgraph2 2014-06-12 12:33 衡锋

@chris
可以看看rgraph2的源码。  回复  更多评论   

# re: 基于raphaeljs的web图实现-rgraph2[未登录] 2014-06-12 17:49 chris

@衡锋
但是有一点不明白。您的这个getViewBox获取的是什么数据?  回复  更多评论   

# re: 基于raphaeljs的web图实现-rgraph2 2014-06-13 12:35 衡锋

@chris
获取的是当前视口在整个图中的左上角偏差和宽高  回复  更多评论   

# re: 基于raphaeljs的web图实现-rgraph2[未登录] 2014-06-24 14:54 chris

又来打扰您了。我按您的方法尝试了拖动整个canvas,但是如果连续拖动的话会飘的很,您有什么方法解决吗  回复  更多评论   

# re: 基于raphaeljs的web图实现-rgraph2 2014-06-24 16:41 衡锋

@chris
这个时能用类似underscore里面的bounce或者throttle来解决了。  回复  更多评论   

# re: 基于raphaeljs的web图实现-rgraph2 2014-06-25 16:08 TIMI

请教下,我要是添加图片该怎么添加呢?我用src不管用呀!  回复  更多评论   

# re: 基于raphaeljs的web图实现-rgraph2 2014-06-25 16:51 TIMI

在您rgraph2中添加节点,要是想添加图片改怎么添加呢?我试了src属性没有效果。  回复  更多评论   

# re: 基于raphaeljs的web图实现-rgraph2 2014-06-27 12:29 衡锋

@TIMI
看Raphaeljs的文档  回复  更多评论   

# re: 基于raphaeljs的web图实现-rgraph2[未登录] 2015-08-03 18:53 aa

删除节点不好用  回复  更多评论   


只有注册用户登录后才能发表评论。


网站导航: