From 8299dc8cd015c354ce0765a130583a16d994a1b0 Mon Sep 17 00:00:00 2001 From: zss <zss@example.com> Date: 星期一, 08 七月 2024 14:25:52 +0800 Subject: [PATCH] 骑缝章1.0 --- inspect-server/src/main/resources/mapper/InsOrderMapper.xml | 2 inspect-server/src/main/resources/mapper/InsReportMapper.xml | 6 inspect-server/src/main/resources/mapper/InsSampleMapper.xml | 1 inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsReportServiceImpl.java | 141 +++++++++++++++++++++++++++------- inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java | 51 +----------- inspect-server/pom.xml | 6 + 6 files changed, 124 insertions(+), 83 deletions(-) diff --git a/inspect-server/pom.xml b/inspect-server/pom.xml index 90e5c68..021ca32 100644 --- a/inspect-server/pom.xml +++ b/inspect-server/pom.xml @@ -25,7 +25,11 @@ <artifactId>aspose-words</artifactId> <version>15.12.0</version> </dependency> - + <dependency> + <groupId>com.itextpdf</groupId> + <artifactId>itextpdf</artifactId> + <version>5.0.6</version> + </dependency> <dependency> <groupId>com.yuanchu.mom</groupId> <artifactId>framework</artifactId> diff --git a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java index 0570e78..4bb2475 100644 --- a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java +++ b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java @@ -823,27 +823,22 @@ List<TableRenderData> tables1 = new ArrayList<>(); TableRenderData tableRenderData = new TableRenderData(); tableRenderData.setRows(new ArrayList<>()); - double totalHeight = 0.0; // 鐢ㄤ簬璺熻釜褰撳墠琛ㄦ牸鐨勬�昏楂� - double heightThreshold = 8000.0; // 闃堝�硷紝渚嬪40cm*28px*15twips + double heightThreshold = 8000.0; // 闃堝�硷紝 List<RowRenderData> firstTwoRows = new ArrayList<>(); // 淇濆瓨鍓嶄袱琛屼互渚垮鍒跺埌鏂拌〃鏍� - - // 淇濆瓨鍓嶄袱琛屼互渚垮鍒跺埌鏂拌〃鏍� if (rows.size() >= 2) { firstTwoRows.add(rows.get(0)); firstTwoRows.add(rows.get(1)); } - for (RowRenderData row : rows) { double rowHeight = row.getRowStyle().getHeight(); // 鑾峰彇褰撳墠琛岀殑琛岄珮 totalHeight += rowHeight; // 鏇存柊鎬昏楂� - if (totalHeight >= heightThreshold) { // 鍒涘缓鏂拌〃鏍煎苟澶嶅埗鍓嶄袱琛� TableRenderData newTableRenderData = new TableRenderData(); newTableRenderData.setRows(new ArrayList<>(firstTwoRows)); - + //璁剧疆鏍峰紡 TableStyle tableStyle = new TableStyle(); tableStyle.setColWidths(new int[]{650, 1600, 2000, 750, 2800, 1100, 1100}); tableStyle.setWidth("10000"); @@ -858,7 +853,6 @@ tableStyle.setBottomBorder(borderStyle); tableRenderData.setTableStyle(tableStyle); newTableRenderData.setTableStyle(tableStyle); - tables1.add(tableRenderData); tableRenderData = newTableRenderData; totalHeight = rowHeight; @@ -866,6 +860,7 @@ tableRenderData.getRows().add(row); } if (!tableRenderData.getRows().isEmpty()) { + //璁剧疆鏍峰紡 TableStyle tableStyle = new TableStyle(); tableStyle.setColWidths(new int[]{650, 1600, 2000, 750, 2800, 1100, 1100}); tableStyle.setWidth("10000"); @@ -881,7 +876,6 @@ tableRenderData.setTableStyle(tableStyle); tables1.add(tableRenderData); } - tables1.forEach(table -> { Map<String, Object> tableMap = new HashMap<>(); tableMap.put("table", table); @@ -1293,14 +1287,6 @@ List<String> list = new ArrayList<>(maps.keySet()); for (int a = list.size() - 1; a >= 0; a--) { Map<String, Integer> v = maps.get(list.get(a)); - /* for (int j = 0; j < v.get("er") - v.get("sr") + 1; j++) { - if (v.get("ec") > v.get("sc")) { - TableTools.mergeCellsHorizonal(table, v.get("sr") + j, v.get("sc"), v.get("ec")); - } - } - if (v.get("er") > v.get("sr")) { - TableTools.mergeCellsVertically(table, v.get("sc"), v.get("sr"), v.get("er")); - }*/ for (int j = 0; j < v.get("er") - v.get("sr") + 1; j++) { if (v.get("ec") > v.get("sc")) { XWPFTableRow row = table.getRow(v.get("sr") + j); @@ -1338,11 +1324,11 @@ } catch (IOException e) { throw new RuntimeException(e); } + //澶勭悊涓嫳鏂囨崲琛岀殑闂 try { FileInputStream stream1 = new FileInputStream(path); XWPFDocument document1 = new XWPFDocument(stream1); List<XWPFTable> xwpfTables1 = document1.getTables(); - //澶勭悊涓嫳鏂囨崲琛岀殑闂 for (int i = 1; i < xwpfTables1.size() - (deviceList == null ? 1 : 2); i++) { for (int j = 0; j < xwpfTables1.get(i).getRows().size(); j++) { for (int k = 0; k < xwpfTables1.get(i).getRows().get(j).getTableCells().size(); k++) { @@ -1359,35 +1345,6 @@ } xwpfParagraph.setAlignment(ParagraphAlignment.CENTER); } - /*if (k == 2 || k == 3 || k == 4) { - if (k == 2 && xwpfTables1.get(i).getRows().get(j).getTableCells().get(k-1).getText().contains("@@")) { - XWPFTableCell cell = xwpfTables1.get(i).getRow(j).getCell(k); - CTTblWidth tblWidth = cell.getCTTc().addNewTcPr().addNewTcW(); - tblWidth.setType(STTblWidth.DXA); - tblWidth.setW(BigInteger.valueOf((int) (4.79 * 1440 / 2.54))); - } - if (k == 3 && xwpfTables1.get(i).getRows().get(j).getTableCells().get(k - 2).getText().contains("@@")) { - XWPFTableCell cell = xwpfTables1.get(i).getRow(j).getCell(k); - CTTblWidth tblWidth = cell.getCTTc().addNewTcPr().addNewTcW(); - tblWidth.setType(STTblWidth.DXA); - tblWidth.setW(BigInteger.valueOf((int) (1.49 * 1440 / 2.54))); - } - if (k == 4 && xwpfTables1.get(i).getRows().get(j).getTableCells().get(k - 3).getText().contains("@@")) { - XWPFTableCell cell = xwpfTables1.get(i).getRow(j).getCell(k); - CTTblWidth tblWidth = cell.getCTTc().addNewTcPr().addNewTcW(); - tblWidth.setType(STTblWidth.DXA); - tblWidth.setW(BigInteger.valueOf((int) (3.51 * 1440 / 2.54))); - } - } - if (xwpfTables1.get(i).getRows().get(j).getTableCells().get(k).getText().contains("@@")) { - String text = xwpfTables1.get(i).getRows().get(j).getTableCells().get(k).getText(); - text = text.replace("@@",""); - xwpfTables1.get(i).getRows().get(j).getTableCells().get(k).removeParagraph(0); - XWPFParagraph xwpfParagraph = xwpfTables1.get(i).getRows().get(j).getTableCells().get(k).addParagraph(); - XWPFRun run = xwpfParagraph.createRun(); - run.setText(text); - xwpfParagraph.setAlignment(ParagraphAlignment.CENTER); - }*/ } } } diff --git a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsReportServiceImpl.java b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsReportServiceImpl.java index b8f0b85..7033aec 100644 --- a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsReportServiceImpl.java +++ b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsReportServiceImpl.java @@ -1,13 +1,17 @@ package com.yuanchu.mom.service.impl; -import com.aspose.words.License; -import com.aspose.words.SaveFormat; +import com.aspose.words.*; import com.baomidou.mybatisplus.core.toolkit.ObjectUtils; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.deepoove.poi.XWPFTemplate; import com.deepoove.poi.data.Pictures; +import com.itextpdf.text.BadElementException; +import com.itextpdf.text.DocumentException; +import com.itextpdf.text.pdf.PdfContentByte; +import com.itextpdf.text.pdf.PdfReader; +import com.itextpdf.text.pdf.PdfStamper; import com.yuanchu.mom.common.GetLook; import com.yuanchu.mom.common.PrintChina; import com.yuanchu.mom.dto.ReportPageDto; @@ -25,10 +29,10 @@ import org.springframework.transaction.annotation.Transactional; import javax.annotation.Resource; -import java.io.File; -import java.io.FileOutputStream; -import java.io.IOException; -import java.io.InputStream; +import javax.imageio.ImageIO; +import java.awt.*; +import java.awt.image.BufferedImage; +import java.io.*; import java.nio.file.Files; import java.nio.file.Paths; import java.time.LocalDateTime; @@ -37,13 +41,13 @@ import java.util.concurrent.CompletableFuture; /** -* @author Administrator -* @description 閽堝琛ㄣ�恑ns_report(妫�楠屾姤鍛�)銆戠殑鏁版嵁搴撴搷浣淪ervice瀹炵幇 -* @createDate 2024-03-17 22:10:02 -*/ + * @author Administrator + * @description 閽堝琛ㄣ�恑ns_report(妫�楠屾姤鍛�)銆戠殑鏁版嵁搴撴搷浣淪ervice瀹炵幇 + * @createDate 2024-03-17 22:10:02 + */ @Service public class InsReportServiceImpl extends ServiceImpl<InsReportMapper, InsReport> - implements InsReportService{ + implements InsReportService { @Resource private GetLook getLook; @@ -98,16 +102,16 @@ String signatureUrl; try { signatureUrl = userMapper.selectById(insReport.getWriteUserId()).getSignatureUrl(); - }catch (Exception e){ + } catch (Exception e) { throw new ErrorException("鎵句笉鍒扮紪鍒朵汉鐨勭鍚�"); } //绯荤粺鐢熸垚鎶ュ憡鍦板潃 String url = insReport.getUrl(); //鎵嬪姩涓婁紶鎶ュ憡鍦板潃 String urlS = insReport.getUrlS(); - wordInsertUrl(new HashMap<String, Object>(){{ - put("writeUrl", Pictures.ofLocal(imgUrl+"/"+signatureUrl).create()); - }}, (urlS==null?url:urlS).replace("/word", wordUrl)); + wordInsertUrl(new HashMap<String, Object>() {{ + put("writeUrl", Pictures.ofLocal(imgUrl + "/" + signatureUrl).create()); + }}, (urlS == null ? url : urlS).replace("/word", wordUrl)); return insReportMapper.updateById(insReport); } @@ -121,7 +125,7 @@ } insReport.setExamineUserId(getLook.selectPowerByMethodAndUserId(null).get("userId"));//瀹℃牳浜� insReport.setExamineTime(LocalDateTime.now());//瀹℃牳鏃堕棿 - if (isExamine==0){ + if (isExamine == 0) { //濡傛灉瀹℃牳涓嶉�氳繃 insReport.setState(0);//鎻愪氦鐘舵�佹敼涓哄緟鎻愪氦 return insReportMapper.updateById(insReport); @@ -130,16 +134,16 @@ String signatureUrl; try { signatureUrl = userMapper.selectById(insReport.getExamineUserId()).getSignatureUrl(); - }catch (Exception e){ + } catch (Exception e) { throw new ErrorException("鎵句笉鍒板鏍镐汉鐨勭鍚�"); } //绯荤粺鐢熸垚鎶ュ憡鍦板潃 String url = insReport.getUrl(); //鎵嬪姩涓婁紶鎶ュ憡鍦板潃 String urlS = insReport.getUrlS(); - wordInsertUrl(new HashMap<String, Object>(){{ - put("examineUrl", Pictures.ofLocal(imgUrl+"/"+signatureUrl).create()); - }}, (urlS==null?url:urlS).replace("/word", wordUrl)); + wordInsertUrl(new HashMap<String, Object>() {{ + put("examineUrl", Pictures.ofLocal(imgUrl + "/" + signatureUrl).create()); + }}, (urlS == null ? url : urlS).replace("/word", wordUrl)); return insReportMapper.updateById(insReport); } @@ -154,7 +158,7 @@ } insReport.setRatifyUserId(getLook.selectPowerByMethodAndUserId(null).get("userId"));//鎵瑰噯浜� insReport.setRatifyTime(LocalDateTime.now());//鎵瑰噯鏃堕棿 - if (isRatify==0){ + if (isRatify == 0) { //濡傛灉鎵瑰噯涓嶉�氳繃 insReport.setState(0);//鎻愪氦鐘舵�佹敼涓哄緟鎻愪氦 return insReportMapper.updateById(insReport); @@ -163,27 +167,44 @@ String signatureUrl; try { signatureUrl = userMapper.selectById(insReport.getRatifyUserId()).getSignatureUrl(); - }catch (Exception e){ + } catch (Exception e) { throw new ErrorException("鎵句笉鍒版壒鍑嗕汉鐨勭鍚�"); } + //鑾峰彇鍦烘墍鐨勬姤鍛婁笓鐢ㄧ珷 String sealUrl; try { String laboratory = insOrderMapper.selectById(insReport.getInsOrderId()).getLaboratory(); sealUrl = insReportMapper.getLaboratoryByName(laboratory); - }catch (Exception e){ + } catch (Exception e) { throw new ErrorException("鎵句笉鍒版姤鍛婁笓鐢ㄧ珷"); } - if(sealUrl==null) throw new ErrorException("鎵句笉鍒版姤鍛婁笓鐢ㄧ珷"); + if (sealUrl == null) throw new ErrorException("鎵句笉鍒版姤鍛婁笓鐢ㄧ珷"); //绯荤粺鐢熸垚鎶ュ憡鍦板潃 String url = insReport.getUrl(); //鎵嬪姩涓婁紶鎶ュ憡鍦板潃 String urlS = insReport.getUrlS(); - wordInsertUrl(new HashMap<String, Object>(){{ - put("ratifyUrl", Pictures.ofLocal(imgUrl+"/"+signatureUrl).create()); - put("seal1", Pictures.ofLocal(imgUrl+"/"+sealUrl).create()); - put("seal2", Pictures.ofLocal(imgUrl+"/"+sealUrl).create()); - }}, (urlS==null?url:urlS).replace("/word", wordUrl)); - wordToPdf((urlS == null ? url : urlS).replace("/word", wordUrl)); + String finalUrl = (urlS == null ? url : urlS).replace("/word", wordUrl); + wordInsertUrl(new HashMap<String, Object>() {{ + put("ratifyUrl", Pictures.ofLocal(imgUrl + "/" + signatureUrl).create()); + put("seal1", Pictures.ofLocal(imgUrl + "/" + sealUrl).create()); + put("seal2", Pictures.ofLocal(imgUrl + "/" + sealUrl).create()); + }}, finalUrl); + wordToPdf(finalUrl); + + String replace = finalUrl.replace(".docx", ".pdf"); + CompletableFuture.supplyAsync(() -> { + try { + stamperCheckMarkPDF(replace,replace,sealUrl); + return null; + } catch (Exception e) { + throw new ErrorException("楠戠紳绔犳彃鍏ュけ璐�"); + } + }).thenAccept(res -> { + }).exceptionally(e -> { + e.printStackTrace(); + return null; + }); + InsOrder insOrder = new InsOrder(); insOrder.setId(insReportMapper.selectById(id).getInsOrderId()); insOrder.setState(4); @@ -218,7 +239,7 @@ }); } - public String wordToPdf(String wordPath,String pdfPath) { + public String wordToPdf(String wordPath, String pdfPath) { FileOutputStream os = null; try { //鍑瘉 涓嶇劧鍒囨崲鍚庢湁姘村嵃 @@ -261,8 +282,66 @@ } return null; } + + /** + * 鍒囧壊鍥剧墖 + * @param Path 鍥剧墖璺緞 + * @param n 鍒囧壊浠芥暟 + */ + public static com.itextpdf.text.Image[] slicingImages(String Path, int n) throws IOException, BadElementException { + com.itextpdf.text.Image[] nImage = new com.itextpdf.text.Image[n]; + ByteArrayOutputStream out = new ByteArrayOutputStream(); + BufferedImage img = ImageIO.read(new File(Path)); + int h = img.getHeight(); + int w = img.getWidth(); + + int sw = w/n; + for(int i=0;i<n;i++){ + BufferedImage subImg; + if(i==n-1){//鏈�鍚庡墿浣欓儴鍒� + subImg = img.getSubimage(i * sw, 0, w-i*sw, h); + }else {//鍓峮-1鍧楀潎鍖�鍒� + subImg = img.getSubimage(i * sw, 0, sw, h); + } + + ImageIO.write(subImg,Path.substring(Path.lastIndexOf('.')+1),out); + nImage[i] = com.itextpdf.text.Image.getInstance(out.toByteArray()); + out.flush(); + out.reset(); + } + return nImage; + } + + /** + * 鐩栭獞缂濈珷 + * + * @param infilePath 鍘烶DF璺緞 + * @param outFilePath 杈撳嚭PDF璺緞 + */ + public static void stamperCheckMarkPDF(String infilePath,String outFilePath,String picPath) throws IOException, DocumentException { + PdfReader reader = new PdfReader(infilePath);//閫夋嫨闇�瑕佸嵃绔犵殑pdf + PdfStamper stamp = new PdfStamper(reader, new FileOutputStream(outFilePath));//鍔犲畬鍗扮珷鍚庣殑pdf + + com.itextpdf.text.Rectangle pageSize = reader.getPageSize(1);//鑾峰緱绗竴椤� + float height = pageSize.getHeight(); + float width = pageSize.getWidth(); + + int nums = reader.getNumberOfPages(); + com.itextpdf.text.Image[] nImage = slicingImages(picPath,nums);//鐢熸垚楠戠紳绔犲垏鍓插浘鐗� + + + for(int n=1;n<=nums;n++){ + PdfContentByte over = stamp.getOverContent(n);//璁剧疆鍦ㄧ鍑犻〉鎵撳嵃鍗扮珷 + com.itextpdf.text.Image img = nImage[n-1];//閫夋嫨鍥剧墖 + img.setAbsolutePosition(width-img.getWidth(),height/2-img.getHeight()/2);//鎺у埗鍥剧墖浣嶇疆 + over.addImage(img); + } + stamp.close(); + } } + + diff --git a/inspect-server/src/main/resources/mapper/InsOrderMapper.xml b/inspect-server/src/main/resources/mapper/InsOrderMapper.xml index e391586..2b23894 100644 --- a/inspect-server/src/main/resources/mapper/InsOrderMapper.xml +++ b/inspect-server/src/main/resources/mapper/InsOrderMapper.xml @@ -96,7 +96,7 @@ ir.url, ir.url_s, (select count(*) from ins_sample isa2 - where isa2.ins_order_id = io.id) sample_num, + where isa2.ins_order_id = io.id and isa2.sample_code NOT REGEXP '/') sample_num, concat(ROUND((select count(*) from ins_product ip where state = 1 and ins_result is not null and ip.ins_sample_id in (select id from ins_sample where ins_sample.ins_order_id= io.id )) / (select count(*) from ins_product ip2 diff --git a/inspect-server/src/main/resources/mapper/InsReportMapper.xml b/inspect-server/src/main/resources/mapper/InsReportMapper.xml index d479c7c..f77f31c 100644 --- a/inspect-server/src/main/resources/mapper/InsReportMapper.xml +++ b/inspect-server/src/main/resources/mapper/InsReportMapper.xml @@ -35,11 +35,11 @@ </if> </select> <select id="getLaboratoryByName" resultType="java.lang.String"> - select s.address from `center-lims`.seal s - left join `center-lims`.laboratory l on s.lab_id = l.id + select s.address from seal s + left join laboratory l on s.lab_id = l.id where l.laboratory_name = #{name} and s.type = '鎶ュ憡绫诲瀷' - order by l.create_time desc + order by s.create_time desc limit 1 </select> </mapper> diff --git a/inspect-server/src/main/resources/mapper/InsSampleMapper.xml b/inspect-server/src/main/resources/mapper/InsSampleMapper.xml index 457fc59..5b22c2d 100644 --- a/inspect-server/src/main/resources/mapper/InsSampleMapper.xml +++ b/inspect-server/src/main/resources/mapper/InsSampleMapper.xml @@ -163,6 +163,7 @@ and state = 1 and ins_fiber_id is null and ins_fibers_id is null + and isa.sample_code NOT REGEXP '/' </select> <select id="getInsOrderAndSample" resultMap="sampleDto"> select isa.*, -- Gitblit v1.9.3