diff options
Diffstat (limited to 'poi')
3 files changed, 42 insertions, 12 deletions
diff --git a/poi/src/main/java/org/apache/poi/hssf/usermodel/HSSFCellStyle.java b/poi/src/main/java/org/apache/poi/hssf/usermodel/HSSFCellStyle.java index 55621d9095..6a34ca930f 100644 --- a/poi/src/main/java/org/apache/poi/hssf/usermodel/HSSFCellStyle.java +++ b/poi/src/main/java/org/apache/poi/hssf/usermodel/HSSFCellStyle.java @@ -642,16 +642,18 @@ public final class HSSFCellStyle implements CellStyle, Duplicatable { * Set the background fill color represented as a {@link org.apache.poi.ss.usermodel.Color} value. * <br> * @param color the color to use + * @param ignoreInvalidColors when set to true, the method will ignore issues like trying to set a + * HSSFColor on a XSSFCellStyle * @throws IllegalArgumentException if you provide a <code>Color</code> instance that is not a {@link HSSFColor} * @since POI 5.2.3 */ @Override - public void setFillBackgroundColor(org.apache.poi.ss.usermodel.Color color) + public void setFillBackgroundColor(org.apache.poi.ss.usermodel.Color color, boolean ignoreInvalidColors) { if (color instanceof HSSFColor) { short index2 = ((HSSFColor)color).getIndex2(); if (index2 != -1) setFillBackgroundColor(index2); - } else if (color != null) { + } else if (color != null && !ignoreInvalidColors) { throw new IllegalArgumentException("HSSFCellStyle only accepts HSSFColor instances"); } } @@ -701,16 +703,18 @@ public final class HSSFCellStyle implements CellStyle, Duplicatable { * Set the foreground fill color represented as a {@link org.apache.poi.ss.usermodel.Color} value. * <br> * @param color the color to use + * @param ignoreInvalidColors when set to true, the method will ignore issues like trying to set a + * HSSFColor on a XSSFCellStyle * @throws IllegalArgumentException if you provide a <code>Color</code> instance that is not a {@link HSSFColor} * @since POI 5.2.3 */ @Override - public void setFillForegroundColor(org.apache.poi.ss.usermodel.Color color) + public void setFillForegroundColor(org.apache.poi.ss.usermodel.Color color, boolean ignoreInvalidColors) { if (color instanceof HSSFColor) { short index2 = ((HSSFColor)color).getIndex2(); if (index2 != -1) setFillForegroundColor(index2); - } else if (color != null) { + } else if (color != null && !ignoreInvalidColors) { throw new IllegalArgumentException("HSSFCellStyle only accepts HSSFColor instances"); } } diff --git a/poi/src/main/java/org/apache/poi/ss/usermodel/CellStyle.java b/poi/src/main/java/org/apache/poi/ss/usermodel/CellStyle.java index c4e539da8b..cc446886c0 100644 --- a/poi/src/main/java/org/apache/poi/ss/usermodel/CellStyle.java +++ b/poi/src/main/java/org/apache/poi/ss/usermodel/CellStyle.java @@ -312,13 +312,26 @@ public interface CellStyle { void setFillBackgroundColor(short bg); /** - * set the background fill color. - * use not a indexed color but a {@link org.apache.poi.ss.usermodel.Color) + * Set the background fill color. + * Uses a {@link org.apache.poi.ss.usermodel.Color} instead of an indexed color. + * + * @param color org.apache.poi.ss.usermodel.Color to set + * @since POI 5.2.3 + */ + default void setFillBackgroundColor(Color color) { + setFillBackgroundColor(color, false); + } + + /** + * Set the background fill color. + * Uses a {@link org.apache.poi.ss.usermodel.Color} instead of an indexed color. * * @param color org.apache.poi.ss.usermodel.Color to set + * @param ignoreInvalidColors when set to true, the method will ignore issues like trying to set a + * HSSFColor on a XSSFCellStyle * @since POI 5.2.3 */ - void setFillBackgroundColor(Color color); + void setFillBackgroundColor(Color color, boolean ignoreInvalidColors); /** * get the background fill color, if the fill @@ -344,13 +357,26 @@ public interface CellStyle { void setFillForegroundColor(short bg); /** - * set the foreground fill color. - * use not a indexed color but a {@link org.apache.poi.ss.usermodel.Color) + * Set the foreground fill color. + * Uses a {@link org.apache.poi.ss.usermodel.Color} instead of an indexed color. + * + * @param color org.apache.poi.ss.usermodel.Color to set + * @since POI 5.2.3 + */ + default void setFillForegroundColor(Color color) { + setFillForegroundColor(color, false); + } + + /** + * Set the foreground fill color. + * Uses a {@link org.apache.poi.ss.usermodel.Color} instead of an indexed color. * * @param color org.apache.poi.ss.usermodel.Color to set + * @param ignoreInvalidColors when set to true, the method will ignore issues like trying to set a + * HSSFColor on a XSSFCellStyle * @since POI 5.2.3 */ - void setFillForegroundColor(Color color); + void setFillForegroundColor(Color color, boolean ignoreInvalidColors); /** * get the foreground fill color, if the fill diff --git a/poi/src/main/java/org/apache/poi/ss/util/CellUtil.java b/poi/src/main/java/org/apache/poi/ss/util/CellUtil.java index 0665cefa38..8bab37d4da 100644 --- a/poi/src/main/java/org/apache/poi/ss/util/CellUtil.java +++ b/poi/src/main/java/org/apache/poi/ss/util/CellUtil.java @@ -532,8 +532,8 @@ public final class CellUtil { style.setFillForegroundColor(getShort(properties, FILL_FOREGROUND_COLOR)); style.setFillBackgroundColor(getShort(properties, FILL_BACKGROUND_COLOR)); - style.setFillForegroundColor(getColor(properties, FILL_FOREGROUND_COLOR_COLOR)); - style.setFillBackgroundColor(getColor(properties, FILL_BACKGROUND_COLOR_COLOR)); + style.setFillForegroundColor(getColor(properties, FILL_FOREGROUND_COLOR_COLOR), true); + style.setFillBackgroundColor(getColor(properties, FILL_BACKGROUND_COLOR_COLOR), true); style.setFont(workbook.getFontAt(getInt(properties, FONT))); style.setHidden(getBoolean(properties, HIDDEN)); |