java如何添加自定义的图片_java代码将图片加上自定义水印 -4

java代码将图片加上自定义水印,然后生成了新的图片

import java.awt.Color;

import java.awt.Font;

import java.awt.Graphics2D;

import java.awt.Image;

import java.awt.image.BufferedImage;

import java.io.File;

import java.io.FileOutputStream;

import javax.imageio.ImageIO;

/** * @author :liu.lu

* @version 创建时间:2018年4月24日 下午9:04:20

Description:

*/

public class WaterMarkUtils {

/**

* @param srcImgPath 源图片路径

* @param tarImgPath 保存的图片路径

* @param waterMarkContent 水印内容

* @param markContentColor 水印颜色

* @param font 水印字体

*/

public void addWaterMark(String srcImgPath, String tarImgPath, String waterMarkContent,Color markContentColor,Font font) {

try {

// 读取原图片信息

File srcImgFile = new File(srcImgPath);//得到文件

Image srcImg = ImageIO.read(srcImgFile);//文件转化为图片

int srcImgWidth = srcImg.getWidth(null);//获取图片的宽

int srcImgHeight = srcImg.getHeight(null);//获取图片的高

// 加水印

BufferedImage bufImg = new BufferedImage(srcImgWidth, srcImgHeight, BufferedImage.TYPE_INT_RGB);

Graphics2D g = bufImg.createGraphics();

g.drawImage(srcImg, 0, 0, srcImgWidth, srcImgHeight, null);

g.setColor(markContentColor); //根据图片的背景设置水印颜色

g.setFont(font);              //设置字体

//设置水印的坐标

int x = srcImgWidth - 2*getWatermarkLength(waterMarkContent, g);

int y = srcImgHeight - 2*getWatermarkLength(waterMarkContent, g);

g.drawString(waterMarkContent, x, y);  //画出水印

g.dispose();

// 输出图片

FileOutputStream outImgStream = new FileOutputStream(tarImgPath);

ImageIO.write(bufImg, "jpg", outImgStream);

System.out.println("添加水印完成");

outImgStream.flush();

outImgStream.close();

} catch (Exception e) {

// TODO: handle exception

}

}

public int getWatermarkLength(String waterMarkContent, Graphics2D g) {

return g.getFontMetrics(g.getFont()).charsWidth(waterMarkContent.toCharArray(), 0, waterMarkContent.length());

}

public static void main(String[] args) {

Font font = new Font("微软雅黑", Font.PLAIN, 35);                    //水印字体

String srcImgPath="D:\\temp\\picture\\魔方.jpg"; //源图片地址

String tarImgPath="D:/temp/t.jpg"; //待存储的地址

String waterMarkContent="我爱生活";  //水印内容

Color color=new Color(135,206,250,130);            //水印图片色彩以及透明度

new WaterMarkUtils().addWaterMark(srcImgPath, tarImgPath, waterMarkContent,color,font);

}

}

测试结果:

原图片:

1c4cbcf4027d?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

加完之后:

1c4cbcf4027d?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

