X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Forg%2Fxwt%2FPicture.java;h=13440f95a02ff8a5b051f6000624badb38e80f1c;hb=0b0673bbc7f06c5d5418d5ab7ad5961a464e2de0;hp=316839011f28a3742dad8e26294de377601aa024;hpb=a76646eb76b01b5f1b5f0507b1c4bcd4202f1f11;p=org.ibex.core.git diff --git a/src/org/xwt/Picture.java b/src/org/xwt/Picture.java index 3168390..13440f9 100644 --- a/src/org/xwt/Picture.java +++ b/src/org/xwt/Picture.java @@ -33,25 +33,34 @@ public abstract class Picture { private static Cache cache = new Cache(100); private static GIF gif = new GIF(); + public static class Holder { + public Picture picture = null; + } + /** turns a resource into a Picture.Source and passes it to the callback */ - public static Picture fromRes(final Res r, final Callback callback) { - Picture ret = (Picture)cache.get(r); - if (ret != null) return ret; + public static Holder fromRes(final Res r, final Scheduler.Task callback) { + Holder ret = (Holder)cache.get(r); + if (ret == null) { + ret = new Holder(); + cache.put(r, ret); + if (callback == null) return null; + } + final Holder holder = ret; if (callback != null) new java.lang.Thread() { public void run() { try { final byte[] b = InputStreamToByteArray.convert(r.getInputStream()); Scheduler.add(new Scheduler.Task() { public void perform() { try { - Picture ret = null; + Picture p = null; InputStream pbis = new ByteArrayInputStream(b); - if ((b[0] & 0xff) == 'G') ret = gif.fromInputStream(pbis, "some picture"); - else if ((b[0] & 0xff) == 137) ret = new PNG().fromInputStream(pbis, "some picture"); - else if ((b[0] & 0xff) == 0xff) ret = Platform.decodeJPEG(pbis, "some picture"); + if ((b[0] & 0xff) == 'G') p = gif.fromInputStream(pbis, "some picture"); + else if ((b[0] & 0xff) == 137) p = new PNG().fromInputStream(pbis, "some picture"); + else if ((b[0] & 0xff) == 0xff) p = Platform.decodeJPEG(pbis, "some picture"); else throw new JS.Exn("couldn't figure out image type from first byte"); - ret.res = r; - cache.put(r, ret); - callback.call(ret); + p.res = r; + holder.picture = p; + Scheduler.add(callback); } catch (Exception e) { Log.log(Picture.class, e); } } }); @@ -60,6 +69,6 @@ public abstract class Picture { return; } } }.start(); - return null; + return ret; } }