Fix NPE of regression tests
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1732972 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
4ad3d7b35a
commit
e5baa15b25
@ -49,8 +49,10 @@ import org.apache.poi.util.POILogger;
|
|||||||
public class DrawPaint {
|
public class DrawPaint {
|
||||||
// HSL code is public domain - see https://tips4java.wordpress.com/contact-us/
|
// HSL code is public domain - see https://tips4java.wordpress.com/contact-us/
|
||||||
|
|
||||||
private final static POILogger LOG = POILogFactory.getLogger(DrawPaint.class);
|
private static final POILogger LOG = POILogFactory.getLogger(DrawPaint.class);
|
||||||
|
|
||||||
|
private static final Color TRANSPARENT = new Color(1f,1f,1f,0f);
|
||||||
|
|
||||||
protected PlaceableShape<?,?> shape;
|
protected PlaceableShape<?,?> shape;
|
||||||
|
|
||||||
public DrawPaint(PlaceableShape<?,?> shape) {
|
public DrawPaint(PlaceableShape<?,?> shape) {
|
||||||
@ -65,8 +67,10 @@ public class DrawPaint {
|
|||||||
throw new NullPointerException("Color needs to be specified");
|
throw new NullPointerException("Color needs to be specified");
|
||||||
}
|
}
|
||||||
this.solidColor = new ColorStyle(){
|
this.solidColor = new ColorStyle(){
|
||||||
public Color getColor() { return color; }
|
public Color getColor() {
|
||||||
public int getAlpha() { return -1; }
|
return new Color(color.getRed(), color.getGreen(), color.getBlue());
|
||||||
|
}
|
||||||
|
public int getAlpha() { return (int)Math.round(color.getAlpha()*100000./255.); }
|
||||||
public int getHueOff() { return -1; }
|
public int getHueOff() { return -1; }
|
||||||
public int getHueMod() { return -1; }
|
public int getHueMod() { return -1; }
|
||||||
public int getSatOff() { return -1; }
|
public int getSatOff() { return -1; }
|
||||||
@ -170,9 +174,11 @@ public class DrawPaint {
|
|||||||
public static Color applyColorTransform(ColorStyle color){
|
public static Color applyColorTransform(ColorStyle color){
|
||||||
// TODO: The colors don't match 100% the results of Powerpoint, maybe because we still
|
// TODO: The colors don't match 100% the results of Powerpoint, maybe because we still
|
||||||
// operate in sRGB and not scRGB ... work in progress ...
|
// operate in sRGB and not scRGB ... work in progress ...
|
||||||
|
if (color == null || color.getColor() == null) {
|
||||||
|
return TRANSPARENT;
|
||||||
|
}
|
||||||
|
|
||||||
Color result = color.getColor();
|
Color result = color.getColor();
|
||||||
if (result == null) return null;
|
|
||||||
|
|
||||||
double alpha = getAlpha(result, color);
|
double alpha = getAlpha(result, color);
|
||||||
double hsl[] = RGB2HSL(result); // values are in the range [0..100] (usually ...)
|
double hsl[] = RGB2HSL(result); // values are in the range [0..100] (usually ...)
|
||||||
@ -291,22 +297,8 @@ public class DrawPaint {
|
|||||||
|
|
||||||
int i = 0;
|
int i = 0;
|
||||||
for (ColorStyle fc : fill.getGradientColors()) {
|
for (ColorStyle fc : fill.getGradientColors()) {
|
||||||
if (fc == null) {
|
// if fc is null, use transparent color to get color of background
|
||||||
// get color of background
|
colors[i++] = (fc == null) ? TRANSPARENT : applyColorTransform(fc);
|
||||||
fc = new ColorStyle() {
|
|
||||||
public int getTint() { return -1; }
|
|
||||||
public int getShade() { return -1; }
|
|
||||||
public int getSatOff() { return -1; }
|
|
||||||
public int getSatMod() { return -1; }
|
|
||||||
public int getLumOff() { return -1; }
|
|
||||||
public int getLumMod() { return -1; }
|
|
||||||
public int getHueOff() { return -1; }
|
|
||||||
public int getHueMod() { return -1; }
|
|
||||||
public Color getColor() { return Color.white; }
|
|
||||||
public int getAlpha() { return 0; }
|
|
||||||
};
|
|
||||||
}
|
|
||||||
colors[i++] = applyColorTransform(fc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
AffineTransform grAt = new AffineTransform();
|
AffineTransform grAt = new AffineTransform();
|
||||||
|
Loading…
Reference in New Issue
Block a user