版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、浅析oa流程的可视化方法摘 要工作流是指整个或部分业务流程在计算机支持下的全自动或半自动化。在计算机网络环境下,工作任务在多个人或单位之间的流转实际上将表现为信息或数据在多个人之间的传送。使用可视化的oa工作流设计工具,用户不需要编程就可以定义设计出满足要求的收发文流程,实际使用效果良好。论文以可视化的oa工作流设计工具的开发为基础,主要阐述五个方面的内容。第一部分介绍了工作流和工作流设计工具的相关概念与开发背景;第二部分对工作相关基础理论技术、系统环境与平台基础、以及开发技术进行了描述;第三部分对系统功能进行了分析;第四部分详细介绍了系统流程、流程可视化设计的实际开发过程中使用到的关键技术;
2、最后一部分在总结了系统开发心得的同时,提出了目前系统存在的不足和有待改进的地方。关键词:工作流;流程定义;可视化;java applet the research and implementation of visual oa workflow based on b/s structureabstractworkflow is a full automation or semi-automation on business process, which is supported by the computer technology. in the distributed environment
3、, tasks transferred among different persons and departments are information or data passed among participants according to the defined set of rules. using visual oa workflow designing tools, users can define and design receiving and ending document workflow without programming. the actual result is
4、very satisfactory. this paper is based on the development of visual oa workflow designing tools. and it consists of five parts. the first part introduces the workflows, the related concepts and the developing background of the tools designing it. the second surveys the work-related theory and develo
5、ping technology. the third one carries on the analysis of the system functions. the fourth deals with following parts in detail: the system flow, the system environment and the essential technology of designing for the platform foundation and the visible flow in the actual developing performance. th
6、e last part is summarized the attainment of system-developing. and at the same time, the insufficiency and the improvements are also included in this part.key words: workflow;flow define;visual;java applet目 录论文总页数:30页1 引言11.1 课题背景11.2 技术可行性研究11.2.1 java applet技术的可行性研究11.2.2 xml技术的可行性研究11.2.3 microso
7、ft office access 2003数据库的可行性研究12 相关基础理论技术以及开发技术12.1工作流的定义与存在问题描述22.1.1 oa中工作流的定义22.1.2工作流中的流程定义问题32.2 java applet和applet绘图技术的介绍32.2.1 applet的介绍32.2.2 applet的awt绘制42.3系统环境与平台基础53 系统需求分析与总体设计53.1系统需求分析53.2 系统功能介绍53.3 系统模块功能和设计思想63.4数据库设计73.4.1 e-r图设计73.4.2 表的构建83.4.3 数据库连接实现94 系统功能模块实现94.2流程可视化设计实现104
8、.2.1界面可视化104.2.2 绘图功能设计114.2.3 流程图保存和读取方法设计174.2.4 节点间关系保存的实现235 系统测试结果及存在的问题和改进的方案27结 论28参考文献281 引言1.1 课题背景办公自动化(oa-office automation)是将现代化办公和计算机网络功能结合起来的一种新型的办公方式,通过网络,组织机构内部的人员可跨越时间、地点协同工作。oa中涉及到诸多业务流程,流程的定义对与oa系统中业务的自动流转具有十分重要的意义,但是在一般b/s模式下的oa系统,对于流程的定义都是文字型或者表单形式的,而不是图形化的,因为基于html解析的b/s在绘图方面存在
9、缺陷,因此大多b/s的oa系统在流程定义时,为了达到可视化的效果,都采用了流程定义用c/s来辅助。但是java中的applet技术可以实现在b/s下的绘图,因此,结合applet技术,可以在b/s系统中直接尝试流程的可视化定义研究。1.2 技术可行性研究在对可视化流程设计工具的研究和实现过程中一共用到了三种技术:java applet、xml、microsoft office access2003。在技术难度方面,由于有指导老师的指导和相关的参考文献,使得在开发过程中所遇到的困难都能够一一得到解决。1.2.1 java applet技术的可行性研究本系统利用java applet作为开发工具,
10、是因为成熟的java技术采用面向对象的编程方法把程序和数据封装起来作为一个对象,并为每个对象赋予相应的属性。而java applet具有能嵌入到浏览器中运行,能通过可视化技术手段实现绘图功能,能连接数据库服务器和应用服务器等这些特点,完全满足了此次b/s结构下oa流程可视化研究和实现的各种要求。1.2.2 xml技术的可行性研究“可扩展标记语言”(xml) 提供一种描述结构化数据的方法。与主要用于控制数据的显示和外观的 html 标记不同,xml 标记用于定义数据本身的结构和数据类型。利用xml技术可实现将绘制图形中的节点关系和图形信息保存在xml文件中并通过xml文件提供上层接口服务的功能。
11、1.2.3 microsoft office access 2003数据库的可行性研究系统采用microsoft office access 2003作为开发数据库,使用于中度规模的数据录入要求。它通过工具界面所提供的组件输入数据到数据库,可以使用查询设计和sql实现查询并生成报表。2 相关基础理论技术以及开发技术2.1工作流的定义与存在问题描述2.1.1 oa中工作流的定义当今社会分工越来越细,在一个单位内部也越来越强调专业化,大部分工作都需要多个部门和员工合作完成。一个制度良好的单位往往对各种工作的工作流程以文件的形式固定下来,即使是管理不太正规的单位也有约定俗成的工作步骤。这种工作流程保
12、证了一件任务能按预定的顺序从起点流向终点,并且在需要的时候可以跟踪、查询和统计。工作流(workflow)的概念是为提高工作效率的研究而产生的,目前尚无统一、明确的定义。工作流管理联盟(workflow management coalition ,wfmc)将工作流定义为:业务流程的全部或部分自动化,在此过程中,文档、信息或者任务按照一定的过程规则流转,实现组织成员间的协调工作以期达到业务的整体目标。工作流包括以下几个要素:实体(entity):是工作流的主体,是需要随着工作流一起流动的物件(object)。例如,在一个采购申请批准流程中,实体就是采购申请单;在公文审批流程中,实体就是公文。参
13、与者(participant):是各个处理步骤中的责任人,可能是人,也可能是某个职能部门,还可能是某个自动化的设备;流程定义(flow definition):是实现某工作目标而要完成的一系列步骤的描述。它包含了所有使业务过程能被工作流执行服务的必要信息。这些信息包含起始和终止条件、各个组成活动、活动调度规则、各业务的参与和需要做的工作、相关应用次序和数据的调用信息等。过程由活动和相关数据组成。流程定义工具被用来创建计算机可处理的业务过程描述。它可是形式过程定义语言或对象关系模型,也可以是简单地规定用户间信息传输的一组路由命令。在本论文中所研究的可视化流程设计工具就是一种通过java 语言实现
14、的利用图形来定义业务流程模型的一种工具。wfmc对工作流有一个简化的定义由一个四元组pt,pa,dt,ti对其进行描述:1)工作流参与者(workflow participant):定义活动的执行者,执行者可以是人和其他实体。2)工作流过程活动(workflow process activity):定义工作流活动的执行步骤,它可分为原子活动和子工作流过程。前者不可再分,后者可由原子活动和其他子工作流组成。3)工作流相关数据(workflow relevant data):定义工作流活动和应用所涉及的数据信息,它们可能包含系统和环境数据。4)跃迁信息(transition information
15、):定义工作流活动执行的依赖信息,决定活动之间的跃迁、一个活动的完成可能对其他活动的执行产生影响。下面给出一个例子,并用上面的定义的规范进行分解:pt = 拟稿人(处员)a,处室领导b,处室会签负责人c,领导d,核稿人e,打字员f,档案室gpa = 拟稿a,送审b,送核稿c,审核d,写审核意见e,送会签f,会签意见g,返回拟稿人h,写核稿意见i,送领导批示j,编号k,送打字室l,写批示意见m,返回核稿人n,排版印刷o,封发p,送档案室q,归档rdt = 文件ti = pt(i):-t pt(j)表示从一个状态到达另一个状态,t 是触发条件,这些定义和例子将是我们通过流程设计工具设计流程时的参考
16、。2.1.2工作流中的流程定义问题在一般b/s模式下的oa系统,对于流程的定义都是文字型或者表单形式的,而不是图形化的,因为基于html解析的b/s在绘图方面存在缺陷,因此大多b/s的oa系统在流程定义时,为了达到可视化的效果,都采用了流程定义用c/s来辅助。而java中的applet技术恰恰可以实现在b/s下的绘图,因此结合applet技术可以在b/s系统中直接尝试流程的可视化定义研究。如何将上一小节的工作流定义转变成b/s结构下的oa系统可以具体运行的程序?首先在数据库中设计一组表单作为状态的模板,用一xml文档来保存流程图形的状态,所有xml 文档保存在一个数据库xml表中。上层接口通过
17、读取并解释数据库中的xml文件来实现工作流程。来如何设计出有效的可视化流程设计工具是本文的重点。2.2 java applet和applet绘图技术的介绍2.2.1 applet的介绍applet是使用java语言编写,可以在浏览器环境中运行的小应用程序。它与application的区别主要在于其执行方式的不同。application 是从其中的main() 方法开始运行的,而applet 是在浏览器中运行的。首先必须创建一个html 文件,通过编写html语言代码告诉浏览器载入何种applet 以及如何运行。就因为applet能在浏览器里运行的这一特点,满足了b/s结构下的浏览器界面的需求,
18、所以我们为选择了applet作为可视化oa工作流程设计工具的开发工具。 小应用程序的生命周期相对于application而言较为复杂。在其生命周期中涉及到applet类的四个方法(也被japplet类继承):init()、start()、stop()和destroy()。applet的生命周期中有四个状态:初始态、运行态、停止态和消亡态。当程序执行完init()方法以后,applet程序就进入了初始态;然后马上执行start()方法,applet程序进入运行态;当applet程序所在的浏览器图标化或者是转入其它页面时,该applet程序马上执行stop()方法,applet程序进入停止态;在停
19、止态中,如果浏览器又重新装载该applet程序所在的页面,或者是浏览器从图标中复原,则applet程序马上调用start()方法,进入运行态;当然,在停止态时,如果浏览器关闭,则applet程序调用destroy()方法,进入消亡态。2.2.2 applet的awt绘制 applet程序中所采用的awt的绘图机制主要涉及三个方法:paint()方法、update()方法和repaint()方法,update()方法和paint()方法都有一个graphics类参数。graphics是画图的关键,它可以支持两种绘图:一种是基本的绘图,如:画线、矩形、圆等;另一种是画图象,主要用于动画制作。 要进
20、行绘图,首先要找到一个graphics类的对象。update()方法和paint()方法所传递的参数都是graphics类的对象,因此主要是通过重载它们来进行绘图,这是在动画程序中经常使用的方法。我们还可以通过getgraphics()方法得到一个graphics类的对象,这个对象和update()方法和paint()方法中所传递的对象一样,都是该成员所对应的graphics类的对象。得到了graphics类的对象,就可使用各种绘图方法。 graphics中提供的图形绘制方法有: paint( ) /进行绘图的具体操作,必须有程序员重写 update( ) /用于更新图形,先清除背景、前景,再
21、调用paint() repaint( ) /*用于重绘图形,在组件外形发生变化,即大小改变或位置移动时,repaint( )方法立即被系统自动调用,而实际上repaint()方法是自动调用update()方法*/ 下面的方法支持基本的绘图和画图像: void drawline( ) /画直线,void drawarc( ) /画弧线,void drawpolygon( ) /画多边形,void drawrect( ) /画矩形,void drawroundrect( ) /画带有圆角的矩形,void fill3drect( ) /画三维矩形,void filloval( ) /画椭圆,这些方法
22、都是来自于java.awt.graphics类 2.3系统环境与平台基础oa可视化工作流设计工具在java环境基础上,后台以microsoft office access 2003为数据库平台,前台采用具有较强跨平台性的java applet开发。具体环境描述如下:microsoft windows server 2003;microsoft office access 2003;jdk1.5.0_09;eclipse 3.1。3 系统需求分析与总体设计3.1系统需求分析在最近几年的各级单位的信息化改造建设中,随着信息化基础设施建设的逐渐完备,各类应用系统开始受到各级单位的重视,开发重点主要侧
23、重于人事信息数字化、文书信息化、公文流转、交互式审批等信息化可行性高的工作领域。 因此,改革传统办公模式,开展电子办公,使业务办公、公文流转和管理过程电子化、信息化,并通过统一办公规范,提高工作效率降低办公成本,实现办公自动化已势在必行。 而上述所介绍的公文流转的一个重要特征就是流程复杂,难以用标准的程序化语言解释,因而公文流转系统必须有与之相适应的工作流程定义系统,使操作人员能够自主地设定公文流转流程。为此我们设计了一个可视化流程设计工具,该工具可以作为工作流管理系统里的一个模块。它具有图形用户界面,用户定义与任务执行完全分离,其体系结构基本上符合wfmc 标准结构。用户不需要程序员的支持就
24、可以定义和设计出工作流程模型,根据该模型生成的文件可以非常方便地被解释为上层接口所需的工作流。3.2 系统功能介绍可视化oa工作流程设计工具针对用户的要求对工作流程进行定制和维护,主要包括:对接点、接点连接线可自由拖放。具备删除节点、节点之间连接线功能。接点之间采用箭头连接。接点采用矩形表示。图形内容利用xml形式保存于的access数据库中,可查询,编辑,保存,更多自定义属性。通过对用户需求的分析,要求本流程设计工具具有以下功能: (1)可视化的操作界面;(2)可以对流程节点和弧线进行填加、修改、删除操作; (3)工作流程支持串签、会签和分支流程;(4)可以将图形内容保存于access数据库
25、或(xml)中,可查询,编辑,保存;(5)可以通过流程模型解释接口和引擎主程序提供给上层程序使用3.3 系统模块功能和设计思想1994年11月,工作流管理联盟发布了工作流管理系统的参考模型,该模型定义了一个基本的工作流管理系统所需要的6个基本模块:过程定义工具,工作流执行服务,其他工作流执行服务,客户应用程序,被调应用程序,管理及监控工具;并制定了个模块之间的接口标准。流程设计工具与其系统交互的简单模块关系图:流程设计工具流程定义解释器引擎主程序api接口启动、终止、提交生成流程实力事件监听器路由判断器过程调用器图1 流程设计工具与其系统交互的简单模块关系图可视化流程设计工具流程定义解释器绘图
26、模块图象关系序列化模块图象关系保存模块图2 可视化流程设计工具的系统关系图可视化流程设计工具各模块的功能描述和设计思想介绍:(1)绘图模块:可将需要设计的流程用此模块画出,利用java.awt来绘制节点和弧线;(2)图象关系序列化模块:可将已画出流程中的节点和弧线序列化,利用接口java.io.serializable就能实现;(3)图象关系保存模块:可将序列化后的节点和弧线关系保存起来供上层流程定义解释器使用。3.4数据库设计3.4.1 e-r图设计实体关系图(e-r图)将系统中的数据模型以一种更加清楚、具体的方式展现出来。图中方框代表实体,椭圆代表实体的属性,实体和实体之间的关系用菱形来表
27、示。在工作流管理系统中,上层程序需要通过读取保存在数据库里流程的xml文件来实现流程的解释和实例化。在对工作流进行定义的工作中用到的e-r如下图所示: 编号节点名流程节点流程文件名称流程号类型前驱节点号前驱节点后继节点号后继节点流程号构成1m11mf m图3 e-r图3.4.2 表的构建表1 流程节点表(flow_node)对象名称数据类型功能描述node_id数字节点编号node_nane文本节点名称node_prev文本节点前驱名称node_previd数字前驱节点号node_next文本节点后继node_nextid数字后继节点号flow_id数字节点所属的流程号表2 流程表(flowd
28、ata)对象名称数据类型功能描述filename文本保存流程的文件名id数字流程号type文本node 类型还是 line 类型 3.4.3 数据库连接实现public connection getconnection() / now we can get the connection from the drivermanager connection con = null; try class.forname(sun.jdbc.odbc.jdbcodbcdriver); /驱动 set this to a ms access db you have on your machine strin
29、g filename = /filedata.mdb; string database = jdbc:odbc:driver=microsoft access driver (*.mdb);dbq=; database+= filename.trim() + ;driverid=22;readonly=true; / add on to the end con = drivermanager.getconnection( jdbc:odbc:ccos ,); /数据源 catch (classnotfoundexception e) / todo auto-generated catch bl
30、ock e.printstacktrace(); catch (sqlexception e) / todo auto-generated catch block e.printstacktrace(); return con; 4 系统功能模块实现4.1系统流程及图示4.2流程可视化设计实现4.2.1界面可视化4.2.2 绘图功能设计 4.2.3 流程图保存和读取方法设计将序列化后的节点与弧线的对象保存为xml文件,易于保存和重绘。序列化是将对象写到流中,序列化需要对象实现serializable接口,序列化后能将对象转换成一系列字节,并可在以后完全复原。序列化可以实现“有限持久化”。在保存
31、前先要对已经绘出的节点以及弧线进行属性采集,我们用一个nodebean以及arcbean方法来实现其功能,nodebean的代码描述如下:public class nodebean implements java.io.serializablepublic nodebean() string leftupnodex; /定义顶点坐标 string leftupnodey; private string minx;/定义边框 private string miny; private string maxx; private string maxy;color color; /定义外框颜色stri
32、ng nodename=;/节点名称public string getnodename() return nodename;public void setnodename(string nodename) nodename = nodename;public color getcolor() return color;public void setcolor(color color) this.color = color;public string getleftupnodex() return leftupnodex;public void setleftupnodex(string lef
33、tupnodex) leftupnodex = leftupnodex;public string getleftupnodey() return leftupnodey;public void setleftupnodey(string leftupnodey) leftupnodey = leftupnodey;public string getmaxx() return maxx;public void setmaxx(string maxx) maxx = maxx;public string getmaxy() return maxy;public void setmaxy(stri
34、ng maxy) maxy = maxy;public string getminx() return minx;public void setminx(string minx) minx = minx;public string getminy() return miny;public void setminy(string miny) miny = miny;将流程图中节点的属性对象进行采集以后,通过调用objecttoxmlutil.objectxmlencoder方法可以对节点和弧段进行保存,以下代码是对节点的保存,描述如下:vector v = new vector();vector
35、 temp = this.canvas.getnodeobject();for(int i=0;itemp.size();i+)/通过nodebean存储node o = (node)temp.elementat(i);nodebean bean = new nodebean();bean.setnodename(o.nodename);bean.setleftupnodex(o.getleftupnodex()+);bean.setleftupnodey(o.getleftupnodey()+);bean.setmaxx(o.getmaxx()+);bean.setmaxy(o.getmax
36、y()+);bean.setminx(o.getminx()+);bean.setminy(o.getminy()+);v.add(bean); string nodefile = nodedata+system.currenttimemillis()+.xml;objecttoxmlutil.objectxmlencoder( v ,nodefile );对弧线的属性采集类arcbean相关的代码描述如下:public class arcbean implements java.io.serializable private string endx; private string endy;
37、 private string startx; private string starty; public arcbean()/返回值 public string getendx() return endx;public void setendx(string endx) this.endx = endx;public string getendy() return endy;public void setendy(string endy) this.endy = endy;public string getstartx() return startx;public void setstart
38、x(string startx) this.startx = startx;public string getstarty() return starty;public void setstarty(string starty) this.starty = starty;将流程图中弧线的属性对象进行采集以后,通过调用objecttoxmlutil.objectxmlencoder方法可以对节点和弧段进行保存,以下代码是对节点的保存,描述如下:vector line = new vector();vector linetemp = this.canvas.getarcobject(); for(int i=0;i0) vector v = new vector(); for(int i= 0;ilist.size();i+) v = (vector)list.get(i); vector nodevector = new vector(); for(int j = 0;j0) vector linevector = new vector(); for(int i= 0
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 重要物资采购合同
- 江西省万载县高中生物 专题2 细胞工程 2.2.2 动物细胞融合与单克隆抗体(练习课)教案 新人教版选修3
- 2024年三年级品社下册《浓浓乡土情》教案 山东版
- 高考化学 专题二 第8讲 有机物的结构、性质和应用教案(含解析)
- 2024秋九年级历史上册 第七单元 工业革命和工人运动的兴起 第20课 第一次工业革命教案 新人教版
- 2023一年级数学上册 二 比一比第1课时 比长短 比高矮教案 苏教版
- 2024年春九年级化学下册 第12单元 化学与生活 课题2 化学元素与人体健康教案 (新版)新人教版
- 文书模板-委托研发合同补充协议
- 年度部门评分表
- 混凝土浇筑课件
- 高考英语高频短语按字母排序
- 世界各国国家代号、区号、时差
- 小学科学一年级下册教材分析(共3页)
- 优秀校长的政治素养与养成讲述
- 河北省滦平县东北部冶金矿产工业区发展规划
- 蓝牙测试项及其标准
- 第二章接待礼仪拜访礼仪馈赠礼仪
- 钢结构拆除的施工协议书
- 旅游列车开行管理办法
- 园区网络规划与设计管理 毕业设计
- 最新原创企业安全生产设备维修记录表.doc
评论
0/150
提交评论