From fa5a54ef993f05cf353e13652eec4bb15e2a9d66 Mon Sep 17 00:00:00 2001
From: yujian <yujian@123.com>
Date: 星期一, 20 五月 2019 09:27:39 +0800
Subject: [PATCH] 邀请素材管理
---
fanli/src/main/java/com/yeshi/fanli/util/ImageUtil.java | 282 +++++++++++++++++++++++++++++++++++++++++++++++++-------
1 files changed, 245 insertions(+), 37 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 c080a66..f9ac319 100644
--- a/fanli/src/main/java/com/yeshi/fanli/util/ImageUtil.java
+++ b/fanli/src/main/java/com/yeshi/fanli/util/ImageUtil.java
@@ -22,12 +22,15 @@
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
+import java.util.Date;
import java.util.HashMap;
import java.util.List;
import javax.imageio.ImageIO;
+import org.yeshi.utils.DateLunarUtil;
import org.yeshi.utils.HttpUtil;
+import org.yeshi.utils.entity.DateInfo;
import com.yeshi.fanli.entity.bus.activity.RecommendActivityTaoBaoGoods;
import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBrief;
@@ -446,7 +449,7 @@
font = font.deriveFont(50.0f);
g2d.setFont(font);
g2d.setColor(new Color(229, 0, 93));
-// g2d.drawString("杩斿埄鍒告彁閱掓偍", 312, 1118 + 40);
+ // g2d.drawString("杩斿埄鍒告彁閱掓偍", 312, 1118 + 40);
g2d.setColor(new Color(102, 102, 102));
g2d.drawString("闀挎寜璇嗗埆浜岀淮鐮侀鍙栦紭鎯犲埜", 312, 1118 + 77);
@@ -472,7 +475,7 @@
return null;
}
-
+
/**
* 缁樺埗澶х殑鍟嗗搧鍔ㄦ�佸垎浜浘
*
@@ -527,7 +530,7 @@
}
g2d.setFont(font);
try {
-// g2d.setColor(new Color(153, 153, 153));
+ // g2d.setColor(new Color(153, 153, 153));
// 鐢荤涓�寮�
for (int i = 0; i < goodsList.size(); i++) {
TaoBaoGoodsBrief goods = goodsList.get(i);
@@ -556,14 +559,14 @@
g2d.drawString("楼", 70, 650);
boldFont = boldFont.deriveFont(42.0f);
g2d.setFont(boldFont);
- g2d.drawString(couplePrice+"", 90, 650);
+ g2d.drawString(couplePrice + "", 90, 650);
// 鐢诲師浠�
g2d.setColor(new Color(102, 102, 102));
font = font.deriveFont(24.0f);
g2d.setFont(font);
- String zkPrice = new BigDecimal((couplePrice+"").replace("楼", "")).add(goods.getCouponAmount())
+ String zkPrice = new BigDecimal((couplePrice + "").replace("楼", "")).add(goods.getCouponAmount())
.toString();
g2d.drawString("楼 " + zkPrice, 70, 650 + 33);
@@ -575,12 +578,12 @@
String quanString = "";
BigDecimal withNoZera = MoneyBigDecimalUtil.getWithNoZera(goods.getCouponAmount());
-
+
if (!withNoZera.toString().endsWith("0")) {
-
+
// 鐢诲埜鍙充晶
- BufferedImage quanRight = ImageIO
- .read(ImageUtil.class.getClassLoader().getResourceAsStream("image/fanli_quan_right.png"));
+ BufferedImage quanRight = ImageIO.read(
+ ImageUtil.class.getClassLoader().getResourceAsStream("image/fanli_quan_right.png"));
quanRight = zoomInImage(quanRight, 12, 60);
g2d.setColor(new Color(241, 66, 66));
g2d.drawImage(quanRight, topX + 630 - quanRight.getWidth(), topY + 630 - quanRight.getHeight(),
@@ -604,8 +607,8 @@
topY + 630 + 42 - quanRight.getHeight());
// 鐢诲埜宸︿晶
- BufferedImage quanLeft = ImageIO
- .read(ImageUtil.class.getClassLoader().getResourceAsStream("image/fanli_quan_left.png"));
+ BufferedImage quanLeft = ImageIO.read(
+ ImageUtil.class.getClassLoader().getResourceAsStream("image/fanli_quan_left.png"));
quanLeft = zoomInImage(quanLeft, 12, 60);
g2d.drawImage(quanLeft, topX + 630 - quanRight.getWidth() - textLength - quanLeft.getWidth(),
topY + 630 - quanRight.getHeight(), null);
@@ -647,12 +650,12 @@
String quanString = "";
BigDecimal withNoZera = MoneyBigDecimalUtil.getWithNoZera(goods.getCouponAmount());
-
+
if (!withNoZera.toString().endsWith("0")) {
-
+
// 鐢诲埜鍙充晶
- BufferedImage quanRight = ImageIO
- .read(ImageUtil.class.getClassLoader().getResourceAsStream("image/fanli_quan_right.png"));
+ BufferedImage quanRight = ImageIO.read(
+ ImageUtil.class.getClassLoader().getResourceAsStream("image/fanli_quan_right.png"));
quanRight = zoomInImage(quanRight, 8, 40);
g2d.setColor(new Color(241, 66, 66));
g2d.drawImage(quanRight, topX + 315 - quanRight.getWidth(), topY + 315 - quanRight.getHeight(),
@@ -660,9 +663,9 @@
// 鐢诲埜鐨勫唴瀹�
g2d.setColor(new Color(229, 0, 93));
-
+
quanString = " " + withNoZera + "鍏冨埜 ";
-
+
font = font.deriveFont(24.0f);
g2d.setFont(font);
FontMetrics fm = g2d.getFontMetrics(font);
@@ -678,13 +681,13 @@
topY + 315 + 28 - quanRight.getHeight());
// 鐢诲埜宸︿晶
- BufferedImage quanLeft = ImageIO
- .read(ImageUtil.class.getClassLoader().getResourceAsStream("image/fanli_quan_left.png"));
+ BufferedImage quanLeft = ImageIO.read(
+ ImageUtil.class.getClassLoader().getResourceAsStream("image/fanli_quan_left.png"));
quanLeft = zoomInImage(quanLeft, 8, 40);
g2d.drawImage(quanLeft, topX + 315 - quanRight.getWidth() - textLength - quanLeft.getWidth(),
topY + 315 - quanRight.getHeight(), null);
}
-
+
}
}
@@ -702,10 +705,10 @@
if (portrait != null) {
BufferedImage portraitImg = ImageIO.read(portrait);
// 鏀剧缉澶у皬
- portraitImg = zoomInImage(portraitImg, 40,40);
+ portraitImg = zoomInImage(portraitImg, 40, 40);
// 鍦嗚
portraitImg = roundImage(portraitImg, 10);
-
+
g2d.drawImage(portraitImg, 70 + (qrcodeImage.getWidth() - portraitImg.getWidth()) / 2,
1092 + (qrcodeImage.getHeight() - portraitImg.getHeight()) / 2, null);
}
@@ -713,27 +716,25 @@
font = font.deriveFont(50.0f);
g2d.setFont(font);
g2d.setColor(new Color(229, 0, 93));
-// g2d.drawString("杩斿埄鍒告彁閱掓偍", 312, 1118 + 40);
+ // g2d.drawString("杩斿埄鍒告彁閱掓偍", 312, 1118 + 40);
g2d.setColor(new Color(102, 102, 102));
g2d.drawString("闀挎寜璇嗗埆浜岀淮鐮佸厤璐归鍒�", 312, 1150);
-
+
g2d.setColor(new Color(102, 102, 102));
g2d.drawString("鍏�", 1000, 1150);
-
-
+
g2d.setColor(new Color(229, 0, 93));
- g2d.drawString(goodsList.size()+"", 1055, 1150);
-
-
+ g2d.drawString(goodsList.size() + "", 1055, 1150);
+
g2d.setColor(new Color(102, 102, 102));
g2d.drawString("涓晢鍝�", 1090, 1150);
-
+
// 鎻愮ず璇�
BufferedImage tips = ImageIO
.read(ImageUtil.class.getClassLoader().getResourceAsStream("image/share/tips1.png"));
- tips = zoomInImage(tips,850, 65);
- g2d.drawImage(tips, 312,1190, null);
+ tips = zoomInImage(tips, 850, 65);
+ g2d.drawImage(tips, 312, 1190, null);
g2d.dispose();
@@ -751,7 +752,6 @@
return null;
}
-
// 鐢诲晢鍝佸垎浜浘
public static InputStream drawGoodsShareImgHCJ(InputStream qrcodeStream, InputStream portrait,
@@ -994,8 +994,8 @@
// 閭�璇峰ソ鍙嬪浘鐗�
public static void inviteFriendImg(InputStream urlInputStream, InputStream portraitInputStream,
- InputStream erCodeInputStream, String targetPath) throws IOException {
- inviteFriendImg(urlInputStream, portraitInputStream, erCodeInputStream, targetPath, 260, 908, 230);
+ InputStream erCodeInputStream, String targetPath,String inviteCode) throws IOException {
+ inviteFriendImg(urlInputStream, portraitInputStream, erCodeInputStream, targetPath, 260, 908, 230, inviteCode);
}
/**
@@ -1010,11 +1010,14 @@
* -浜岀淮鐮佺殑绾靛潗鏍�
* @param size
* -浜岀淮鐮佺殑灏哄
+ * @param inviteCode
+ * -閭�璇风爜
* @throws IOException
*/
// 閭�璇峰ソ鍙嬪浘鐗�
public static void inviteFriendImg(InputStream urlInputStream, InputStream portraitInputStream,
- InputStream erCodeInputStream, String targetPath, int pX, int pY, int size) throws IOException {
+ InputStream erCodeInputStream, String targetPath, int pX, int pY, int size, String inviteCode)
+ throws IOException {
BufferedImage bgImage = ImageIO.read(urlInputStream);
final BufferedImage targetImg = new BufferedImage(bgImage.getWidth(), bgImage.getHeight(),
BufferedImage.TYPE_INT_RGB);
@@ -1039,6 +1042,37 @@
int pPX = pX + size / 2 - portraitSize / 2;
int pPY = pY + size / 2 - portraitSize / 2;
portraitImg = ImageUtil.portraitImg(g2d, portraitImg, pPX, pPY, portraitSize, portraitSize);// 澶村儚闀垮
+
+ // 鐢婚個璇风爜(閭�璇风爜鐨勫ぇ灏忎笌瀛椾綋鍥哄畾)
+ if (!StringUtil.isNullOrEmpty(inviteCode)) {
+ String st = "閭�璇风爜锛�" + inviteCode;
+ int width = bgImage.getWidth();
+ 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.setColor(new Color(0, 0, 0));
+
+ FontMetrics fm = g2d.getFontMetrics(boldFont);
+ int textLength = fm.stringWidth(st);
+
+ int ax = (width - textLength) / 2;
+ int ay = bgImage.getHeight() - 92 + boldFont.getSize() / 2 - 5;
+
+ g2d.setColor(new Color(0, 0, 0));
+ g2d.drawString(st, ax, ay);
+
+ }
OutputStream out = new FileOutputStream(new File(targetPath));
ImageIO.write(targetImg, "JPEG", out);
@@ -1074,7 +1108,7 @@
gs.dispose();
return image;
}
-
+
public static int saveToImgByInputStream(InputStream inputStream, String imgPath, String imgName) {
int stateInt = 1;
try {
@@ -1141,4 +1175,178 @@
return new int[] { width, height };
}
+
+ /**
+ * 缁樺埗閭�璇烽棶鍊欏浘
+ * @param bgPigInStream 鑳屾櫙鍥�
+ * @param portraitInStream 鐢ㄦ埛澶村儚
+ * @param erCodeInStream 浜岀淮鐮�
+ * @param targetPath 璺緞
+ * @param inviteCode 閭�璇风爜
+ * @param content 鏂囧瓧鍐呭
+ * @param date 鏄剧ず鏃ュ巻
+ * @throws IOException
+ */
+ public static void drawInviteToGreet(InputStream bgPigInStream, InputStream portraitInStream,
+ InputStream erCodeInStream, String targetPath, String inviteCode, String content, Date date)
+ throws IOException {
+ // 鑳屾櫙鍥剧墖
+ BufferedImage bgImage = ImageIO.read(bgPigInStream);
+ 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 mengCeng = ImageIO
+ .read(ImageUtil.class.getClassLoader().getResourceAsStream("image/invite/mc.png"));
+ g2d.drawImage(mengCeng, 0, bgImage.getHeight() / 2, bgImage.getWidth(), bgImage.getHeight() / 2, null);
+
+ int width = bgImage.getWidth();
+ int height = bgImage.getHeight();
+
+ int pX = width - 250;
+ int pY = height - 290; // 320
+ int size = 210; // 230
+ // 鐢� 浜岀淮鐮�
+ BufferedImage qrCodeImage = ImageIO.read(erCodeInStream);
+ qrCodeImage = ImageUtil.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;
+ BufferedImage portraitImg = ImageIO.read(portraitInStream);
+ portraitImg = ImageUtil.portraitImg(g2d, portraitImg, pPX, pPY, portraitSize, portraitSize);// 澶村儚闀垮
+
+ // 鏂囧瓧鐧借壊
+ 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 = "D:/yahei.ttf";
+ }
+
+ Font boldFont = null;
+ // 鐢婚個璇风爜(閭�璇风爜鐨勫ぇ灏忎笌瀛椾綋鍥哄畾)
+ if (!StringUtil.isNullOrEmpty(inviteCode)) {
+ String st = "閭�璇风爜锛�" + inviteCode;
+ try {
+ boldFont = Font.createFont(Font.PLAIN, new File(fontBoldPath)).deriveFont(32.0f);
+ } catch (FontFormatException e) {
+ e.printStackTrace();
+ }
+ g2d.setFont(boldFont);
+ g2d.setColor(new Color(255, 255, 255));
+
+ FontMetrics fm = g2d.getFontMetrics(boldFont);
+ int textLength = fm.stringWidth(st);
+
+ int ax = (width - textLength) - 30;
+ int ay = bgImage.getHeight() - 50 + boldFont.getSize() / 2 - 5;
+
+ g2d.setColor(new Color(255, 255, 255));
+ g2d.drawString(st, ax, ay);
+ }
+
+ // 宸﹁竟璺�
+ int padding_left = 30;
+
+ // 鏃ュ巻
+ try {
+ if (date == null) {
+ date = new Date();
+ }
+
+ boldFont = Font.createFont(Font.PLAIN, new File(fontBoldPath)).deriveFont(36.0f);
+ g2d.setFont(boldFont);
+ g2d.setColor(color);
+ g2d.setRenderingHints(mapH);
+
+ DateInfo dateInfo = DateLunarUtil.getDateInfo(date);
+ // 鍐滃巻
+ g2d.drawString(dateInfo.getLunar_month() + dateInfo.getLunar_day(), padding_left, height - 80);
+ // 澶╁共鍦版敮
+ g2d.drawString(dateInfo.getAgenary_month() + " " + dateInfo.getAgenary_day(), padding_left, height - 140);
+
+ // 褰撳墠鏃ユ湡
+ Font boldFontMax = Font.createFont(Font.PLAIN, new File(fontBoldPath)).deriveFont(100.0f);
+ g2d.setFont(boldFontMax);
+
+ if (dateInfo.getDay() < 10) {
+ g2d.drawString("0" + dateInfo.getDay().toString(), padding_left, height - 200);
+ } else {
+ g2d.drawString(dateInfo.getDay().toString(), padding_left, height - 200);
+ }
+
+ String theDate = "";
+ if (dateInfo.getMonth() < 10) {
+ theDate = "/0";
+ } else {
+ theDate = "/";
+ }
+ theDate += dateInfo.getMonth() + "/" + dateInfo.getYear() + " " + dateInfo.getWeekDay();
+ g2d.setFont(boldFont);
+ g2d.drawString(theDate, padding_left + boldFontMax.getSize() + 15, height - 200);
+
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+
+ if (!StringUtil.isNullOrEmpty(content)) {
+ // 鏂囧瓧鍐呭
+ try {
+ boldFont = Font.createFont(Font.PLAIN, new File(fontBoldPath)).deriveFont(36.0f);
+ g2d.setFont(boldFont);
+ g2d.setColor(color);
+ g2d.setRenderingHints(mapH);
+
+ int lineHeight = 70;
+ int lineTextLength = 19;
+
+ if (content.length() <= lineTextLength) {
+ g2d.drawString(content, padding_left, height - 350);
+ } else {
+ String text = "";
+ int mod = content.length() % lineTextLength;
+ if (mod == 0) {
+ text = content.substring(content.length() - lineTextLength, content.length());
+ content = content.substring(0, content.length() - lineTextLength);
+ } else {
+ text = content.substring(content.length() - mod, content.length());
+ content = content.substring(0, content.length() - mod);
+ }
+ g2d.drawString(text, padding_left, height - 350);
+
+ int i = 1;
+ while (true) {
+ if (content.length() <= 17) {
+ g2d.drawString(content, padding_left, height - 350 - lineHeight * i);
+ break;
+ } else {
+ text = content.substring(content.length() - lineTextLength, content.length());
+ content = content.substring(0, content.length() - lineTextLength);
+ g2d.drawString(text, padding_left, height - 350 - lineHeight * i);
+ i++;
+ }
+ }
+ }
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ }
+
+ OutputStream out = new FileOutputStream(new File(targetPath));
+ ImageIO.write(targetImg, "JPEG", out);
+ out.flush();
+ out.close();
+ }
}
--
Gitblit v1.8.0