如鹏网 大学生计算机学习社区

CowNew开源团队

http://www.cownew.com 邮件请联系 about521 at 163.com

  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  363 随笔 :: 2 文章 :: 808 评论 :: 0 Trackbacks
 

已经可以比较好的运行JBPM了,但是如果能以图形化的方式显示工作流,并且把当前节点高亮显示,这样可用性就更好了,用户可以很轻松的看到当前流程到哪个节点了。

       我发现JBPMstarters-kit的例子中就有类似的效果,所以决定分析一下它是怎么实现的。

       打开网页,浏览到有显示当前工作流节点的页面,查看到此页面的地址为task.jsp,发现其中的核心代码如下:

<jbpm:processimage task="${taskBean.taskInstanceId}"/>

       这里使用了JBPM提供的jbpm:processimage标签,此标签定义在jbpm.tld中,这个Tag的类为org.jbpm.webapp.tag.ProcessImageTag。所以只要使用这个标签我们就可以很轻松的在Web页面中显示图形化的工作流了。

       那么如果是在SwingSWT等非Web界面中也想显示这种效果怎么办呢?那么让我们来分析一下ProcessImageTag类。

 private void retrieveByteArrays() {

    try {

      FileDefinition fileDefinition = processDefinition.getFileDefinition();

      gpdBytes = fileDefinition.getBytes("gpd.xml");

      imageBytes = fileDefinition.getBytes("processimage.jpg");

    } catch (Exception e) {

      e.printStackTrace();

    }

 }

       gpd.xml中记录的是节点的位置关系,processimage.jpg是图形化的图片(只是基图,没有高亮显示当前节点),这两个文件是JBPMEclipse插件自动生成的。

       得到流程实例当前节点的方法:

 private void initialize() {

    JbpmContext jbpmContext = JbpmContext.getCurrentJbpmContext();

    if (this.taskInstanceId > 0) {

           TaskInstance taskInstance = jbpmContext.getTaskMgmtSession().loadTaskInstance(taskInstanceId);

           currentToken = taskInstance.getToken();

    }

    else

    {

           if (this.tokenInstanceId > 0)

                  currentToken = jbpmContext.getGraphSession().loadToken(this.tokenInstanceId);

    }

    processDefinition = currentToken.getProcessInstance().getProcessDefinition();

 }

       currentToken中可以得到当前节点在显示的时候的长度、宽度、横纵坐标等值。得到的方式如下:

 private int[] extractBoxConstraint(Element root) {

    int[] result = new int[4];

    String nodeName = currentToken.getNode().getName();

    XPath xPath = new DefaultXPath("//node[@name='" + nodeName + "']");

    Element node = (Element) xPath.selectSingleNode(root);

    result[0] = Integer.valueOf(node.attribute("x").getValue()).intValue();

    result[1] = Integer.valueOf(node.attribute("y").getValue()).intValue();

    result[2] = Integer.valueOf(node.attribute("width").getValue()).intValue();

    result[3] = Integer.valueOf(node.attribute("height").getValue()).intValue();

    return result;

 }

       这样用<div/>标签就可以将当前节点框上一个红色的框框了:

           jspOut.println("<div style='position:relative; background-image:url(" + imageLink + "); width: " + imageDimension[0] + "px; height: " + imageDimension[1] + "px;'>");

       //详细代码参考:writeTable方法

原来高亮显示是在原有的图片上叠加一个高亮的框框实现的。所以如果要显示在SwingSWT中的话也只要参考这个思路,在当前节点位置显示一个高亮的框框就可以了!

posted on 2007-11-19 17:44 CowNew开源团队 阅读(6038) 评论(8)  编辑  收藏

评论

# re: 以图形化的方式显示JBPM当前流程的方法及原理分析 2007-11-20 09:30 专注JAVA开源
以前做过一个基于xpdl的流程监控的程序  回复  更多评论
  

# re: 以图形化的方式显示JBPM当前流程的方法及原理分析[未登录] 2008-11-13 10:04 Simple
JBPM可以与Ibatis结合吗?  回复  更多评论
  

# re: 以图形化的方式显示JBPM当前流程的方法及原理分析 2008-11-15 13:32 漠漠
@Simple
可以,使用同一个数据源!  回复  更多评论
  

# re: 以图形化的方式显示JBPM当前流程的方法及原理分析[未登录] 2008-11-24 16:19 Simple
可不可以发个Demo我参考一下~~   回复  更多评论
  

# re: 以图形化的方式显示JBPM当前流程的方法及原理分析 2009-06-01 09:46 不毛之地
太强了,正是我想要的  回复  更多评论
  

# re: 以图形化的方式显示JBPM当前流程的方法及原理分析 2009-06-26 10:49 鱼中鱼
但是在private void retrieveByteArrays() {
try {
FileDefinition fileDefinition = processDefinition.getFileDefinition();
gpdBytes = fileDefinition.getBytes("gpd.xml");
//gpdBytes = fileDefinition.getBytes("com/flowdemo/jbpm/expense/gpd.xml");
imageBytes = fileDefinition.getBytes("processimage.jpg");
//imageBytes = fileDefinition.getBytes("com/flowdemo/jbpm/expense/processimage.jpg");
} catch (Exception e) {
e.printStackTrace();
}
}
gpdBytes = fileDefinition.getBytes("gpd.xml");这一句的时候发生异常了,出现空指针是怎么回事呢?请赐教,谢谢。
  回复  更多评论
  

# re: 以图形化的方式显示JBPM当前流程的方法及原理分析 2009-08-29 08:22 zw
@鱼中鱼

zw7534313@163.com 咋解决的?
  回复  更多评论
  

# re: 以图形化的方式显示JBPM当前流程的方法及原理分析 2010-05-29 12:21 小邓子
在private void retrieveByteArrays() {
try {
FileDefinition fileDefinition = processDefinition.getFileDefinition();
gpdBytes = fileDefinition.getBytes("gpd.xml");
//gpdBytes = fileDefinition.getBytes("com/flowdemo/jbpm/expense/gpd.xml");
imageBytes = fileDefinition.getBytes("processimage.jpg");
//imageBytes = fileDefinition.getBytes("com/flowdemo/jbpm/expense/processimage.jpg");
} catch (Exception e) {
e.printStackTrace();
}
}
gpdBytes = fileDefinition.getBytes("gpd.xml");这一句的时候发生异常了,出现空指针是怎么回事呢?请赐教,谢谢。
邮箱:djx@kingtopinfo.com 希望得到回复!  回复  更多评论
  


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


网站导航: