Как предварительно выбрать изображение в GWT?

Я попробовал следующий код:

RootPanel root = RootPanel.get("root");
root.clear();
final FlowPanel p = new FlowPanel();
root.add(p);
for (int i=0; i<20; ++i) {
    String url = "/thumb/"+i;
    final Image img = new Image(url);
    img.addLoadHandler(new LoadHandler() {
        @Override
        public void onLoad(LoadEvent event) {
        p.add(img);
    }
});
Image.prefetch(url);

Но это не работает для меня. Я что-то пропустил?

Ответ 1

Обработчик нагрузки изображения вызывается только в том случае, когда изображение прикреплено к DOM. Таким образом, вы должны добавить изображение в DOM за пределами loadHandler:

p.add(img);
img.addLoadHandler(new LoadHandler() {
    @Override
    public void onLoad(LoadEvent event) {
        //do some stuff, image is loaded
    }
}

Ответ 2

То, что сказал Стэн, имеет смысл.

Я думаю, проблема в том, что LoadHandler почему-то не вызван. Мне всегда удалось без LoadHandler, но я обычно добавляю errorHandler в соответствии с демонстрацией JavaDoc, которая запускается, если загрузка не выполняется. Это должно работать:

final Image img = new Image();

img.addErrorHandler(new ErrorHandler() {
      public void onError(ErrorEvent event) {
        // Handle the error
      }
    });

img.setUrl(url);
p.add(img);

См. пример в GWT Javadoc: http://google-web-toolkit.googlecode.com/svn/javadoc/2.1/com/google/gwt/user/client/ui/Image.html

Ответ 3

ImageElement img = DOM.createImg().cast();
img.setSrc("images/myImage.png");