网站备案有什么作用,合肥建站服务,企业网站建设合同百度文库,店铺logo设计图片免费生成器目录 前言#xff1a;
3.我的审批#xff1a;
3.1实现的特色功能#xff1a;
3.2显示的效果
3.3思路#xff1a;
3.4寻找相关的案例或者自己使用JavaScript去写一个类似的功能
3.5具体的步骤#xff1a;
3.5.1添加静态的jsp代码#xff08;我的审批数据的显示
3.我的审批
3.1实现的特色功能
3.2显示的效果
3.3思路
3.4寻找相关的案例或者自己使用JavaScript去写一个类似的功能
3.5具体的步骤
3.5.1添加静态的jsp代码我的审批数据的显示
3.5.2添加我的审批对应的js
3.5.3修改sql
3.5.4添加点击审批的jsp
3.5.5添加弹出审批的js
3.5.6实现送审的图片数据添加到数据库中注意这里有两个点运用到批处理的思维同时执行两条sql语句
dao方法
创建对应的实体类
action类
关键一步配置服务中的相关映射的信息
总结 前言
针对我的审批项要去实现一个有特色功能签字并且要将签字的那一小块截出来保存到指定的文件夹中。 3.我的审批 3.1实现的特色功能 只有审批人才能接收不同会议的请求默认待审批如果审批了就不显示具有会议签字的功能。 3.2显示的效果 3.3思路 当我们点击查询审批会显示当前账号对于的审批内容点击审批就会将点击的数据回显到弹出的页面上去这里我们有审批通过驳回的按钮点击通过才将签字的图片截图保存到数据库中。驳回就只返回一个驳回的结果不需要保存签字。 这里我们要注意的细节是审批页面的通过和驳回是针对于它下面被遮挡的页面进行的操作。理解就是我们在审批上的操作作用在我的审批页面上去。 3.4寻找相关的案例或者自己使用JavaScript去写一个类似的功能 要实现签字网络上只要找到50%相似就可以修改完成我们指定的功能 3.5具体的步骤
3.5.1添加静态的jsp代码我的审批数据的显示
% page languagejava contentTypetext/html; charsetUTF-8pageEncodingUTF-8%
%include file/common/header.jsp%
!DOCTYPE html
html
head
meta http-equivContent-Type contenttext/html; charsetUTF-8
script typetext/javascript src${pageContext.request.contextPath }/static/js/meeting/myAudit.js/script
/head
title我的审批界面/title
style
body{margin:15px;
}.layui-table-cell {height: inherit;}.layui-layer-page .layui-layer-content { overflow: visible !important;}
/style
body
!-- 搜索栏 --
div classlayui-form-item stylemargin:15px 0px;div classlayui-inlinelabel classlayui-form-label会议标题/labeldiv classlayui-input-inlineinput typehidden idauditor value${user.id }/input typetext idtitle autocompleteoff classlayui-input/div/divdiv classlayui-inlinebutton idbtn_search typebutton classlayui-btni classlayui-icon layui-icon-search/i 查询/button/div
/div
!-- 数据表格 --
table idtb lay-filtertb classlayui-table stylemargin-top:-15px/tablescript typetext/html idtbara classlayui-btn layui-btn-xs lay-eventedit审批/a
/script
/body
/html
3.5.2添加我的审批对应的js
let layer,table,$,form;
var row;
layui.use([layer,table,jquery,form],function(){layerlayui.layer,tablelayui.table,formlayui.form,$layui.jquery;initTable();//查询事件$(#btn_search).click(function(){query();});});//初始化数据表格我的审批
function initTable(){table.render({ //执行渲染elem: #tb, //指定原始表格元素选择器推荐id选择器height: 400, //自定义高度loading: false, //是否显示加载条默认 truecols: [[ //设置表头{field: id, title: 会议编号, width: 90},{field: title, title: 会议标题, width: 120},{field: location, title: 会议地点, width: 140},{field: startTime, title: 开始时间, width: 120},{field: endTime, title: 结束时间, width: 120},{field: meetingState, title: 会议状态, width: 120},{field: seatPic, title: 会议排座, width: 120,templet: function(d){if(d.seatPicnull || d.seatPic)return 尚未排座;elsereturn img width120px srcd.seatPic/;}},{field: , title: 操作, width: 200,toolbar:#tbar},]]});
}//点击查询
function query(){table.reload(tb, {url: $(#ctx).val()/info.action, //请求地址method: POST, //请求方式GET或者POSTloading: true, //是否显示加载条默认 truepage: true, //是否分页where: { //设定异步数据接口的额外参数任意设methodName:myAudit,auditor:$(#auditor).val(),title:$(#title).val(),}, request: { //自定义分页请求参数名pageName: page, //页码的参数名称默认pagelimitName: rows //每页数据量的参数名默认limit},done: function (res, curr, count) {//console.log(res);}});//工具条事件table.on(tool(tb), function(obj){ //注tool 是工具条事件名test 是 table 原始容器的属性 lay-filter对应的值row obj.data; //获得当前行数据var layEvent obj.event; //获得 lay-event 对应的值也可以是表头的 event 参数对应的值var tr obj.tr; //获得当前行 tr 的 DOM 对象如果有的话console.log(row);if(layEvent edit){ //审批openLayer(row.id);} else {}});
}// 打开审批页面
function openLayer(id){layer.open({type: 2, //layer提供了5种层类型。可传入的值有0信息框默认1页面层2iframe层3加载层4tips层title: 审批, //对话框标题area: [600px, 500px], //宽高skin: layui-layer-rim, //样式类名content: jsp/meeting/addMeetingAudit.jsp, //弹出内容。可以传入普通的html内容还可以指定DOM更可以随着type的不同而不同btn:[审批通过,审批驳回],yes:function(index,layero){//layer.msg(保存);//调用子页面中提供的getData方法快速获取子页面的form表单数据let data $(layero).find(iframe)[0].contentWindow.save();data[meetingId]id;data[auditor]$(#auditor).val();addMeetingAudit(data);},btn2:function(){let data{};data[sign]null;data[meetingId]id;data[auditor]$(#auditor).val();addMeetingAudit(data);return false;}});
}// 添加审批意见
function addMeetingAudit(params){params[methodName]add;console.log(params);$.post($(#ctx).val()/audit.action,params,function(rs){if(rs.success){layer.closeAll();query();}else{layer.msg(rs.msg,{icon:5},function(){});}},json);
} 3.5.3修改sql 根据当前登录的账号id降序查询 -- 这里需要两张表infouser表 -- 需求这里要显示审批人不为空新建user表通过字段auditor连接 private String getSQL() {return SELECT a.id,a.title,a.content,a.canyuze,a.liexize,a.zhuchiren,b.name,a.location\r\n ,DATE_FORMAT(a.startTime,%Y-%m-%d %H:%i:%s) as startTime\r\n ,DATE_FORMAT(a.endTime,%Y-%m-%d %H:%i:%s) as endTime\r\n ,a.state\r\n ,(case a.state\r\n when 0 then 取消会议\r\n when 1 then 新建\r\n when 2 then 待审核\r\n when 3 then 驳回\r\n when 4 then 待开\r\n when 5 then 进行中\r\n when 6 then 开启投票\r\n else 结束会 end\r\n ) as meetingState\r\n ,a.seatPic,a.remark,a.auditor,c.name as auditorName\r\n FROM t_oa_meeting_info a\r\n inner join t_oa_user b on a.zhuchiren b.id\r\n left JOIN t_oa_user c on a.auditor c.id where 11 ;
}
3.5.4添加点击审批的jsp % page languagejava contentTypetext/html; charsetUTF-8pageEncodingUTF-8%
%include file/common/header.jsp%
!DOCTYPE html
html
head
meta http-equivContent-Type contenttext/html; charsetUTF-8
link relstylesheet typetext/css href${pageContext.request.contextPath }/static/js/plugins/sign/css/www.jsdaima.com.css
link relstylesheet typetext/css href${pageContext.request.contextPath }/static/js/plugins/sign/font/iconfont.css
script typetext/javascript src${pageContext.request.contextPath }/static/js/meeting/addMeetingAudit.js/script
title我的审批的审批操作界面/title
/head
style
body{margin:5px;
}
/style
body
div stylepadding:10px 20px 10px 10px;form classlayui-form layui-form-pane lay-filterauditinput typehidden idid nameid/input typehidden idauditor value${sessionScope.user.id }/div classlayui-form-itemlabel classlayui-form-label会议标题/labeldiv classlayui-input-blockinput typetext nametitle autocompleteoff classlayui-input readonlyreadonly/div/divdiv classlayui-form-item layui-form-textlabel classlayui-form-label会议内容/labeldiv classlayui-input-blocktextarea placeholder请输入内容 namecontent classlayui-textarea readonlyreadonly/textarea/div/div!-- div classlayui-form-item layui-form-text --!-- label classlayui-form-label会议内容/label --!-- div classlayui-input-block --div classcanvasBoxdiv classcontroul classdrawType li data-namepen data-nameNum0span classicon iconfont icon-qianbi/spanspan classiconAlert铅笔/span/li !-- li classdownLoad span classicon iconfont icon-baocun/spanspan classiconAlert保存/spanimg src alt classdownImg/li li data-nameeraser span classicon iconfont icon-xiangpi/spanspan classiconAlert橡皮/span/li --li classremotespan classicon iconfont icon-delete/spanspan classiconAlert清空/span/li /ul /div div classcanvasDrawdiv classdrawFont data-typehidespan classintoFont/spaninput typetext classintoFontInput/divcanvas idcanvas width550 height150/canvas /div /div!-- /div/div --/form
/div
/body
/html
3.5.5添加弹出审批的js 这里的js代码直接copy就好了因为这个js的功能强大。 let layer,table,$,form;
var row;
layui.use([layer,table,jquery,form],function(){layerlayui.layer,tablelayui.table,formlayui.form,$layui.jquery;if(parent.row!null){form.val(audit,$.extend({}, parent.row||{}));}init();function init() {$(.strokeColorBox).css(border,4px solid $(.strokeColor).val()).find(.icon).css(color,$(.strokeColor).val());$(.weightBox .icon).html($(.weight).val()px);$(.drawFont).css({height: $(.font_box_size).val()})}/*** 右键按下不显示浏览器自带框*/$(#canvas).get(0).oncontextmenu function (e) { showMyselfBox(e);return false;}; /*** 显示自定义框*/function showMyselfBox (e) {var left e.offsetX;var top e.offsetY;$(.myselfBox).css({left: left,top: top}).show();}/*** 鼠标滑过工具台*/$(.contro li).on(mouseover, function () {$(this).on(mouseout, function () {$(.contro li).find(.iconAlert).hide()});$(this).find(.iconAlert).show();});/*** 点击工具台*/$(.drawType li).on(click touchstart, function (e) {if (e.type touchstart) {e.preventDefault();}$(this).addClass(drawTypeChoose).siblings().removeClass(drawTypeChoose);initData.drawType $(this).attr(data-name);initData.drayTypeNum $(this).attr(data-nameNum)})/*** 改变线条颜色*/$(.strokeColor).on(change, function (e) {initData.color $(this).val();$(.strokeColorBox).css(border,4px solid initData.color).find(.icon).css(color,initData.color);})/*** 改变背景色*/$(.backgroundColor).on(change, function (e) {initData.background $(this).val();$(.backgroundColor).css(border,4px solid initData.background).find(.icon).css(color,initData.background);})$(.fillDraw).on(click touchstart,function (e) {if (e.type touchstart) {e.preventDefault()}if ($(this).attr(data-choose) false) {$(this).attr(data-choose,true).addClass(fillBg);$(.backgroundColorBox).css({border:4px solid initData.background,background:#fff}).find(.icon).css(color,initData.background);$(.backgroundColor).show();initData.isFill true;} else {initData.isFill false;$(this).attr(data-choose,false).removeClass(fillBg);$(.backgroundColor).hide();$(.backgroundColorBox).css({border:4px solid #07133d,background:#07133d}).find(.icon).css(color,#666);}})/*** 改变线条粗细*/$(.weight).on(change, function () {initData.size $(this).val();$(.weightBox .icon).html($(.weight).val()px);})/*** 绘制还是移动*/$(.drawOrMove).on(click touchstart,function (e) {if (e.type touchstart) {e.preventDefault()}$(this).addClass(drawOrmoveChoose).siblings(.drawOrMove).removeClass(drawOrmoveChoose);if ($(this).attr(data-name) move) {// if (initData.drawType line || initData.drawType pen || initData.drawType line || initData.drawType signet || initData.drawType eraser) {// alert()// }$(.maskLi).show();initData.drawOrMove $(this).attr(data-name);$(#canvas).css(cursor,move);} else {initData.drawOrMove $(this).attr(data-name);$(.maskLi).hide();$(#canvas).css(cursor,crosshair);}})/*** 绘制文字*/$(.intoFontInput).on(input, function () {$(.intoFont).html($(this).val());initData.context $(this).val();})$(.font_box_size).on(change,function () {initData.fontSize $(this).val();})/*** 清除画布*/$(.remote).on(mousedown touchstart,function (e) {if (e.type touchstart) {e.preventDefault()}initData.context2d.clearRect(0,0,initData.canvasWidth,initData.canvasHeight);initData.drawHistoryArrData [];initData.drawHistoryArrData.length 0;})/*** 保存图片*/$(.downLoad).on(mousedown touchstart,function (a) {//debugger;save();})/*** 鼠标在canvas按下*/$(#canvas).on(mousedown touchstart,function (e) {if (e.type touchstart) {e.preventDefault()}if (e.button 0 || e.type touchstart) { // 判断是左键按下$(.myselfBox).hide();initData.mouseDown(e);$(this).on(mousemove touchmove, function (e) {if (e.type touchmove) {e.preventDefault()}initData.mouseMove(e);})}})/*** 鼠标抬起*/$(html).on(mouseup touchend,function(){initData.mouseUp();})var initData {drawHistoryArrData: [], // 存放所有绘制图形的数据context2d: $(#canvas).get(0).getContext(2d), // canvas绘图2d环境canvasWidth: $(#canvas).width(),canvasHeight: $(#canvas).height(),relPosX: 0, // 鼠标在绘制图形中按下相对该图形左面的距离relPosY: 0, // 鼠标在绘制图形中按下相对该图形上面的距离relPosToX: 0, // 鼠标在绘制图形中按下相对该图形左面的距离relPosToY: 0, initLeft: 0,initTop: 0,chooseIndex: 0, // 选中图形在drawHistoryArrData数据中的indexdrawOrMove: draw, // 当前模式是拖拽还是绘制isMove: false, // 是否可以拖拽drawType: pen, // 绘制图形的类型drawTypeNum: 1, // 用于区分同一图形不同形状size: 2, // 绘制的粗细fontSize: $(.font_box_size).val(),context:,color: $(.strokeColor).val(), // 绘制颜色isFill: false, // 是否填充background: $(.backgroundColor).val(),msgArr:[], // 画笔信息/*** 矩形绘制轨迹*/drawTypeArr: function (arr,j) {var drawTypeFn { // 绘制方法rect: function () { // 矩形initData.context2d.beginPath();initData.context2d.lineWidth arr[j].size;initData.context2d.strokeStyle arr[j].color;initData.context2d.rect(arr[j].x, arr[j].y, arr[j].w,arr[j].h);if (arr[j].fill) {initData.context2d.fillStyle arr[j].fill;initData.context2d.fill();}initData.context2d.stroke();},line: function () { // 线initData.context2d.beginPath();initData.context2d.moveTo (arr[j].x,arr[j].y); //设置起点状态initData.context2d.lineTo (arr[j].toX,arr[j].toY); //设置末端状态initData.context2d.lineWidth arr[j].size; //设置线宽状态initData.context2d.strokeStyle arr[j].color; //设置线的颜色状态initData.context2d.stroke(); },circle: function () { // 圆initData.context2d.beginPath();initData.context2d.lineWidth arr[j].size; //设置线宽状态initData.context2d.strokeStyle arr[j].color;initData.context2d.arc(arr[j].x,arr[j].y,arr[j].r,0,2*Math.PI);if (arr[j].fill) {initData.context2d.fillStyle arr[j].fill;initData.context2d.fill();}initData.context2d.stroke()},delta: function () { // 三角var w arr[j].toX-arr[j].x;var h arr[j].toY-arr[j].y;var harfDis Math.tan(30/2)*h ;if (arr[j].toX-arr[j].x0) {harfDis harfDis} else {harfDis -harfDis}initData.context2d.beginPath();initData.context2d.moveTo (arr[j].x,arr[j].y); //设置起点状态initData.context2d.lineTo (arr[j].toX,arr[j].toY);initData.context2d.lineTo (arr[j].toX 2*harfDis,arr[j].toY);initData.context2d.lineTo (arr[j].x,arr[j].y); //设置末端状态initData.context2d.lineWidth arr[j].size; //设置线宽状态initData.context2d.strokeStyle arr[j].color; //设置线的颜色状态if (arr[j].fill) {initData.context2d.fillStyle arr[j].fill;initData.context2d.fill();}initData.context2d.stroke(); },ellipse: function () {initData.context2d.beginPath();initData.context2d.lineWidth arr[j].size; //设置线宽状态initData.context2d.strokeStyle arr[j].color;initData.context2d.ellipse(arr[j].x,arr[j].y,Math.abs(arr[j].toX - arr[j].x),Math.abs(arr[j].toY -arr[j].y),0,0,Math.PI*2); if (arr[j].fill) {initData.context2d.fillStyle arr[j].fill;initData.context2d.fill();}initData.context2d.stroke();},polygon: function () {var y1 (arr[j].toY-arr[j].y)/2;var tan Math.tan((90-(arr[j].reg/2))*(2*Math.PI/360));var x1 y1*tan;initData.context2d.beginPath();initData.context2d.moveTo (arr[j].x,arr[j].y); //设置起点状态initData.context2d.lineTo (arr[j].toX,arr[j].y);initData.context2d.lineTo (arr[j].toXx1,arr[j].yy1);initData.context2d.lineTo (arr[j].toX,arr[j].toY); //设置末端状态initData.context2d.lineTo (arr[j].x,arr[j].toY); initData.context2d.lineTo (arr[j].x-x1,arr[j].yy1); initData.context2d.lineTo (arr[j].x,arr[j].y); initData.context2d.lineWidth arr[j].size; //设置线宽状态initData.context2d.strokeStyle arr[j].color; //设置线的颜色状态if (arr[j].fill) {initData.context2d.fillStyle arr[j].fill;initData.context2d.fill();}initData.context2d.stroke(); },font: function () {// initData.context2d.beginPath();initData.context2d.font arr[j].fontSizepx Verdana;initData.context2d.textAlign center;initData.context2d.textBaseline bottom;initData.context2d.fillStyle arr[j].color;// if (arr[j].fill) {initData.context2d.fillText(arr[j].context, arr[j].x, arr[j].y); // }// initData.context2d.strokeText(arr[j].context, arr[j].x, arr[j].y);// initData.context2d.lineWidth 1;// initData.context2d.strokeStyle transparent;// initData.context2d.rect(arr[j].x, arr[j].y, arr[j].w,arr[j].h);// initData.context2d.stroke();$(.drawFont).hide();// initData.context $(.intoFont).html();$(.intoFontInput).val();$(.drawFont).attr(data-type,hide);},signet: function () {var img new Image();img.src ;img.onload function(){initData.context2d.drawImage(img, arr[j].x-50, arr[j].y-50,100,100);}},pen: function () {var lineWidth arr[j].size;var radiuslineWidth/2;var lineColor arr[j].color;initData.context2d.beginPath();$.each(arr[j].msgArr,function (index,val) {initData.context2d.lineWidth lineWidth; initData.context2d.lineTo(val.x, val.y); initData.context2d.strokeStyle lineColor;initData.context2d.stroke(); initData.context2d.beginPath(); initData.context2d.arc(val.x, val.y, radius, 0, 360, false);initData.context2d.fillStyle lineColor;initData.context2d.fill(); initData.context2d.beginPath(); initData.context2d.moveTo(val.x, val.y); initData.context2d.stroke(); })},eraser: function () {$.each(arr[j].msgArr,function (index,val) {initData.context2d.clearRect(val.x,val.y,arr[j].size,arr[j].size);})}};switch (arr[j].drawType) {case rect:drawTypeFn.rect(); break;case line:drawTypeFn.line(); break;case circle:drawTypeFn.circle(); break;case delta:drawTypeFn.delta(); break;case ellipse:drawTypeFn.ellipse(); break;case polygon: drawTypeFn.polygon(); break;case font: drawTypeFn.font(); break;case signet: drawTypeFn.signet(); break;case pen: drawTypeFn.pen(); break;case eraser: drawTypeFn.eraser(); break;}},/*** 统一绘制方法*/drawArr: function (arr) {for (var j in arr) {this.drawTypeArr(arr,j)}},/*** 鼠标按下执行*/mouseDown: function (e) { // 鼠标按下initData.initLeft e.offsetX?e.offsetX:e.originalEvent.targetTouches[0].pageX - $(#canvas).offset().left;//获取鼠标起始位置initData.initTop e.offsetY?e.offsetY:e.originalEvent.targetTouches[0].pageY - $(#canvas).offset().top; initData.msgArr [];if (initData.drawHistoryArrData.length0) {function getChooseIndex() {for(var i in initData.drawHistoryArrData) {initData.drawArr([initData.drawHistoryArrData[i]]);if (initData.drawOrMove move) {if(initData.context2d.isPointInPath(initData.initLeft,initData.initTop)) {initData.drawArr(initData.drawHistoryArrData);initData.relPosX initData.initLeft - initData.drawHistoryArrData[i].x;initData.relPosY initData.initTop - initData.drawHistoryArrData[i].y;initData.relPosToX initData.initLeft - initData.drawHistoryArrData[i].toX;initData.relPosToY initData.initTop - initData.drawHistoryArrData[i].toY;initData.isMove true;return i; } }}if (initData.drawOrMove move) {return -1;} else {return initData.drawHistoryArrData.length;}}initData.chooseIndex getChooseIndex();} else {if (initData.drawOrMove move) {initData.chooseIndex -1;} }if ($(.drawFont).attr(data-type) hide) {if (this.drawType font) {var x initData.initLeft;var y initData.initTop;$(.drawFont).attr(data-type,show);$(.drawFont).css({left:initData.initLeftpx,top:initData.initToppx}).show();$(.intoFontInput).on(blur, function () {initData.context $(.intoFontInput).val();initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawType,drawTypeNum: initData.drawTypeNum,fill: initData.isFill?initData.background:,size: initData.size,fontSize: initData.fontSize,context:initData.context,color: initData.color,x: x,y: y,w: $(.intoFontInput).width(),h: $(.intoFontInput).height()};initData.drawArr(initData.drawHistoryArrData);})}}if (this.drawType signet) {initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawType,drawTypeNum: initData.drawTypeNum,fill: initData.isFill?initData.background:,size: initData.size,color: initData.color,x: initData.initLeft,y: initData.initTop};initData.drawArr(initData.drawHistoryArrData);}}, /*** 鼠标移动执行*/mouseMove: function (e) { // 鼠标移动initData.context2d.clearRect(0,0,initData.canvasWidth,initData.canvasHeight);var moveX e.offsetX?e.offsetX:e.originalEvent.targetTouches[0].pageX - $(#canvas).offset().left;var moveY e.offsetY?e.offsetY:e.originalEvent.targetTouches[0].pageY - $(#canvas).offset().top;var moveWidth moveX - initData.initLeft;var moveHeight moveY - initData.initTop;if (initData.isMove) {switch (initData.drawHistoryArrData[initData.chooseIndex].drawType) {case rect:initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawHistoryArrData[initData.chooseIndex].drawType,drawTypeNum: initData.drawHistoryArrData[initData.chooseIndex].drawTypeNum,fill: initData.drawHistoryArrData[initData.chooseIndex].fill,size: initData.drawHistoryArrData[initData.chooseIndex].size,color: initData.drawHistoryArrData[initData.chooseIndex].color,x: moveWidth initData.initLeft - initData.relPosX,y: moveHeight initData.initTop - initData.relPosY,w: initData.drawHistoryArrData[initData.chooseIndex].w,h: initData.drawHistoryArrData[initData.chooseIndex].h}; break;case line:initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawHistoryArrData[initData.chooseIndex].drawType,drawTypeNum: initData.drawHistoryArrData[initData.chooseIndex].drawTypeNum,fill: initData.drawHistoryArrData[initData.chooseIndex].fill,size: initData.drawHistoryArrData[initData.chooseIndex].size,color: initData.drawHistoryArrData[initData.chooseIndex].color,x: initData.drawHistoryArrData[initData.chooseIndex].xmoveX,y: initData.drawHistoryArrData[initData.chooseIndex].y moveY,toX: moveX,toY: moveY}; break;case circle:initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawHistoryArrData[initData.chooseIndex].drawType,drawTypeNum: initData.drawTypeNum,fill: initData.drawHistoryArrData[initData.chooseIndex].fill,size: initData.size,color: initData.color,x: moveWidth initData.initLeft - initData.relPosX,y: moveHeight initData.initTop - initData.relPosY,r: initData.drawHistoryArrData[initData.chooseIndex].r,}; break;case delta:initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawHistoryArrData[initData.chooseIndex].drawType,drawTypeNum: initData.drawTypeNum,fill: initData.drawHistoryArrData[initData.chooseIndex].fill,size: initData.size,color: initData.color,x: moveWidth initData.initLeft - initData.relPosX,y: moveHeight initData.initTop - initData.relPosY,toX: moveWidth initData.initLeft - initData.relPosToX,toY: moveHeight initData.initTop - initData.relPosToY,}; break;case ellipse:initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawHistoryArrData[initData.chooseIndex].drawType,drawTypeNum: initData.drawTypeNum,fill: initData.drawHistoryArrData[initData.chooseIndex].fill,size: initData.size,color: initData.color,x: moveWidth initData.initLeft - initData.relPosX,y: moveHeight initData.initTop - initData.relPosY,toX: moveWidth initData.initLeft - initData.relPosToX,toY: moveHeight initData.initTop - initData.relPosToY,}; break;case polygon:// 六边形initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawHistoryArrData[initData.chooseIndex].drawType,drawTypeNum: initData.drawTypeNum,fill: initData.drawHistoryArrData[initData.chooseIndex].fill,size: initData.size,color: initData.color,x: moveWidth initData.initLeft - initData.relPosX,y: moveHeight initData.initTop - initData.relPosY,reg: initData.drawHistoryArrData[initData.chooseIndex].reg,toX: moveWidth initData.initLeft - initData.relPosToX,toY: moveHeight initData.initTop - initData.relPosToY}; break;}} else {if (initData.chooseIndex ! -1) {switch (this.drawType) {case rect: // 矩形initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawType,drawTypeNum: initData.drawTypeNum,fill: initData.isFill?initData.background:,size: initData.size,color: initData.color,x: initData.initLeft,y: initData.initTop,w: moveWidth,h: moveHeight}; break;case line: // 线initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawType,drawTypeNum: initData.drawTypeNum,fill: initData.isFill?initData.background:,size: initData.size,color: initData.color,x: initData.initLeft,y: initData.initTop,toX: moveX,toY: moveY}; break;case circle: //圆initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawType,drawTypeNum: initData.drawTypeNum,fill: initData.isFill?initData.background:,size: initData.size,color: initData.color,x: initData.initLeft,y: initData.initTop,r: Math.sqrt(moveWidth*moveWidthmoveHeight*moveHeight)}; break;case delta: // 三角initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawType,drawTypeNum: initData.drawTypeNum,fill: initData.isFill?initData.background:,size: initData.size,color: initData.color,x: initData.initLeft,y: initData.initTop,toX: moveX,toY: moveY,}; break;case ellipse: // 椭圆initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawType,drawTypeNum: initData.drawTypeNum,fill: initData.isFill?initData.background:,size: initData.size,color: initData.color,x: initData.initLeft,y: initData.initTop,toX: moveX,toY: moveY,}; break;case polygon:// 六边形initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawType,drawTypeNum: initData.drawTypeNum,fill: initData.isFill?initData.background:,size: initData.size,color: initData.color,x: initData.initLeft,y: initData.initTop,reg: $(.polygon_1_deg).val(),toX: moveX,toY: moveY,}; break;case pen:initData.msgArr.push({x: moveX,y: moveY})var msg initData.msgArr.concat();initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawType,drawTypeNum: initData.drawTypeNum,fill: initData.isFill?initData.background:,size: initData.size,color: initData.color,x: initData.initLeft,y: initData.initTop,toX: moveX,toY: moveY,msgArr:msg}; break;case eraser: initData.msgArr.push({x: moveX,y: moveY})var msg initData.msgArr.concat();initData.drawHistoryArrData[initData.chooseIndex] {drawType: initData.drawType,drawTypeNum: initData.drawTypeNum,fill: initData.isFill?initData.background:,size: initData.size,color: initData.color,x: initData.initLeft,y: initData.initTop,toX: moveX,toY: moveY,msgArr:msg}; break;// case signet: // 印章// initData.drawHistoryArrData[initData.chooseIndex] {// drawType: initData.drawType,// drawTypeNum: initData.drawTypeNum,// fill: initData.isFill?initData.background:,// size: initData.size,// color: initData.color,// x: initData.initLeft,// y: initData.initTop,// toX: moveX,// toY: moveY,// }; break;// case delta// case circle// case ellipse// case line// // case signet// case pen// case brush}}}initData.drawArr(initData.drawHistoryArrData);},/*** 鼠标抬起执行*/mouseUp: function () {initData.msgArr [];initData.isMove false;initData.relPosX 0;initData.relPosY 0;$(#canvas).off(mousemove);}};});/*** 用于保存签字的图片* returns*/
function save(){var mycanvas document.getElementById(canvas); var image mycanvas.toDataURL(image/png); let params{sign:image};return params;
}3.5.6实现送审的图片数据添加到数据库中注意这里有两个点运用到批处理的思维同时执行两条sql语句
dao方法
public class MeetingAuditDao extends BaseDaoMeetingAudit{/*** 添加我的审批//批处理* 这里我们的处理逻辑 将图片意见保存到meeting_audit表中同时修改会议的状态* return*/public int add(MeetingAudit audit) {//图片意见保存到meeting_audit表中的sql//添加的字段id是自增的time是data,这里号不能被basedao识别的需要用到getString sql1 insert into t_oa_meeting_audit(meetingId,auditor,sign) values(audit.getMeetingId(),audit.getAuditor(),audit.getSign());//修改会议的状态的sql//这里的state会议的状态需要判断4通过了3驳回了boolean flag StringUtils.isNotBlank(audit.getSign());int state flag ? 4 :3;String sql2 update t_oa_meeting_info set state ? where id audit.getMeetingId();String[] sqlLst new String [] {sql1,sql2};//executeUpdateBatch()调用父类的批处理//这里我们传了两个sqlbasedao中就应该是返回他们两个的长度。return super.executeUpdateBatch(sqlLst);}
创建对应的实体类
/*** */
package com.lya.entity;import java.io.Serializable;import javafx.scene.chart.PieChart.Data;/*** 审批表的实体* * author 李永安** date:2023年7月21日 下午7:18:47* */
public class MeetingAudit implements Serializable {private Integer id;private Long meetingId;// 会议表的idprivate String auditor;private String sign;// 审批签字private Data createdate;// 审批时间/*** */public MeetingAudit() {// TODO Auto-generated constructor stub}public Integer getId() {return id;}public void setId(Integer id) {this.id id;}public Long getMeetingId() {return meetingId;}public void setMeetingId(Long meetingId) {this.meetingId meetingId;}public String getAuditor() {return auditor;}public void setAuditor(String auditor) {this.auditor auditor;}public String getSign() {return sign;}public void setSign(String sign) {this.sign sign;}public Data getCreatedate() {return createdate;}public void setCreatedate(Data createdate) {this.createdate createdate;}public MeetingAudit(Integer id, Long meetingId, String auditor, String sign, Data createdate) {super();this.id id;this.meetingId meetingId;this.auditor auditor;this.sign sign;this.createdate createdate;}Overridepublic String toString() {return MeetingAudit [id id , meetingId meetingId , auditor auditor , sign sign , createdate createdate ];}}action类
public String add(HttpServletRequest req, HttpServletResponse resp) {try {if(StringUtils.isNotBlank(audit.getSign())) {// 1.接收图片存放的地址字符串String dirPath PropertiesUtil.getValue(dirPathSign);// dirPathSignE:/temp/images/t_oao/sign/这是保存下载图片的位置// 接收浏览器请求的地址➡用于保存到数据库中String serverPath PropertiesUtil.getValue(serverPathSign);// 保存图片前先去设置一个随机的路径字符将-换成空的因为这里我们保存路径是连着的String savepic UUID.randomUUID().toString().replaceAll(-, ) .png;// 2.调用无参获取当前的保存的地址//info.getSeatPic();// 3.图片转换工具Baseutil中的generataImage并且重新保存路径Base64ImageUtils.GenerateImage(audit.getSign().toString().replaceAll(data:image/png;base64,, ), dirPathsavepic);// 调用无参去重新保存的地址audit.setSign(serverPathsavepic);}int rs mad.add(audit);if (rs 0) {ResponseUtil.writeJson(resp, R.ok(200, 会议审批成功));} else {ResponseUtil.writeJson(resp, R.error(0, 会议审批失败));}} catch (Exception e) {e.printStackTrace();}return toList;}
关键一步配置服务中的相关映射的信息 总结 在实现我的审批时还是比较难的要注意保存图片的路径是否匹配还有批处理的sql。
文章转载自: http://www.morning.fthcq.cn.gov.cn.fthcq.cn http://www.morning.lzdbb.cn.gov.cn.lzdbb.cn http://www.morning.wpydf.cn.gov.cn.wpydf.cn http://www.morning.ryzgp.cn.gov.cn.ryzgp.cn http://www.morning.rkgyx.cn.gov.cn.rkgyx.cn http://www.morning.jggr.cn.gov.cn.jggr.cn http://www.morning.gpkjx.cn.gov.cn.gpkjx.cn http://www.morning.pyxtn.cn.gov.cn.pyxtn.cn http://www.morning.bkfdf.cn.gov.cn.bkfdf.cn http://www.morning.rqgq.cn.gov.cn.rqgq.cn http://www.morning.llxns.cn.gov.cn.llxns.cn http://www.morning.xzkgp.cn.gov.cn.xzkgp.cn http://www.morning.clbsd.cn.gov.cn.clbsd.cn http://www.morning.gnzsd.cn.gov.cn.gnzsd.cn http://www.morning.lffgs.cn.gov.cn.lffgs.cn http://www.morning.alwpc.cn.gov.cn.alwpc.cn http://www.morning.ftmp.cn.gov.cn.ftmp.cn http://www.morning.sqtsl.cn.gov.cn.sqtsl.cn http://www.morning.wdhlc.cn.gov.cn.wdhlc.cn http://www.morning.nrmyj.cn.gov.cn.nrmyj.cn http://www.morning.kmqlf.cn.gov.cn.kmqlf.cn http://www.morning.fmqng.cn.gov.cn.fmqng.cn http://www.morning.lczxm.cn.gov.cn.lczxm.cn http://www.morning.jkpnm.cn.gov.cn.jkpnm.cn http://www.morning.bwzzt.cn.gov.cn.bwzzt.cn http://www.morning.rjynd.cn.gov.cn.rjynd.cn http://www.morning.fnbtn.cn.gov.cn.fnbtn.cn http://www.morning.pyswr.cn.gov.cn.pyswr.cn http://www.morning.mlcwl.cn.gov.cn.mlcwl.cn http://www.morning.bxqpl.cn.gov.cn.bxqpl.cn http://www.morning.twhgn.cn.gov.cn.twhgn.cn http://www.morning.trlhc.cn.gov.cn.trlhc.cn http://www.morning.yppln.cn.gov.cn.yppln.cn http://www.morning.tbjtp.cn.gov.cn.tbjtp.cn http://www.morning.deupp.com.gov.cn.deupp.com http://www.morning.dmlsk.cn.gov.cn.dmlsk.cn http://www.morning.lgwpm.cn.gov.cn.lgwpm.cn http://www.morning.wnzgm.cn.gov.cn.wnzgm.cn http://www.morning.nccqs.cn.gov.cn.nccqs.cn http://www.morning.mltsc.cn.gov.cn.mltsc.cn http://www.morning.bzsqr.cn.gov.cn.bzsqr.cn http://www.morning.bxczt.cn.gov.cn.bxczt.cn http://www.morning.tcpnp.cn.gov.cn.tcpnp.cn http://www.morning.swbhq.cn.gov.cn.swbhq.cn http://www.morning.pqqxc.cn.gov.cn.pqqxc.cn http://www.morning.rckmz.cn.gov.cn.rckmz.cn http://www.morning.lkbkd.cn.gov.cn.lkbkd.cn http://www.morning.gmgnp.cn.gov.cn.gmgnp.cn http://www.morning.eshixi.com.gov.cn.eshixi.com http://www.morning.txfzt.cn.gov.cn.txfzt.cn http://www.morning.lrprj.cn.gov.cn.lrprj.cn http://www.morning.wqrk.cn.gov.cn.wqrk.cn http://www.morning.qnksk.cn.gov.cn.qnksk.cn http://www.morning.clbsd.cn.gov.cn.clbsd.cn http://www.morning.tmnyj.cn.gov.cn.tmnyj.cn http://www.morning.jlthz.cn.gov.cn.jlthz.cn http://www.morning.jqpq.cn.gov.cn.jqpq.cn http://www.morning.zqfz.cn.gov.cn.zqfz.cn http://www.morning.rklgm.cn.gov.cn.rklgm.cn http://www.morning.prmbn.cn.gov.cn.prmbn.cn http://www.morning.smhtg.cn.gov.cn.smhtg.cn http://www.morning.rsxw.cn.gov.cn.rsxw.cn http://www.morning.hjwxm.cn.gov.cn.hjwxm.cn http://www.morning.mqmmc.cn.gov.cn.mqmmc.cn http://www.morning.xsszn.cn.gov.cn.xsszn.cn http://www.morning.lqypx.cn.gov.cn.lqypx.cn http://www.morning.mdgb.cn.gov.cn.mdgb.cn http://www.morning.rxnxl.cn.gov.cn.rxnxl.cn http://www.morning.rqkzh.cn.gov.cn.rqkzh.cn http://www.morning.jqhrk.cn.gov.cn.jqhrk.cn http://www.morning.yqzyp.cn.gov.cn.yqzyp.cn http://www.morning.jfymz.cn.gov.cn.jfymz.cn http://www.morning.yysqz.cn.gov.cn.yysqz.cn http://www.morning.pjrql.cn.gov.cn.pjrql.cn http://www.morning.wfysn.cn.gov.cn.wfysn.cn http://www.morning.yzygj.cn.gov.cn.yzygj.cn http://www.morning.jwefry.cn.gov.cn.jwefry.cn http://www.morning.mbzlg.cn.gov.cn.mbzlg.cn http://www.morning.aishuxue.com.cn.gov.cn.aishuxue.com.cn http://www.morning.sqhtg.cn.gov.cn.sqhtg.cn