工具类之十五 excel加水印工具类

package com.taylor.query.utils;

import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.xssf.streaming.SXSSFCell;
import org.apache.poi.xssf.streaming.SXSSFRow;
import org.apache.poi.xssf.streaming.SXSSFSheet;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;

import javax.imageio.ImageIO;
import java.awt.*;
import java.awt.Color;
import java.awt.font.FontRenderContext;
import java.awt.geom.Rectangle2D;
import java.awt.image.BufferedImage;
import java.io.*;
import java.math.BigDecimal;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Iterator;
import java.util.Map;

/**
 * 2020/11/20修改 by Taylor
 */
public class ExcelExport {
   
    /**未定义的字段*/
    public static String NO_DEFINE = "no_define";
    /**默认日期格式*/
    public static String DEFAULT_DATE_PATTERN="yyyy年MM月dd日";
    public static int DEFAULT_COLOUMN_WIDTH = 17;
    /**
     * 导出Excel  (.xls)格式
     * @param waterContent 水印
     * @param headMap 属性-列头
     * @param jsonArray 数据集
     * @param datePattern 日期格式,传null值则默认 年月日
     * @param colWidth 列宽 默认 至少17个字节
     * @param out 输出流
     */
    public static void exportExcelX(String waterContent, Map<String, String> headMap, JSONArray jsonArray, String datePattern, int colWidth, OutputStream out) {
   
        if(datePattern==null) {
   datePattern = DEFAULT_DATE_PATTERN;}
        // 声明一个工作薄
        HSSFWorkbook workbook = new HSSFWorkbook();//缓存
        //workbook.setCompressTempFiles(true);
        //表头样式
        /*CellStyle titleStyle = workbook.createCellStyle();
        titleStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
        Font titleFont = workbook.createFont();
        titleFont.setFontHeightInPoints((short) 20);
        titleFont.setBoldweight((short) 700);
        titleStyle.setFont(titleFont);*/
        // 列头样式
        CellStyle headerStyle = workbook.createCellStyle();
        headerStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);
        headerStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);
        headerStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);
        headerStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);
        headerStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
        headerStyle.setFillForegroundColor((short) 10);
        Font headerFont = workbook.createFont();
        headerFont.setFontHeightInPoints((short) 12);
        headerFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
        headerStyle.setFont(headerFont);
        // 单元格样式
        CellStyle cellStyle = workbook.createCellStyle();
        cellStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);
        cellStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);
        cellStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);
        cellStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);
        cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
        cellStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
        Font cellFont = workbook.createFont();
        cellFont.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);
        cellStyle.setFont(cellFont);
        // 生成一个(带标题)表格
        HSSFSheet sheet =  workbook.createSheet();
        //设置列宽
        int minBytes = colWidth<DEFAULT_COLOUMN_WIDTH?DEFAULT_COLOUMN_WIDTH:colWidth;//至少字节数
        int[] arrColWidth = new int[headMap.size()];
        // 产生表格标题行,以及设置列宽
        String[] properties = new String[headMap.size()];
        String[] headers = new String[headMap.size()];
        int ii = 0;
        for (Iterator<String> iter = headMap.keySet().iterator(); iter.hasNext(
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot是一个基于Java的框架,用于开发微服务应用程序。FFmpeg是一个强大的音视频处理工具,而JavaCV是一个在Java平台上使用OpenCV和FFmpeg功能的库。 请问您是想要实现在使用Spring Boot后端中使用FFmpeg和JavaCV给音视频文件水印,并将处理后的文件推流吗? 如果是这样,首先需要在您的Spring Boot项目中引入JavaCV的依赖,例如: ``` <dependency> <groupId>org.bytedeco</groupId> <artifactId>javacv-platform</artifactId> <version>1.5.4</version> </dependency> ``` 然后,您可以使用JavaCV提供的FFmpegFrameGrabber和FFmpegFrameRecorder类来分别处理输入和输出的音视频流。您可以使用FFmpegFrameGrabber类来读取原始的音视频文件,然后使用FFmpegFrameRecorder类来创建一个新的音视频流,并在其上水印水印的具体步骤大致如下: 1. 创建一个FFmpegFrameGrabber对象,用于读取原始音视频文件。 2. 创建一个FFmpegFrameRecorder对象,用于输出水印后的音视频流。 3. 使用FFmpegFrameGrabber对象的grab方法读取每一帧的音视频数据,并使用FFmpegFrameRecorder对象的record方法写入水印后的音视频流。 4. 在每一帧的音视频数据上添水印,可以使用JavaCV提供的图像处理功能来实现,例如在视频帧上添图片或者文字水印。 5. 循环执行第3和第4步,直至处理完所有的音视频帧。 6. 完成水印后的音视频处理后,执行FFmpegFrameRecorder对象的stop方法,结束音视频流的处理。 7. 将处理后的音视频流推流到指定的服务器或平台。 需要注意的是,水印的效果和位置需要根据实际需求进行调整,并且推流需要配置相应的推流地址和参数。 总结起来,使用Spring Boot结合FFmpeg和JavaCV可以完成后端水印并推流的任务。具体的实现步骤可以按上述指引进行操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值