aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDominik Stadler <centic@apache.org>2023-01-30 12:19:24 +0000
committerDominik Stadler <centic@apache.org>2023-01-30 12:19:24 +0000
commitacdf2ec9815fd01d9a9b9db3752fc70dd3914059 (patch)
treeb42e300353a7af8103ed62bb58ae5c0906d86cf2
parenta7382f00b948dd627df529aeadc8646ed95f40d3 (diff)
downloadpoi-acdf2ec9815fd01d9a9b9db3752fc70dd3914059.tar.gz
poi-acdf2ec9815fd01d9a9b9db3752fc70dd3914059.zip
Bug 62272: Include alpha/transparency value when setting a color-value for a font
Use method with returns 4 bytes to use an ARGB value instead of only RGB git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1907105 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--poi-ooxml/src/main/java/org/apache/poi/xssf/usermodel/XSSFFont.java17
-rw-r--r--poi-ooxml/src/test/java/org/apache/poi/xssf/usermodel/TestXSSFFont.java52
-rw-r--r--test-data/spreadsheet/62272.xlsxbin0 -> 4966 bytes
3 files changed, 57 insertions, 12 deletions
diff --git a/poi-ooxml/src/main/java/org/apache/poi/xssf/usermodel/XSSFFont.java b/poi-ooxml/src/main/java/org/apache/poi/xssf/usermodel/XSSFFont.java
index 0f97f6e4af..41e903907b 100644
--- a/poi-ooxml/src/main/java/org/apache/poi/xssf/usermodel/XSSFFont.java
+++ b/poi-ooxml/src/main/java/org/apache/poi/xssf/usermodel/XSSFFont.java
@@ -392,17 +392,10 @@ public class XSSFFont implements Font {
@Override
public void setColor(short color) {
CTColor ctColor = _ctFont.sizeOfColorArray() == 0 ? _ctFont.addNewColor() : _ctFont.getColorArray(0);
- switch (color) {
- case Font.COLOR_NORMAL: {
- ctColor.setIndexed(XSSFFont.DEFAULT_FONT_COLOR);
- break;
- }
- case Font.COLOR_RED: {
- ctColor.setIndexed(IndexedColors.RED.getIndex());
- break;
- }
- default:
- ctColor.setIndexed(color);
+ if (color == Font.COLOR_NORMAL) {
+ ctColor.setIndexed(XSSFFont.DEFAULT_FONT_COLOR);
+ } else {
+ ctColor.setIndexed(color);
}
}
@@ -418,7 +411,7 @@ public class XSSFFont implements Font {
if (ctColor.isSetIndexed()) {
ctColor.unsetIndexed();
}
- ctColor.setRgb(color.getRGB());
+ ctColor.setRgb(color.getARGB());
}
}
diff --git a/poi-ooxml/src/test/java/org/apache/poi/xssf/usermodel/TestXSSFFont.java b/poi-ooxml/src/test/java/org/apache/poi/xssf/usermodel/TestXSSFFont.java
index 9553d595bb..35bcd75f00 100644
--- a/poi-ooxml/src/test/java/org/apache/poi/xssf/usermodel/TestXSSFFont.java
+++ b/poi-ooxml/src/test/java/org/apache/poi/xssf/usermodel/TestXSSFFont.java
@@ -21,16 +21,20 @@ import static org.apache.poi.ss.usermodel.FontCharset.*;
import static org.junit.jupiter.api.Assertions.*;
import java.io.IOException;
+import java.util.Arrays;
import java.util.stream.Stream;
import org.apache.poi.common.usermodel.fonts.FontCharset;
import org.apache.poi.ooxml.POIXMLException;
import org.apache.poi.ss.usermodel.BaseTestFont;
+import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.ss.usermodel.FontFamily;
import org.apache.poi.ss.usermodel.FontScheme;
import org.apache.poi.ss.usermodel.FontUnderline;
import org.apache.poi.ss.usermodel.IndexedColors;
+import org.apache.poi.ss.usermodel.Row;
+import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.util.SheetUtil;
import org.apache.poi.util.LocaleUtil;
@@ -495,4 +499,52 @@ public final class TestXSSFFont extends BaseTestFont {
notequ.setThemeColor((short)123);
assertNotEquals(font, notequ);
}
+
+ @Test
+ public void testBug62272() throws IOException {
+ try (XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("62272.xlsx")) {
+ // make sure we read the font-color with alpha
+ checkFontColor(wb);
+ }
+ }
+
+ @Test
+ public void testBug62272a() throws IOException {
+ try (XSSFWorkbook wb = new XSSFWorkbook()) {
+ Sheet sheet = wb.createSheet("test");
+ Row row = sheet.createRow(0);
+ Cell cell = row.createCell(0);
+
+ // create a font with alpha
+ XSSFFont font = wb.createFont();
+ font.setColor(new XSSFColor(new byte[] {
+ 0x7f, 0x33, (byte)0xCC, 0x66
+ }));
+
+ XSSFCellStyle style = wb.createCellStyle();
+ style.setFont(font);
+
+ cell.setCellStyle(style);
+ cell.setCellValue("testtext");
+
+ // make sure the alpha-value was stored properly
+ checkFontColor(wb);
+
+ /*try (OutputStream out = new FileOutputStream("/tmp/testout.xlsx")) {
+ wb.write(out);
+ }*/
+ }
+ }
+
+ private static void checkFontColor(Workbook wb) {
+ int fontIdx = wb.getSheetAt(0).getRow(0).getCell(0).getCellStyle().getFontIndex();
+ Font font = wb.getFontAt(fontIdx);
+ //System.out.println(font.getColor());
+
+ CTColor[] colorArray = ((XSSFFont) font).getCTFont().getColorArray();
+ //System.out.println(Arrays.toString(colorArray));
+ assertArrayEquals(new byte[] {
+ 0x7f, 0x33, (byte)0xCC, 0x66
+ }, colorArray[0].getRgb());
+ }
}
diff --git a/test-data/spreadsheet/62272.xlsx b/test-data/spreadsheet/62272.xlsx
new file mode 100644
index 0000000000..9b91105c06
--- /dev/null
+++ b/test-data/spreadsheet/62272.xlsx
Binary files differ