温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java如何在Excel中添加水印

发布时间:2021-04-30 10:56:50 来源:亿速云 阅读:900 作者:小新 栏目:开发技术

这篇文章主要介绍了Java如何在Excel中添加水印,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

java基本数据类型有哪些

Java的基本数据类型分为:1、整数类型,用来表示整数的数据类型。2、浮点类型,用来表示小数的数据类型。3、字符类型,字符类型的关键字是“char”。4、布尔类型,是表示逻辑值的基本数据类型。

程序环境:

测试文档:Office Excel 2013

编译环境:IntelliJ IDEA 2018

JDK版本:1.8.0

Excel库:Java系列free spire.xls.jar 3.9.1

1.单一水印效果

import com.spire.xls.*; import java.awt.*; import java.awt.image.BufferedImage; import static java.awt.image.BufferedImage.TYPE_INT_ARGB; public class SingleWatermark {     public static void main(String[] args) {         //加载Excel测试文档         Workbook wb = new Workbook();         wb.loadFromFile("test.xlsx");         //设置文本和字体大小         Font font = new Font("仿宋", Font.PLAIN, 40);         for (int i =0;i<wb.getWorksheets().getCount();i++)         {             Worksheet sheet = wb.getWorksheets().get(i);             //调用DrawText() 方法插入图片             BufferedImage imgWtrmrk = drawText("内部专用", font, Color.pink, Color.white, sheet.getPageSetup().getPageHeight(), sheet.getPageSetup().getPageWidth());             //将图片设置为页眉             sheet.getPageSetup().setCenterHeaderImage(imgWtrmrk);             sheet.getPageSetup().setCenterHeader("&G");             //将显示模式设置为Layout             sheet.setViewMode(ViewMode.Layout);         }         //保存文档         wb.saveToFile("SingleWatermark.xlsx", ExcelVersion.Version2013);     }     private static BufferedImage drawText (String text, Font font, Color textColor, Color backColor,double height, double width)     {         //定义图片宽度和高度         BufferedImage img = new BufferedImage((int) width, (int) height, TYPE_INT_ARGB);         Graphics2D loGraphic = img.createGraphics();         //获取文本size         FontMetrics loFontMetrics = loGraphic.getFontMetrics(font);         int liStrWidth = loFontMetrics.stringWidth(text);         int liStrHeight = loFontMetrics.getHeight();         //文本显示样式及位置         loGraphic.setColor(backColor);         loGraphic.fillRect(0, 0, (int) width, (int) height);         loGraphic.translate(((int) width - liStrWidth) / 2, ((int) height - liStrHeight) / 2);         loGraphic.rotate(Math.toRadians(-45));         loGraphic.translate(-((int) width - liStrWidth) / 2, -((int) height - liStrHeight) / 2);         loGraphic.setFont(font);         loGraphic.setColor(textColor);         loGraphic.drawString(text, ((int) width - liStrWidth) / 2, ((int) height - liStrHeight) / 2);         loGraphic.dispose();         return img;     } }

单一水印效果:

Java如何在Excel中添加水印

2.平铺水印效果

import com.spire.xls.*; import java.awt.*; import java.awt.image.BufferedImage; import static java.awt.image.BufferedImage.TYPE_INT_ARGB; public class TiledWatermark {     public static void main(String[] args) {         //加载Excel测试文档         Workbook wb = new Workbook();         wb.loadFromFile("test.xlsx");         //设置文本和字体大小         Font font = new Font("仿宋", Font.PLAIN, 25);         for (int i =0;i<wb.getWorksheets().getCount();i++)         {             Worksheet sheet = wb.getWorksheets().get(i);             //调用DrawText() 方法插入图片             BufferedImage imgWtrmrk = drawText("内部专用     内部专用     内部专用     内部专用", font, Color.pink, Color.white, sheet.getPageSetup().getPageHeight(), sheet.getPageSetup().getPageWidth());             //将图片设置为页眉             sheet.getPageSetup().setCenterHeaderImage(imgWtrmrk);             sheet.getPageSetup().setCenterHeader("&G");             //将显示模式设置为Layout             sheet.setViewMode(ViewMode.Layout);         }         //保存文档         wb.saveToFile("TiledWatermark.xlsx", ExcelVersion.Version2013);     }     private static BufferedImage drawText (String text, Font font, Color textColor, Color backColor,double height, double width)     {         //定义图片宽度和高度         BufferedImage img = new BufferedImage((int) width, (int) height, TYPE_INT_ARGB);         Graphics2D loGraphic = img.createGraphics();         //获取文本size         FontMetrics loFontMetrics = loGraphic.getFontMetrics(font);         int liStrWidth = loFontMetrics.stringWidth(text);         int liStrHeight = loFontMetrics.getHeight();         //文本显示样式及位置         loGraphic.setColor(backColor);         loGraphic.fillRect(0, 0, (int) width, (int) height);         loGraphic.translate(((int) width - liStrWidth) / 2, ((int) height - liStrHeight) / 2);         //loGraphic.rotate(Math.toRadians(-45));         loGraphic.translate(-((int) width - liStrWidth) / 2, -((int) height - liStrHeight) / 2);         loGraphic.setFont(font);         loGraphic.setColor(textColor);         loGraphic.drawString(text, ((int) width - liStrWidth) /6 , ((int) height - liStrHeight) /6);         loGraphic.drawString(text,((int) width - liStrWidth) /3, ((int) height - liStrHeight) /3);         loGraphic.drawString(text,((int) width - liStrWidth) /2, ((int) height - liStrHeight) /2);         loGraphic.dispose();         return img;     } }

平铺水印效果:

Java如何在Excel中添加水印

★ 需要注意的是:在添加完水印效果后,查看文档时,在“普通视图”水印不可见,需在“页面布局”模式或“打印预览”模式下查看。

感谢你能够认真阅读完这篇文章,希望小编分享的“Java如何在Excel中添加水印”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI