Skip to content

Latest commit

 

History

History
159 lines (129 loc) · 4.42 KB

README_zh.md

File metadata and controls

159 lines (129 loc) · 4.42 KB

💧 EasyWatermark

📷 图片水印样例 | 📄 Pdf水印样例 | 📝 Docx水印样例

EasyWatermark 是一个简单易用的水印添加框架,框架抽象了各个文件类型的对于水印添加的方法。仅使用几行代码即可为不同类型的文件添加相同样式的水印。

🚀 快速开始

1️⃣ 添加依赖

<dependency>
  <groupId>org.easywatermark</groupId>
  <artifactId>easy-watermark</artifactId>
  <version>最新版本</version>
</dependency>

2️⃣ 添加水印

public class WatermarkExample {

    public static void main(String[] args) {
        byte[] result = EasyWatermark.create()
                .file(fileData)
                .text("Easy-Watermark")
                .execute();
    }

}

🔧 更多配置

🎯 预制水印类型

  • CUSTOM:自定义水印,使用框架抽象的统一方法,对传入文件的每个页面进行特殊处理(开发中)
  • CENTER:居中,在页面的各个居中位置上添加。
    • VERTICAL_CENTER:水印垂直居中
    • LEFT_CENTER:靠左居中
    • RIGHT_CENTER:靠右居中
    • TOP_CENTER:顶部居中
    • BOTTOM_CENTER:底部居中
  • OVERSPREAD:页面铺满,可设置倾斜角度
    • LOW:低铺满,水印内容占比33%
    • NORMAL:一般铺满,水印内容占比66%
    • HIGH:高铺满,水印内容占比90%
  • DIAGONAL:页面对角水印
    • TOP_TO_BOTTOM:文字从上到下
    • BOTTOM_TO_TOP:文字从下到上

⚙️ 水印配置

对应WatermarkConfig类,该类会对水印的各项属性进行设置。

public class WatermarkConfig {
  // 水印颜色
  private Color color = Color.BLACK;
  // 忽略旋转,仍在开发
  private boolean ignoreRotation = true;
  // 水印透明度
  private float alpha = 1;
  // 铺满水印子类型
  private OverspreadTypeEnum overspreadType = OverspreadTypeEnum.NORMAL;
  // 居中水印子类型
  private CenterLocationTypeEnum centerLocationType = CenterLocationTypeEnum.VERTICAL_CENTER;
  // 对角水印子类型
  private DiagonalDirectionTypeEnum diagonalDirectionType = DiagonalDirectionTypeEnum.TOP_TO_BOTTOM;

  /**
   * An angle, in degrees
   * The angle of clockwise rotation
   */
  private float angle = 0;
}

🛠️ 字体配置

对应FontConfig类,该类会对水印文字的各项属性进行设置。

public class FontConfig {
    // 字体颜色
    private Color color = Color.BLACK;
    // 字体文件
    private File fontFile;
  
    /**
     * 默认的字体,目前仅在图片水印中生效
     * Default font name is Dialog
     */
    private String fontName = "Dialog";
    // 字体大小
    private int fontSize = 12;
  
    /**
     * 字体样式:加粗、斜体、正常
     */
    private int fontStyle = Font.PLAIN;
}

🛠️ 进阶用法

使用预设水印类型

public class UsingPresetWatermarkType {

    public static void main(String[] args) {
        byte[] result = EasyWatermark.create()
                .file(fileData)
                .text("Easy-Watermark")
                // Choose different watermark types
                .easyWatermarkType(EasyWatermarkTypeEnum.CENTER)
                .execute();
    }

}

自定义水印配置以及字体配置

public class CustomWatermarkExample {

    public static void main(String[] args) {
        WatermarkConfig watermarkConfig = new WatermarkConfig();
        // Set the transparency of the watermark
        watermarkConfig.setAlpha(0.5f);
    
        FontConfig fontConfig = new FontConfig();
        // Set the size of the watermark text
        fontConfig.setFontSize(30);
    
        byte[] result = EasyWatermark.create()
                .file(fileData)
                // Custom configuration
                .config(watermarkConfig)
                .config(fontConfig)
                // Watermark type
                .easyWatermarkType(EasyWatermarkTypeEnum.CENTER)
                .text("Easy-Watermark")
                .executor();
    }

}

📅 开发计划

  • 图片类型文件添加水印
  • PDF类型文件添加水印
  • Word文件添加水印
  • 用户自定义水印方法完善
  • Excel文件添加水印
  • PowerPoint文件添加水印
  • 隐藏水印

🙌 其他

如有更多建议,欢迎提出issue😊