]> git.argeo.org Git - lgpl/argeo-commons.git/blobdiff - swt/org.argeo.cms.swt/src/org/argeo/cms/swt/osgi/BundleSvgTheme.java
Improve image management and ACR
[lgpl/argeo-commons.git] / swt / org.argeo.cms.swt / src / org / argeo / cms / swt / osgi / BundleSvgTheme.java
index e65f226e2bf8174119a229c2a51c275912ecda04..038a1fca62a210ea331d12600bfac01fd44a67d5 100644 (file)
@@ -1,5 +1,6 @@
 package org.argeo.cms.swt.osgi;
 
+import java.awt.Color;
 import java.io.ByteArrayInputStream;
 import java.io.ByteArrayOutputStream;
 import java.io.IOException;
@@ -9,6 +10,7 @@ import java.lang.System.Logger.Level;
 import java.util.Collections;
 import java.util.HashMap;
 import java.util.Map;
+import java.util.Objects;
 
 import org.apache.batik.transcoder.TranscoderException;
 import org.apache.batik.transcoder.TranscoderInput;
@@ -24,17 +26,29 @@ import org.osgi.framework.BundleContext;
 public class BundleSvgTheme extends BundleCmsSwtTheme {
        private final static Logger logger = System.getLogger(BundleSvgTheme.class.getName());
 
-       private Map<String, Map<Integer, Image>> imageCache = Collections.synchronizedMap(new HashMap<>());
+//     private Map<String, Map<Integer, Image>> imageCache = Collections.synchronizedMap(new HashMap<>());
 
        private Map<Integer, ImageTranscoder> transcoders = Collections.synchronizedMap(new HashMap<>());
 
+       private final static String IMAGE_CACHE_KEY = BundleSvgTheme.class.getName() + ".imageCache";
+
        @Override
        public Image getIcon(String name, Integer preferredSize) {
                String path = "icons/types/svg/" + name + ".svg";
                return createImageFromSvg(path, preferredSize);
        }
 
+       @SuppressWarnings("unchecked")
        protected Image createImageFromSvg(String path, Integer preferredSize) {
+               Display display = Display.getCurrent();
+               Objects.requireNonNull(display, "Not a user interface thread");
+
+               Map<String, Map<Integer, Image>> imageCache = (Map<String, Map<Integer, Image>>) display
+                               .getData(IMAGE_CACHE_KEY);
+               if (imageCache == null)
+                       display.setData(IMAGE_CACHE_KEY, new HashMap<String, Map<Integer, Image>>());
+               imageCache = (Map<String, Map<Integer, Image>>) display.getData(IMAGE_CACHE_KEY);
+
                Image image = null;
                if (imageCache.containsKey(path)) {
                        image = imageCache.get(path).get(preferredSize);
@@ -42,7 +56,7 @@ public class BundleSvgTheme extends BundleCmsSwtTheme {
                if (image != null)
                        return image;
                ImageData imageData = loadFromSvg(path, preferredSize);
-               image = new Image(Display.getDefault(), imageData);
+               image = new Image(display, imageData);
                if (!imageCache.containsKey(path))
                        imageCache.put(path, Collections.synchronizedMap(new HashMap<>()));
                imageCache.get(path).put(preferredSize, image);
@@ -57,6 +71,7 @@ public class BundleSvgTheme extends BundleCmsSwtTheme {
                                transcoder = new PNGTranscoder();
                                transcoder.addTranscodingHint(PNGTranscoder.KEY_WIDTH, (float) size);
                                transcoder.addTranscodingHint(PNGTranscoder.KEY_HEIGHT, (float) size);
+                               transcoder.addTranscodingHint(PNGTranscoder.KEY_BACKGROUND_COLOR, new Color(255, 255, 255, 0));
                                transcoders.put(size, transcoder);
                        }
                }
@@ -90,16 +105,16 @@ public class BundleSvgTheme extends BundleCmsSwtTheme {
 //             }
        }
 
-       @Override
-       public void destroy(BundleContext bundleContext, Map<String, String> properties) {
-               Display display = Display.getDefault();
-               if (display != null)
-                       for (String path : imageCache.keySet()) {
-                               for (Image image : imageCache.get(path).values()) {
-                                       display.syncExec(() -> image.dispose());
-                               }
-                       }
-               super.destroy(bundleContext, properties);
-       }
+//     @Override
+//     public void destroy(BundleContext bundleContext, Map<String, String> properties) {
+//             Display display = Display.getDefault();
+//             if (display != null)
+//                     for (String path : imageCache.keySet()) {
+//                             for (Image image : imageCache.get(path).values()) {
+//                                     display.syncExec(() -> image.dispose());
+//                             }
+//                     }
+//             super.destroy(bundleContext, properties);
+//     }
 
 }