mirror of https://github.com/apache/poi.git
Use an enum to simplify the themes code and tests
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1694125 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
d243cdddac
commit
6f3a8f0cec
|
@ -34,18 +34,31 @@ import org.openxmlformats.schemas.drawingml.x2006.main.ThemeDocument;
|
||||||
* colors and fonts.
|
* colors and fonts.
|
||||||
*/
|
*/
|
||||||
public class ThemesTable extends POIXMLDocumentPart {
|
public class ThemesTable extends POIXMLDocumentPart {
|
||||||
public static final int THEME_LT1 = 0;
|
public enum ThemeElement {
|
||||||
public static final int THEME_DK1 =1;
|
LT1(0, "Lt1"),
|
||||||
public static final int THEME_LT2 = 2;
|
DK1(1,"Dk1"),
|
||||||
public static final int THEME_DK2 = 3;
|
LT2(2,"Lt2"),
|
||||||
public static final int THEME_ACCENT1 = 4;
|
DK2(3,"Dk2"),
|
||||||
public static final int THEME_ACCENT2 = 5;
|
ACCENT1(4,"Accent1"),
|
||||||
public static final int THEME_ACCENT3 = 6;
|
ACCENT2(5,"Accent2"),
|
||||||
public static final int THEME_ACCENT4 = 7;
|
ACCENT3(6,"Accent3"),
|
||||||
public static final int THEME_ACCENT5 = 8;
|
ACCENT4(7,"Accent4"),
|
||||||
public static final int THEME_ACCENT6 = 9;
|
ACCENT5(8,"Accent5"),
|
||||||
public static final int THEME_HLINK = 10;
|
ACCENT6(9,"Accent6"),
|
||||||
public static final int THEME_FOLHLINK = 11;
|
HLINK(10,"Hlink"),
|
||||||
|
FOLHLINK(11,"FolHlink"),
|
||||||
|
UNKNOWN(-1,null);
|
||||||
|
|
||||||
|
public static ThemeElement byId(int idx) {
|
||||||
|
if (idx >= values().length || idx < 0) return UNKNOWN;
|
||||||
|
return values()[idx];
|
||||||
|
}
|
||||||
|
private ThemeElement(int idx, String name) {
|
||||||
|
this.idx = idx; this.name = name;
|
||||||
|
}
|
||||||
|
public final int idx;
|
||||||
|
public final String name;
|
||||||
|
};
|
||||||
|
|
||||||
private ThemeDocument theme;
|
private ThemeDocument theme;
|
||||||
|
|
||||||
|
@ -92,19 +105,19 @@ public class ThemesTable extends POIXMLDocumentPart {
|
||||||
// in theme1.xml. They are keys to a mapped color.
|
// in theme1.xml. They are keys to a mapped color.
|
||||||
CTColorScheme colorScheme = theme.getTheme().getThemeElements().getClrScheme();
|
CTColorScheme colorScheme = theme.getTheme().getThemeElements().getClrScheme();
|
||||||
CTColor ctColor;
|
CTColor ctColor;
|
||||||
switch (idx) {
|
switch (ThemeElement.byId(idx)) {
|
||||||
case THEME_LT1: ctColor = colorScheme.getLt1(); break;
|
case LT1: ctColor = colorScheme.getLt1(); break;
|
||||||
case THEME_DK1: ctColor = colorScheme.getDk1(); break;
|
case DK1: ctColor = colorScheme.getDk1(); break;
|
||||||
case THEME_LT2: ctColor = colorScheme.getLt2(); break;
|
case LT2: ctColor = colorScheme.getLt2(); break;
|
||||||
case THEME_DK2: ctColor = colorScheme.getDk2(); break;
|
case DK2: ctColor = colorScheme.getDk2(); break;
|
||||||
case THEME_ACCENT1: ctColor = colorScheme.getAccent1(); break;
|
case ACCENT1: ctColor = colorScheme.getAccent1(); break;
|
||||||
case THEME_ACCENT2: ctColor = colorScheme.getAccent2(); break;
|
case ACCENT2: ctColor = colorScheme.getAccent2(); break;
|
||||||
case THEME_ACCENT3: ctColor = colorScheme.getAccent3(); break;
|
case ACCENT3: ctColor = colorScheme.getAccent3(); break;
|
||||||
case THEME_ACCENT4: ctColor = colorScheme.getAccent4(); break;
|
case ACCENT4: ctColor = colorScheme.getAccent4(); break;
|
||||||
case THEME_ACCENT5: ctColor = colorScheme.getAccent5(); break;
|
case ACCENT5: ctColor = colorScheme.getAccent5(); break;
|
||||||
case THEME_ACCENT6: ctColor = colorScheme.getAccent6(); break;
|
case ACCENT6: ctColor = colorScheme.getAccent6(); break;
|
||||||
case THEME_HLINK: ctColor = colorScheme.getHlink(); break;
|
case HLINK: ctColor = colorScheme.getHlink(); break;
|
||||||
case THEME_FOLHLINK:ctColor = colorScheme.getFolHlink();break;
|
case FOLHLINK:ctColor = colorScheme.getFolHlink();break;
|
||||||
default: return null;
|
default: return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -28,6 +28,7 @@ import org.apache.commons.codec.binary.Hex;
|
||||||
import org.apache.poi.ss.usermodel.CellStyle;
|
import org.apache.poi.ss.usermodel.CellStyle;
|
||||||
import org.apache.poi.ss.util.CellReference;
|
import org.apache.poi.ss.util.CellReference;
|
||||||
import org.apache.poi.xssf.XSSFTestDataSamples;
|
import org.apache.poi.xssf.XSSFTestDataSamples;
|
||||||
|
import org.apache.poi.xssf.model.ThemesTable.ThemeElement;
|
||||||
import org.apache.poi.xssf.usermodel.XSSFCell;
|
import org.apache.poi.xssf.usermodel.XSSFCell;
|
||||||
import org.apache.poi.xssf.usermodel.XSSFCellStyle;
|
import org.apache.poi.xssf.usermodel.XSSFCellStyle;
|
||||||
import org.apache.poi.xssf.usermodel.XSSFColor;
|
import org.apache.poi.xssf.usermodel.XSSFColor;
|
||||||
|
@ -36,27 +37,13 @@ import org.apache.poi.xssf.usermodel.XSSFRow;
|
||||||
import org.apache.poi.xssf.usermodel.XSSFSheet;
|
import org.apache.poi.xssf.usermodel.XSSFSheet;
|
||||||
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
|
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTColor;
|
||||||
|
|
||||||
public class TestThemesTable {
|
public class TestThemesTable {
|
||||||
private String testFileSimple = "Themes.xlsx";
|
private String testFileSimple = "Themes.xlsx";
|
||||||
private String testFileComplex = "Themes2.xlsx";
|
private String testFileComplex = "Themes2.xlsx";
|
||||||
// TODO .xls version available too, add HSSF support then check
|
// TODO .xls version available too, add HSSF support then check
|
||||||
|
|
||||||
// What our theme names are
|
|
||||||
private static String[] themeEntries = {
|
|
||||||
"lt1",
|
|
||||||
"dk1",
|
|
||||||
"lt2",
|
|
||||||
"dk2",
|
|
||||||
"accent1",
|
|
||||||
"accent2",
|
|
||||||
"accent3",
|
|
||||||
"accent4",
|
|
||||||
"accent5",
|
|
||||||
"accent6",
|
|
||||||
"hlink",
|
|
||||||
"folhlink"
|
|
||||||
};
|
|
||||||
// What colours they should show up as
|
// What colours they should show up as
|
||||||
private static String rgbExpected[] = {
|
private static String rgbExpected[] = {
|
||||||
"ffffff", // Lt1
|
"ffffff", // Lt1
|
||||||
|
@ -93,7 +80,7 @@ public class TestThemesTable {
|
||||||
// workbooks.put("Re-Saved_" + testFileComplex, complexRS);
|
// workbooks.put("Re-Saved_" + testFileComplex, complexRS);
|
||||||
|
|
||||||
// Sanity check
|
// Sanity check
|
||||||
assertEquals(themeEntries.length, rgbExpected.length);
|
assertEquals(rgbExpected.length, rgbExpected.length);
|
||||||
|
|
||||||
// For offline testing
|
// For offline testing
|
||||||
boolean createFiles = false;
|
boolean createFiles = false;
|
||||||
|
@ -106,25 +93,33 @@ public class TestThemesTable {
|
||||||
int startRN = 0;
|
int startRN = 0;
|
||||||
if (whatWorkbook.endsWith(testFileComplex)) startRN++;
|
if (whatWorkbook.endsWith(testFileComplex)) startRN++;
|
||||||
|
|
||||||
for (int rn=startRN; rn<themeEntries.length+startRN; rn++) {
|
for (int rn=startRN; rn<rgbExpected.length+startRN; rn++) {
|
||||||
XSSFRow row = sheet.getRow(rn);
|
XSSFRow row = sheet.getRow(rn);
|
||||||
assertNotNull("Missing row " + rn + " in " + whatWorkbook, row);
|
assertNotNull("Missing row " + rn + " in " + whatWorkbook, row);
|
||||||
String ref = (new CellReference(rn, 0)).formatAsString();
|
String ref = (new CellReference(rn, 0)).formatAsString();
|
||||||
XSSFCell cell = row.getCell(0);
|
XSSFCell cell = row.getCell(0);
|
||||||
assertNotNull(
|
assertNotNull(
|
||||||
"Missing cell " + ref + " in " + whatWorkbook, cell);
|
"Missing cell " + ref + " in " + whatWorkbook, cell);
|
||||||
|
|
||||||
|
ThemeElement themeElem = ThemeElement.byId(rn-startRN);
|
||||||
assertEquals(
|
assertEquals(
|
||||||
"Wrong theme at " + ref + " in " + whatWorkbook,
|
"Wrong theme at " + ref + " in " + whatWorkbook,
|
||||||
themeEntries[rn], cell.getStringCellValue());
|
themeElem.name.toLowerCase(), cell.getStringCellValue());
|
||||||
|
|
||||||
|
// Fonts are theme-based in their colours
|
||||||
XSSFFont font = cell.getCellStyle().getFont();
|
XSSFFont font = cell.getCellStyle().getFont();
|
||||||
XSSFColor color = font.getXSSFColor();
|
CTColor ctColor = font.getCTFont().getColorArray(0);
|
||||||
|
assertNotNull(ctColor);
|
||||||
|
assertEquals(true, ctColor.isSetTheme());
|
||||||
|
assertEquals(themeElem.idx, ctColor.getTheme());
|
||||||
|
|
||||||
|
// Get the colour, via the theme
|
||||||
|
XSSFColor color = font.getXSSFColor();
|
||||||
// Theme colours aren't tinted
|
// Theme colours aren't tinted
|
||||||
assertEquals(false, color.hasTint());
|
assertEquals(false, color.hasTint());
|
||||||
// Check the RGB part (no tint)
|
// Check the RGB part (no tint)
|
||||||
assertEquals(
|
assertEquals(
|
||||||
"Wrong theme colour " + themeEntries[rn] + " on " + whatWorkbook,
|
"Wrong theme colour " + themeElem.name + " on " + whatWorkbook,
|
||||||
rgbExpected[rn], Hex.encodeHexString(color.getRGB()));
|
rgbExpected[rn], Hex.encodeHexString(color.getRGB()));
|
||||||
// Check the Theme ID
|
// Check the Theme ID
|
||||||
int expectedThemeIdx = rn - startRN;
|
int expectedThemeIdx = rn - startRN;
|
||||||
|
|
Loading…
Reference in New Issue