easy-watermark

💧 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();
    }

}

🔧 更多配置

🎯 预制水印类型

⚙️ 水印配置

对应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();
    }

}

📅 开发计划

🙌 其他

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