Posted on 2010-08-25 15:24
penngo 阅读(4253)
评论(1) 编辑 收藏 所属分类:
JBPM
jbpm流程设计器开发(1)
本篇主要实现了多个流程节点的绘制。
部分功能代码
FlowNode.xml主要配置流程节点的属性。
<?xml version="1.0" encoding="GBK" standalone="yes"?>
<flowNode>
<node height="40" width="40" type="straight" shape="shape=ellipse;perimeter=ellipsePerimeter;"
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
icon="images/straight.gif" label="直线"/>
<node height="40" width="40" type="start" shape="shape=ellipse;perimeter=ellipsePerimeter;" icon="images/start.gif"
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
label="开始"/>
<node height="40" width="40" type="end" shape="shape=doubleEllipse;perimeter=ellipsePerimeter;" icon="images/end.gif"
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
label="结束"/>
<node height="40" width="80" type="state" shape="rounded=1;" icon="images/state.gif" label="状态"/>
<node height="40" width="80" type="task" shape="rounded=1;" icon="images/task.gif" label="任务"/>
<node height="40" width="40" type="decision" shape="shape=rhombus;perimeter=rhombusPerimeter;"
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
icon="images/decision.gif" label="判断"/>
<node height="40" width="40" type="fork" shape="shape=rhombus;perimeter=rhombusPerimeter;" icon="images/fork.gif"
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
label="分支"/>
<node height="40" width="40" type="join" shape="shape=rhombus;perimeter=rhombusPerimeter;" icon="images/join.gif"
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
label="合并"/>
</flowNode>
LeftPanel.java主要显示流程节点列表
package com.workflow.designer.view;
import java.awt.Color;
import java.awt.Component;
import java.awt.Desktop;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.io.File;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import javax.swing.DefaultListModel;
import javax.swing.Icon;
import javax.swing.ImageIcon;
import javax.swing.JLabel;
import javax.swing.JList;
import javax.swing.JPanel;
import javax.swing.ListCellRenderer;
import javax.swing.filechooser.FileSystemView;
import javax.xml.bind.JAXBContext;
import javax.xml.bind.Unmarshaller;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import com.mxgraph.view.mxGraph;
import com.workflow.designer.model.FlowNode;
import com.workflow.designer.model.Node;
import com.workflow.designer.util.Logger;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class LeftPanel extends JList
{
//private JList list = null;
private GraphImpl graph = null;
private DefaultListModel listModel = null;
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public LeftPanel()
{
init();
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public DefaultListModel getListModel()
{
return listModel;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setListModel(DefaultListModel listModel)
{
this.listModel = listModel;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private void init()
{
listModel = new DefaultListModel();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
//JList数据初始化
JAXBContext jc = JAXBContext.newInstance("com.workflow.designer.model");
Unmarshaller u = jc.createUnmarshaller();
FlowNode fn = (FlowNode) u
.unmarshal(FlowNode.class.getClassLoader().getResourceAsStream("com/workflow/designer/model/FlowNode.xml"));
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for(Node n:fn.getNode())
{
listModel.addElement(n);
}
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
catch(Exception e)
{
e.printStackTrace();
}
this.setModel(listModel);
this.setCellRenderer(new MyCellRenderer());
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
this.addMouseListener(new MouseAdapter()
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void mouseClicked(MouseEvent e)
{
super.mouseClicked(e);
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void mousePressed(MouseEvent e)
{
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
super.mousePressed(e);
}
});
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
class MyCellRenderer extends JLabel implements ListCellRenderer
{
public Component getListCellRendererComponent(JList list,
Object value,
int index,
boolean isSelected,
boolean cellHasFocus)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (value instanceof Node)
{
Node n = (Node) value;
Icon icon = new ImageIcon(getClass().getClassLoader().getResource(n.getIcon()));
setIcon(icon);
}
String s = value.toString();
setText(s);
this.setToolTipText(s);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (isSelected)
{
setBackground(list.getSelectionBackground());
setForeground(list.getSelectionForeground());
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
setBackground(Color.WHITE);
setForeground(list.getForeground());
}
setEnabled(list.isEnabled());
setOpaque(true);
return this;
}
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setGraph(GraphImpl gi)
{
this.graph = gi;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public static void main(String arg[])
{
new LeftPanel();
}
}
GraphView.java获取LeftPanel中被选中的节点,并在面板上绘制该节点
package com.workflow.designer.view;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import java.awt.Point;
import java.awt.event.MouseEvent;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import com.mxgraph.model.mxCell;
import com.mxgraph.view.mxGraph;
import com.workflow.designer.model.Node;
import com.workflow.designer.util.Logger;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class GraphView extends GraphImpl
{
private mxGraph graph = this.getGraph();
private Object parent = graph.getDefaultParent();
private LeftPanel lp = null;
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public GraphView(LeftPanel lp)
{
this.lp = lp;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void inser(Point p, Node n)
{
this.getGraph().getModel().beginUpdate();
try
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
//调用jgraph插入节点
Object v1 = graph.insertVertex(parent, null, n.getLabel(), p.getX() - 5, p.getY() - 5,
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
n.getWidth(),
n.getHeight(), n.getShape());
((mxCell)v1).setConnectable(false);
}
finally
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
graph.getModel().endUpdate();
}
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void mouseClicked(MouseEvent e)
{
//获取被选中节点
Object obj = lp.getSelectedValue();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(obj instanceof Node)
{
Node n = (Node)obj;
Point p = e.getPoint();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(!n.getType().equals("straight"))
{
//鼠标点击时,在jgraph面板上插入节点
inser(p, n);
lp.clearSelection();
}
}
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void mousePressed(MouseEvent e)
{
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void mouseReleased(MouseEvent e)
{
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void mouseEntered(MouseEvent e)
{
//只有在线条节点被选中时,才能绘制连接线
Object obj = lp.getSelectedValue();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(obj instanceof Node)
{
Node n = (Node)obj;
Object parent = graph.getDefaultParent();
Object childs[] = graph.getChildCells(parent);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(n.getType().equals("straight"))
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for(Object cell:childs)
{
((mxCell)cell).setConnectable(true); //设置可连线
}
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
else
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for(Object cell:childs)
{
((mxCell)cell).setConnectable(false);
}
}
}
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void mouseExited(MouseEvent e)
{
}
}
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
绘制的流程图
现在已经基本实现流程的绘制了,下一篇将会介绍流程定义文件保存打开。
源码:
源码
打包jar:
jgraphxflow.jar