JBPM在线流程设计器的分析与实现部分构想

在发表文章之前,先写一下博客声明,由于JE限制了本人的发贴功能,所以大家回复的内容本人现在没有办法在线回复各位,望见谅。需要技术交流的请加我Q:1165655130。

 

     最近JBPM比较火,很多同行也跟我探讨如何使用这个东西完成企业应用中的流程问题,本人也谈谈对Jbpm4的理解,JBPM在实现流程上应该没有什么问题,但是由于其客户端的可视化相对薄弱,如设计器不够人性化,流程表单也不方便,所以客户要设计企业内的业务流程就会遇到问题,毕竟大部分的客户都不是开发人员。

 

     尽管JBPM的客户化相对薄弱,但是它比较轻巧,相对其他商业的工作流引擎,部署及开发都是相当方便,这使得连IBM有些系统都采用JBPM来开发。JOffice中也在努力提升的JBPM的易用性,提供一些可视化的在线流程设计器及表单设计器。

 

     大家都知道Jbpm有一个eclipse的plugin可以完成流程的设计开发,但是那个东西却没有提供在线的设计器,而JBPM也提供一个在线的设计器(Signavio),其是基于SVG来进行画图的,可惜ie目前的版本却不支持SVG。Flex应该是个不错的流程设计器的做法,不过目前的版本对图形的支持相对差一些,Flex3也有一个不错的流程框架如degrafa,可惜文档及例子不多,使用起来也相当困难。Flex4还在期待。而JavaFx初看却不错,但是感觉不如直接用JAVA写,用JAVA写要在浏览器中使用,就离不开Applet了。

      而画流程图最好还是有一个框架,记得在C++下完成一个简单的画板功能,完全自己写,也是费很多功夫。用现成的框架,却可以省很多功夫。开源的JAVA画图框架可以省去我们的功夫呢,如:JUNG,JHotDraw,他们的画图及编辑图形的功能已经很强,不需要再写大量的代码去实现,并且提供在线的Applet演示,同时文档也比较丰富。

 

用了类似的图形画图框架后,可以让他们生成对应自己程序的XML文件后,就可以与JBPM的XML文件作一个相互转换则可。最终的目的就是转换成JBPM所认识的流程定义,同时可以比较容易恢复流程的定义图形的显示。

 

