zoukankan      html  css  js  c++  java
  • activiti5学习资料(5.12版本流程图的生成)

    activiti5学习资料(5.12版本流程图的生成)

    描述:

    activiti5.12版本,流程图的生成,在servlet将图片流输出到div层中,然后在页面上显示图形。

    activiti版本:5.12版本

    导入jar包:

    <dependency>
    			<groupId>org.activiti</groupId>
    			<artifactId>activiti-spring</artifactId>
    			<version>${activiti-version}</version>
    		</dependency>
    		<dependency>
    			<groupId>org.activiti</groupId>
    			<artifactId>activiti-engine</artifactId>
    			<version>${activiti-version}</version>
    		</dependency>
    		<dependency>
    			<groupId>org.activiti</groupId>
    			<artifactId>activiti-bpmn-model</artifactId>
    			<version>${activiti-version}</version>
    		</dependency>
    		<dependency>
    		    <groupId>org.activiti</groupId>
    		    <artifactId>activiti-bpmn-converter</artifactId>
    		    <version>${activiti-version}</version>
    		</dependency>


    jsp页面代码:

    <%@ page language="java" contentType="text/html; charset=UTF-8"
    	pageEncoding="UTF-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>流程图</title>
    <%@ include file="/inc.jsp"%>
    </head>
    <body>
    	<h2>流程图x=${point.x},y=${point.y}</h2>
    	<div style="position: relative;background:url('${ctx}/bpmImage?processDefinitionId=${processDefinitionId}')  no-repeat;${point.x}px;height:${point.y}px;">
    	</div>
    </body>
    </html>


    servlet代码:

    @Override
    	protected void doPost(HttpServletRequest req, HttpServletResponse resp)
    			throws ServletException, IOException {
    		String proDefId = req.getParameter("processDefinitionId");
    		// 生成图片
    		InputStream is = null;
    		if (StringUtils.isNotEmpty(proDefId)) {
    			BpmnModel bpmnModel = repositoryService.getBpmnModel(proDefId);
    			is = ProcessDiagramGenerator.generatePngDiagram(bpmnModel);
    		}
    		if (is != null) {
    			resp.setContentType("image/png");
    			OutputStream out = resp.getOutputStream();
    			try {
    				byte[] bs = new byte[1024];
    				int n = 0;
    				while ((n = is.read(bs)) != -1) {
    					out.write(bs, 0, n);
    				}
    				out.flush();
    			} catch (Exception ex) {
    				ex.printStackTrace();
    			} finally {
    				is.close();
    				out.close();
    			}
    		}
    	}


    如果想设置流程图的div的大小:

    遍历流程节点的元素大小,然后获取最大的坐标信息。

    代码:

    import org.activiti.bpmn.model.BpmnModel;
    import org.activiti.bpmn.model.GraphicInfo;
    
    /**
     * @description 流程图片辅助类
     * @description BpmImageUtil
     * @author 不了了之之了之
     * @data 2013-3-31
     */
    public class BpmImageUtil {
    
    	/**
    	 * 获取流程节点元素中,最大的x,y坐标信息
    	 * 
    	 * @param bpmnModel
    	 *            BpmnModel对象
    	 * @return Point
    	 */
    	public static Point getPoint(BpmnModel bpmnModel) {
    		Point point = null;
    		if (bpmnModel != null && bpmnModel.getFlowLocationMap().size() > 0) {
    			int maxX = 0;
    			int maxY = 0;
    			for (String key : bpmnModel.getLocationMap().keySet()) {
    				GraphicInfo graphicInfo = bpmnModel.getGraphicInfo(key);
    				double elementX = graphicInfo.getX() + graphicInfo.getWidth();
    				if (maxX < elementX) {
    					maxX = (int) elementX;
    				}
    				double elementY = graphicInfo.getY() + graphicInfo.getHeight();
    				if (maxY < elementY) {
    					maxY = (int) elementY;
    				}
    			}
    			point = new Point(maxX, maxY);
    		} else {
    			point = new Point(100, 100);
    		}
    		return point;
    	}
    }
    


    效果图:




  • 相关阅读:
    安全公司
    HTML5 Security Cheatsheet
    渗透1
    dos其他
    Ddos 类别
    python之控制条件if语句
    python编码规范(二)——空行,换行,缩进
    python编码规范(一)——空格的使用
    python入门基础
    网页模板的自定义
  • 原文地址:https://www.cnblogs.com/javawebsoa/p/2991992.html
Copyright © 2011-2022 走看看