From ce30484f7cec4d7f8827a09037e4fdde6517b713 Mon Sep 17 00:00:00 2001 From: Steve Hannah Date: Sat, 26 Oct 2024 08:09:41 -0700 Subject: [PATCH] fix: css nullpointer when using cn1-box-shadow-h or cn1-box-shadow-v (#3852) --- .../com/codename1/designer/css/CSSTheme.java | 37 ++++++++++--------- 1 file changed, 19 insertions(+), 18 deletions(-) diff --git a/CodenameOneDesigner/src/com/codename1/designer/css/CSSTheme.java b/CodenameOneDesigner/src/com/codename1/designer/css/CSSTheme.java index 95563fb4c8..5652272ef1 100644 --- a/CodenameOneDesigner/src/com/codename1/designer/css/CSSTheme.java +++ b/CodenameOneDesigner/src/com/codename1/designer/css/CSSTheme.java @@ -3128,38 +3128,43 @@ Insets getBoxShadowPadding(Map style) { boxShadow = tmp; } } - - + if (isNone(boxShadow)) { return i; } - - - + ScaledUnit insetUnit = boxShadow; while (insetUnit != null) { if ("inset".equals(insetUnit.getStringValue())) { - return i; } insetUnit = (ScaledUnit)insetUnit.getNextLexicalUnit(); } - - + double hShadow = boxShadow.getPixelValue(); - - boxShadow = (ScaledUnit)boxShadow.getNextLexicalUnit(); - - double vShadow = boxShadow.getPixelValue(); boxShadow = (ScaledUnit)boxShadow.getNextLexicalUnit(); + + double vShadow = 0; + if (boxShadow == null) { + boxShadow = (ScaledUnit)style.get("cn1-box-shadow-v"); + } + if (boxShadow != null) { + vShadow = boxShadow.getPixelValue(); + boxShadow = (ScaledUnit)boxShadow.getNextLexicalUnit(); + } double blur = 0; - + if (boxShadow == null) { + boxShadow = (ScaledUnit)style.get("cn1-box-shadow-blur"); + } if (boxShadow != null) { blur = boxShadow.getPixelValue(); boxShadow = (ScaledUnit)boxShadow.getNextLexicalUnit(); } double spread = 0; + if (boxShadow == null) { + boxShadow = (ScaledUnit)style.get("cn1-box-shadow-spread"); + } if (boxShadow != null) { spread = boxShadow.getPixelValue(); } @@ -3168,12 +3173,8 @@ Insets getBoxShadowPadding(Map style) { i.left = Math.max(0, (int)Math.ceil(spread - hShadow + blur/2)); i.bottom = Math.max(0, (int)Math.ceil(spread + vShadow + blur/2)); i.right = Math.max(0, (int)Math.ceil(spread + hShadow + blur/2)); - - + return i; - - - } String generateBoxShadowPaddingString() {