(在线演示地址:http://joffice.jee-soft.cn user:csx,pwd:111)

如在JOffice 1.3中,在线定义一个公文撰稿的流程,如下所示:

 

JBPM在线流程设计器的分析与实现部分构想

 

以上画图会有不同的画图属性,因而会生成一个画图对应的文件存储内容,如字体大小、颜色等,其最终生成以下文件:

 

<drawing id="0">
	<figures>
		<start id="1" x="151" y="8" w="48" h="48" name="&#x5f00;&#x59cb;">
			<a>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</start>
		<end id="2" x="492" y="423" w="48" h="48" name="&#x7ed3;&#x675f;1">
			<a>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</end>
		<task id="3" name="&#x516c;&#x6587;&#x62df;&#x7a3f;" x="123" y="107"
			w="101" h="39">
			<a>
				<text>
					<string>&#x516c;&#x6587;&#x62df;&#x7a3f;</string>
				</text>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</task>
		<transition id="4" g="-24,-16" name="&#x51c6;&#x5907;">
			<points>
				<p colinear="true" x="174.6095238095238" y="56.6" c1x="0" c1y="0"
					c2x="0" c2y="0" />
				<p colinear="true" x="173.81904761904764" y="106.4" c1x="0" c1y="0"
					c2x="0" c2y="0" />
			</points>
			<startConnector>
				<rConnector id="5">
					<Owner>
						<start ref="1" />
					</Owner>
				</rConnector>
			</startConnector>
			<endConnector>
				<rConnector id="6">
					<Owner>
						<task ref="3" />
					</Owner>
				</rConnector>
			</endConnector>
			<a>
				<endDecoration>
					<arrowTip id="7" angle="0.35" innerRadius="11.3"
						outerRadius="12" isFilled="true" isStroked="false" isSolid="true" />
				</endDecoration>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</transition>
		<fork id="8" x="150" y="204" w="48" h="48"
			name="&#x540c;&#x6b65;&#x4efb;&#x52a1;">
			<a>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</fork>
		<transition id="9" g="-24,-16" name="&#x540c;&#x6b65;">
			<points>
				<p colinear="true" x="173.5990147783251" y="146.60000000000002"
					c1x="0" c1y="0" c2x="0" c2y="0" />
				<p colinear="true" x="173.87881773399016" y="203.4" c1x="0" c1y="0"
					c2x="0" c2y="0" />
			</points>
			<startConnector>
				<rConnector id="a">
					<Owner>
						<task ref="3" />
					</Owner>
				</rConnector>
			</startConnector>
			<endConnector>
				<rConnector id="b">
					<Owner>
						<fork ref="8" />
					</Owner>
				</rConnector>
			</endConnector>
			<a>
				<endDecoration>
					<arrowTip ref="7" />
				</endDecoration>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</transition>
		<task id="c" name="&#x5ba1;&#x6838;" x="301" y="166" w="108" h="41">
			<a>
				<text>
					<string>&#x5ba1;&#x6838;</string>
				</text>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</task>
		<task id="d" name="&#x5370;&#x7ae0;&#x51c6;&#x5907;" x="305" y="282"
			w="111" h="42">
			<a>
				<text>
					<string>&#x5370;&#x7ae0;&#x51c6;&#x5907;</string>
				</text>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</task>
		<transition id="e" g="-24,-16" name="&#x4efb;&#x52a1;">
			<points>
				<p colinear="true" x="198.60000000000002" y="222.3596685082873"
					c1x="0" c1y="0" c2x="0" c2y="0" />
				<p colinear="true" x="300.4" y="199.01878453038674" c1x="0" c1y="0"
					c2x="0" c2y="0" />
			</points>
			<startConnector>
				<rConnector id="f">
					<Owner>
						<fork ref="8" />
					</Owner>
				</rConnector>
			</startConnector>
			<endConnector>
				<rConnector id="10">
					<Owner>
						<task ref="c" />
					</Owner>
				</rConnector>
			</endConnector>
			<a>
				<endDecoration>
					<arrowTip ref="7" />
				</endDecoration>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</transition>
		<transition id="11" g="-24,-16" name="&#x51c6;&#x5907;">
			<points>
				<p colinear="true" x="198.60000000000002" y="237.89276139410188"
					c1x="0" c1y="0" c2x="0" c2y="0" />
				<p colinear="true" x="306.78799999999995" y="281.4" c1x="0" c1y="0"
					c2x="0" c2y="0" />
			</points>
			<startConnector>
				<rConnector id="12">
					<Owner>
						<fork ref="8" />
					</Owner>
				</rConnector>
			</startConnector>
			<endConnector>
				<rConnector id="13">
					<Owner>
						<task ref="d" />
					</Owner>
				</rConnector>
			</endConnector>
			<a>
				<endDecoration>
					<arrowTip ref="7" />
				</endDecoration>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</transition>
		<join id="14" x="488" y="209" w="48" h="48"
			name="&#x6c47;&#x96c6;&#x4efb;&#x52a1;">
			<a>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</join>
		<transition id="15" g="-24,-16" name="&#x63d0;&#x4ea4;">
			<points>
				<p colinear="true" x="409.59999999999997" y="202.67133757961784"
					c1x="0" c1y="0" c2x="0" c2y="0" />
				<p colinear="true" x="487.4" y="225.7140127388535" c1x="0" c1y="0"
					c2x="0" c2y="0" />
			</points>
			<startConnector>
				<rConnector id="16">
					<Owner>
						<task ref="c" />
					</Owner>
				</rConnector>
			</startConnector>
			<endConnector>
				<rConnector id="17">
					<Owner>
						<join ref="14" />
					</Owner>
				</rConnector>
			</endConnector>
			<a>
				<endDecoration>
					<arrowTip ref="7" />
				</endDecoration>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</transition>
		<transition id="18" g="-24,-16" name="&#x63d0;&#x4ea4;">
			<points>
				<p colinear="true" x="407.2485714285714" y="281.4" c1x="0" c1y="0"
					c2x="0" c2y="0" />
				<p colinear="true" x="487.4" y="244.36633663366337" c1x="0" c1y="0"
					c2x="0" c2y="0" />
			</points>
			<startConnector>
				<rConnector id="19">
					<Owner>
						<task ref="d" />
					</Owner>
				</rConnector>
			</startConnector>
			<endConnector>
				<rConnector id="1a">
					<Owner>
						<join ref="14" />
					</Owner>
				</rConnector>
			</endConnector>
			<a>
				<endDecoration>
					<arrowTip ref="7" />
				</endDecoration>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</transition>
		<task id="1b" name="&#x5b9a;&#x7a3f;" x="456" y="327" w="119" h="45">
			<a>
				<text>
					<string>&#x5b9a;&#x7a3f;</string>
				</text>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</task>
		<transition id="1c" g="-24,-16" name="&#x63d0;&#x4ea4;">
			<points>
				<p colinear="true" x="512.7390557939914" y="257.6" c1x="0" c1y="0"
					c2x="0" c2y="0" />
				<p colinear="true" x="514.806008583691" y="326.4" c1x="0" c1y="0"
					c2x="0" c2y="0" />
			</points>
			<startConnector>
				<rConnector id="1d">
					<Owner>
						<join ref="14" />
					</Owner>
				</rConnector>
			</startConnector>
			<endConnector>
				<rConnector id="1e">
					<Owner>
						<task ref="1b" />
					</Owner>
				</rConnector>
			</endConnector>
			<a>
				<endDecoration>
					<arrowTip ref="7" />
				</endDecoration>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</transition>
		<transition id="1f" g="-24,-16" name="1">
			<points>
				<p colinear="true" x="515.6184615384616" y="372.59999999999997"
					c1x="0" c1y="0" c2x="0" c2y="0" />
				<p colinear="true" x="515.8738461538461" y="422.4" c1x="0" c1y="0"
					c2x="0" c2y="0" />
			</points>
			<startConnector>
				<rConnector id="20">
					<Owner>
						<task ref="1b" />
					</Owner>
				</rConnector>
			</startConnector>
			<endConnector>
				<rConnector id="21">
					<Owner>
						<end ref="2" />
					</Owner>
				</rConnector>
			</endConnector>
			<a>
				<endDecoration>
					<arrowTip ref="7" />
				</endDecoration>
				<strokeColor>
					<color rgba="#ff000000" />
				</strokeColor>
			</a>
		</transition>
	</figures>
</drawing>
 

 

转为jbpm的定义为:

 

<?xml version="1.0" encoding="GBK"?>
<process xmlns="http://jbpm.org/4.0/jpdl" name="pd7250331474571141836">
	<start name="开始" g="151,8,58,58">
		<transition name="准备" to="公文拟稿" g="-24,-16" />
	</start>
	<end name="结束1" g="492,423,58,58" />
	<task name="公文拟稿" g="123,107,111,49">
		<transition name="同步" to="同步任务" g="-24,-16" />
	</task>
	<fork name="同步任务" g="150,204,58,58">
		<transition name="准备" to="印章准备" g="-24,-16" />
		<transition name="任务" to="审核" g="-24,-16" />
	</fork>
	<task name="审核" g="301,166,118,51">
		<transition name="提交" to="汇集任务" g="-24,-16" />
	</task>
	<task name="印章准备" g="305,282,121,52">
		<transition name="提交" to="汇集任务" g="-24,-16" />
	</task>
	<join name="汇集任务" g="488,209,58,58">
		<transition name="提交" to="定稿" g="-24,-16" />
	</join>
	<task name="定稿" g="456,327,129,55">
		<transition name="1" to="结束1" g="-24,-16" />
	</task>
</process>

 

 

相对来说,画图需要存储的内容比较多, jbpm却只是关心流程,在界面恢复图形,仅需要使用流程画图的xml,而流程发布则仅需要使用生成的Jbpm流程定义。

 

而流程在线表单功能目前已经提供了模板及可视化的设计,不过可视化的设计还是相对弱一些,强大的流程表单设计功能将会在后续的版本提供。如将提供表单的自定义功能,并且可以动态生成表单对应的表,提供方便的查询及权限控制显示等功能。

 

你可能感兴趣的:(框架,浏览器,jbpm,Flex,企业应用)