LoopMergeStrategy.java 2.3 KB
Newer Older
Z
zhuangjiaju 已提交
1 2
package com.alibaba.excel.write.merge;

庄家钜's avatar
庄家钜 已提交
3
import org.apache.poi.ss.usermodel.Row;
Z
zhuangjiaju 已提交
4 5
import org.apache.poi.ss.util.CellRangeAddress;

6
import com.alibaba.excel.metadata.property.LoopMergeProperty;
庄家钜's avatar
庄家钜 已提交
7 8 9
import com.alibaba.excel.write.handler.AbstractRowWriteHandler;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.metadata.holder.WriteTableHolder;
Z
zhuangjiaju 已提交
10 11 12

/**
 * The regions of the loop merge
Z
zhuangjiaju 已提交
13
 *
Z
zhuangjiaju 已提交
14
 * @author Jiaju Zhuang
Z
zhuangjiaju 已提交
15
 */
庄家钜's avatar
庄家钜 已提交
16 17 18 19
public class LoopMergeStrategy extends AbstractRowWriteHandler {
    /**
     * Each row
     */
Z
zhuangjiaju 已提交
20
    private int eachRow;
庄家钜's avatar
庄家钜 已提交
21 22 23 24 25 26 27
    /**
     * Extend column
     */
    private int columnExtend;
    /**
     * The number of the current column
     */
Z
zhuangjiaju 已提交
28
    private int columnIndex;
Z
zhuangjiaju 已提交
29

Z
zhuangjiaju 已提交
30
    public LoopMergeStrategy(int eachRow, int columnIndex) {
Z
zl 已提交
31 32 33
        this(eachRow, 1, columnIndex);
    }

庄家钜's avatar
庄家钜 已提交
34
    public LoopMergeStrategy(int eachRow, int columnExtend, int columnIndex) {
Z
zhuangjiaju 已提交
35 36 37
        if (eachRow < 1) {
            throw new IllegalArgumentException("EachRows must be greater than 1");
        }
庄家钜's avatar
庄家钜 已提交
38 39
        if (columnExtend < 1) {
            throw new IllegalArgumentException("ColumnExtend must be greater than 1");
Z
zl 已提交
40
        }
庄家钜's avatar
庄家钜 已提交
41 42
        if (columnExtend == 1 && eachRow == 1) {
            throw new IllegalArgumentException("ColumnExtend or eachRows must be greater than 1");
Z
zl 已提交
43
        }
Z
zhuangjiaju 已提交
44 45
        if (columnIndex < 0) {
            throw new IllegalArgumentException("ColumnIndex must be greater than 0");
Z
zhuangjiaju 已提交
46 47
        }
        this.eachRow = eachRow;
庄家钜's avatar
庄家钜 已提交
48
        this.columnExtend = columnExtend;
Z
zhuangjiaju 已提交
49
        this.columnIndex = columnIndex;
Z
zhuangjiaju 已提交
50 51
    }

52 53 54 55
    public LoopMergeStrategy(LoopMergeProperty loopMergeProperty, Integer columnIndex) {
        this(loopMergeProperty.getEachRow(), loopMergeProperty.getColumnExtend(), columnIndex);
    }

Z
zhuangjiaju 已提交
56
    @Override
庄家钜's avatar
庄家钜 已提交
57 58 59
    public void afterRowDispose(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, Row row,
        Integer relativeRowIndex, Boolean isHead) {
        if (isHead) {
庄家钜's avatar
庄家钜 已提交
60 61
            return;
        }
庄家钜's avatar
庄家钜 已提交
62 63 64 65
        if (relativeRowIndex % eachRow == 0) {
            CellRangeAddress cellRangeAddress = new CellRangeAddress(row.getRowNum(), row.getRowNum() + eachRow - 1,
                columnIndex, columnIndex + columnExtend - 1);
            writeSheetHolder.getSheet().addMergedRegionUnsafe(cellRangeAddress);
Z
zhuangjiaju 已提交
66 67
        }
    }
庄家钜's avatar
庄家钜 已提交
68

Z
zhuangjiaju 已提交
69
}