From ff942c3f9f6fe84f6d141c87f47e58bf70273d40 Mon Sep 17 00:00:00 2001 From: yujian <yujian@123.com> Date: 星期五, 24 五月 2019 15:13:42 +0800 Subject: [PATCH] 动态 二维码样式修改 已下架商品不提供分享 --- fanli/src/main/java/com/yeshi/fanli/util/ImageUtil.java | 134 +++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 130 insertions(+), 4 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/util/ImageUtil.java b/fanli/src/main/java/com/yeshi/fanli/util/ImageUtil.java index 252ad09..fd05368 100644 --- a/fanli/src/main/java/com/yeshi/fanli/util/ImageUtil.java +++ b/fanli/src/main/java/com/yeshi/fanli/util/ImageUtil.java @@ -1094,7 +1094,7 @@ return originalImage; } - static BufferedImage roundImage(BufferedImage srcImage, int cornerRadius) { // 鍗婂緞 + public static BufferedImage roundImage(BufferedImage srcImage, int cornerRadius) { // 鍗婂緞 int width = srcImage.getWidth(); int height = srcImage.getHeight(); BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_ARGB); @@ -1176,6 +1176,121 @@ } + + /** + * 澶村儚鍔犵櫧搴曞浘 閭�璇峰ソ鍙嬪浘鐗� + * @param urlInputStream + * @param portraitInputStream + * @param erCodeInputStream + * @param targetPath + * @param inviteCode + * @throws IOException + */ + public static void inviteFriendImgWhite(InputStream urlInputStream, InputStream portraitInputStream, + InputStream erCodeInputStream, String targetPath,String inviteCode) throws IOException { + inviteFriendImgWhite(urlInputStream, portraitInputStream, erCodeInputStream, targetPath, 260, 908, 230, inviteCode); + } + + + /** + * 澶村儚鍔犵櫧搴曞浘 閭�璇峰ソ鍙嬪浘鐗� -鑷畾涔変簩缁寸爜浣嶇疆 + * @param urlInputStream + * @param portraitInputStream + * @param erCodeInputStream + * @param targetPath + * @param inviteCode + * @throws IOException + */ + public static void inviteFriendImgWhitecustom(InputStream urlInputStream, InputStream portraitInputStream, + InputStream erCodeInputStream, String targetPath, Integer pX, Integer pY, Integer size, String inviteCode) throws IOException { + inviteFriendImgWhite(urlInputStream, portraitInputStream, erCodeInputStream, targetPath, pX, pY, size, inviteCode); + } + + + /** + * 閭�璇峰ソ鍙嬪浘鐗囧姞涓婂ご鍍忓姞涓婄櫧搴� + */ + public static void inviteFriendImgWhite(InputStream urlInputStream, InputStream portraitInputStream, + InputStream erCodeInputStream, String targetPath, Integer pX, Integer pY, Integer size, String inviteCode) throws IOException { + + if (pX == null) { + pX = 260; + } + + if (pY == null) { + pY = 908; + } + + if (size == null) { + size = 230; + } + + + BufferedImage bgImage = ImageIO.read(urlInputStream); + final BufferedImage targetImg = new BufferedImage(bgImage.getWidth(), bgImage.getHeight(), + BufferedImage.TYPE_INT_RGB); + HashMap<Key, Object> mapH = new HashMap<Key, Object>(); + mapH.put(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);// 鎶楅敮榻柯狅紙鎶楅敮榻挎�诲紑鍏筹級聽聽 + mapH.put(RenderingHints.KEY_TEXT_ANTIALIASING, RenderingHints.VALUE_TEXT_ANTIALIAS_GASP);// 鏂囧瓧鎶楅敮榻柯� + + // 鐢� 鑳屾櫙鍥剧墖 + final Graphics2D g2d = targetImg.createGraphics(); + g2d.drawImage(bgImage, 0, 0, bgImage.getWidth(), bgImage.getHeight(), null); + g2d.setRenderingHints(mapH); + + // 鐢� 浜岀淮鐮� + BufferedImage qrCodeImage = ImageIO.read(erCodeInputStream); + qrCodeImage = ImageUtil.qrCodeImage(g2d, qrCodeImage, pX, pY, size, size); + + int portraitSize = size * 5 / 23; + int pPX = pX + size / 2 - portraitSize / 2; + int pPY = pY + size / 2 - portraitSize / 2; + + // 澶村儚鐧借壊杈规 + g2d.fillRoundRect(pPX-4, pPY-4,portraitSize+8, portraitSize + 8, 5, 5); + g2d.setRenderingHints(mapH); + // 鐢� 澶村儚 + BufferedImage portraitImg = ImageIO.read(portraitInputStream); + portraitImg = ImageUtil.zoomInImage(portraitImg, portraitSize, portraitSize); + portraitImg = ImageUtil.roundImage(portraitImg, 10); + g2d.drawImage(portraitImg, pPX, pPY, portraitSize, portraitSize, null); + + + // 鐢婚個璇风爜(閭�璇风爜鐨勫ぇ灏忎笌瀛椾綋鍥哄畾) + if (!StringUtil.isNullOrEmpty(inviteCode)) { + String st = "閭�璇风爜锛�" + inviteCode; + String os = System.getProperty("os.name"); + String fontBoldPath = "/usr/share/fonts/PingFang_Medium.ttf"; + if (os.toLowerCase().startsWith("win")) { + fontBoldPath = "D:/PingFang_Medium.ttf"; + } + + Font boldFont = null; + try { + boldFont = Font.createFont(Font.PLAIN, new File(fontBoldPath)).deriveFont(36.0f); + } catch (FontFormatException e) { + e.printStackTrace(); + } + + g2d.setFont(boldFont); + g2d.getFontMetrics(boldFont); + g2d.setColor(new Color(0, 0, 0)); + + int ax = pX - 30; + int ay = pY + size + 118; + + g2d.setColor(new Color(0, 0, 0)); + g2d.drawString(st, ax, ay); + + } + + OutputStream out = new FileOutputStream(new File(targetPath)); + ImageIO.write(targetImg, "JPEG", out); + out.flush(); + out.close(); + } + + /** * 缁樺埗閭�璇烽棶鍊欏浘 * @param bgPigInStream 鑳屾櫙鍥� @@ -1203,6 +1318,7 @@ final Graphics2D g2d = targetImg.createGraphics(); g2d.drawImage(bgImage, 0, 0, bgImage.getWidth(), bgImage.getHeight(), null); g2d.setRenderingHints(mapH); + g2d.setBackground(Color.WHITE); // 鐢� 钂欏眰 BufferedImage mengCeng = ImageIO @@ -1217,23 +1333,32 @@ int size = 210; // 230 // 鐢� 浜岀淮鐮� BufferedImage qrCodeImage = ImageIO.read(erCodeInStream); - qrCodeImage = ImageUtil.qrCodeImage(g2d, qrCodeImage, pX, pY, size, size); // 浜岀淮鐮侀暱瀹� + qrCodeImage = qrCodeImage(g2d, qrCodeImage, pX, pY, size, size); // 浜岀淮鐮侀暱瀹� // 230*230 // 鐢� 澶村儚 int portraitSize = size * 5 / 23; int pPX = pX + size / 2 - portraitSize / 2; int pPY = pY + size / 2 - portraitSize / 2; + + // 澶村儚鐧借壊杈规 + g2d.fillRoundRect(pPX-4, pPY-4,portraitSize+8, portraitSize + 8, 5, 5); + g2d.setRenderingHints(mapH); + BufferedImage portraitImg = ImageIO.read(portraitInStream); - portraitImg = ImageUtil.portraitImg(g2d, portraitImg, pPX, pPY, portraitSize, portraitSize);// 澶村儚闀垮 + portraitImg = ImageUtil.zoomInImage(portraitImg, portraitSize, portraitSize); + portraitImg = ImageUtil.roundImage(portraitImg, 10); + g2d.drawImage(portraitImg, pPX, pPY, portraitSize, portraitSize, null); + - // 鏂囧瓧鐧借壊 + // 瀛椾綋鐧借壊 Color color = new Color(255, 255, 255); String os = System.getProperty("os.name"); String fontBoldPath = "/usr/share/fonts/yahei.ttf"; if (os.toLowerCase().startsWith("win")) { fontBoldPath = "C:/yahei.ttf"; } + Font boldFont = null; // 鐢婚個璇风爜(閭�璇风爜鐨勫ぇ灏忎笌瀛椾綋鍥哄畾) @@ -1349,4 +1474,5 @@ out.flush(); out.close(); } + } -- Gitblit v1.8.0