下面在给大家弄个之前在linux上弄的转换图片脚本 centos7系统。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java EasyExcel 是一款非常好用的 Excel 操作工具,提供了丰富的 API 接口,可以方便地进行 Excel 文件的读写操作。而在实际应用中,我们可能需要在 Excel 文件中添加一些自定义水印,以便于区分文件的来源或者保护文件的安全性。本文将介绍如何使用 Java EasyExcel 自定义水印插件。 1. 创建水印插件类 首先,我们需要创建一个自定义水印插件类,实现 com.alibaba.excel.write.handler.WriteHandler 接口,该接口提供了 beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) 方法,允许我们在生成 Excel 文件之前对 Sheet 进行一些自定义操作。以下是一个简单的水印插件类示例: ```java public class WaterMarkHandler implements WriteHandler { private String waterMark; // 水印内容 public WaterMarkHandler(String waterMark) { this.waterMark = waterMark; } @Override public void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) { Sheet sheet = writeSheetHolder.getSheet(); Drawing<?> drawing = sheet.createDrawingPatriarch(); // 创建水印文本框 ClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, 0, 0, 10, 10); Textbox textBox = drawing.createTextbox(anchor); // 设置文本框属性 textBox.setLineStyleColor(255, 255, 255); textBox.setFillColor(255, 255, 255); textBox.setVerticalAlignment(VerticalAlignment.CENTER); textBox.setHorizontalAlignment(HorizontalAlignment.CENTER); textBox.setText(new HSSFRichTextString(waterMark)); } @Override public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) { // do nothing } } ``` 在上面的代码中,我们通过实现 beforeSheetCreate() 方法,在生成 Sheet 之前创建了一个水印文本框,并设置了文本框的属性和文本内容。 2. 使用水印插件 在使用 Java EasyExcel 生成 Excel 文件时,我们可以将上面定义的 WaterMarkHandler 类作为参数传递给 ExcelWriter 的构造函数,从而实现添加自定义水印的功能。以下是一个简单的示例: ```java public void writeExcelWithWaterMark(OutputStream outputStream, List<List<String>> data, String waterMark) throws IOException { ExcelWriter writer = new ExcelWriter(outputStream, ExcelTypeEnum.XLSX); WriteSheet sheet = new WriteSheet(); sheet.setSheetName("Sheet1"); sheet.setClazz(String.class); sheet.setHead(Collections.emptyList()); sheet.setTableStyle(new TableStyle()); sheet.setWriteHandler(new WaterMarkHandler(waterMark)); // 设置水印插件 writer.write1(data, sheet); writer.finish(); } ``` 在上面的代码中,我们通过调用 setWriteHandler() 方法将 WaterMarkHandler 对象传递给 WriteSheet,从而在生成 Excel 文件时添加自定义水印。完整的代码实现可以参考下面的示例: ```java import com.alibaba.excel.ExcelWriter; import com.alibaba.excel.metadata.TableStyle; import com.alibaba.excel.metadata.VerticalAlignment; import com.alibaba.excel.metadata.WriteSheet; import com.alibaba.excel.write.handler.WriteHandler; import com.alibaba.excel.write.handler.WriteHandlerHolder; import com.alibaba.excel.write.handler.WriteWorkbookHolder; import com.alibaba.excel.write.handler.context.CellWriteHandlerContext; import com.alibaba.excel.write.handler.context.RowWriteHandlerContext; import com.alibaba.excel.write.handler.context.SheetWriteHandlerContext; import org.apache.poi.hssf.usermodel.HSSFRichTextString; import org.apache.poi.ss.usermodel.HorizontalAlignment; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.VerticalAlignment; import org.apache.poi.ss.usermodel.drawing.ClientAnchor; import org.apache.poi.ss.usermodel.drawing.Drawing; import org.apache.poi.ss.usermodel.drawing.Textbox; import org.apache.poi.ss.util.CellAddress; import java.io.IOException; import java.io.OutputStream; import java.util.Collections; import java.util.List; public class WaterMarkHandler implements WriteHandler { private String waterMark; public WaterMarkHandler(String waterMark) { this.waterMark = waterMark; } @Override public void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) { Sheet sheet = writeSheetHolder.getSheet(); Drawing<?> drawing = sheet.createDrawingPatriarch(); // 创建水印文本框 ClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, 0, 0, 10, 10); Textbox textBox = drawing.createTextbox(anchor); // 设置文本框属性 textBox.setLineStyleColor(255, 255, 255); textBox.setFillColor(255, 255, 255); textBox.setVerticalAlignment(VerticalAlignment.CENTER); textBox.setHorizontalAlignment(HorizontalAlignment.CENTER); textBox.setText(new HSSFRichTextString(waterMark)); } @Override public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) { // do nothing } public static void writeExcelWithWaterMark(OutputStream outputStream, List<List<String>> data, String waterMark) throws IOException { ExcelWriter writer = new ExcelWriter(outputStream, ExcelTypeEnum.XLSX); WriteSheet sheet = new WriteSheet(); sheet.setSheetName("Sheet1"); sheet.setClazz(String.class); sheet.setHead(Collections.emptyList()); sheet.setTableStyle(new TableStyle()); sheet.setWriteHandler(new WaterMarkHandler(waterMark)); writer.write1(data, sheet); writer.finish(); } } ``` 这样,我们就可以使用 Java EasyExcel 实现自定义水印插件的功能了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值