我是GWT的新手,并尝试按照文档与UIBinders合作。
我认为我已经从以下某些来源中了解了我在该主题上发现的所有内容
http://www.gwtproject.org/doc/latest/DevGuideClientBundle.html#ImageResource
http://www.gwtproject.org/doc/latest/DevGuideUiBinder.html#Using_an_external_resource
GWT UiBinder and Image Sprites
我收到错误无法从ImageResource转换为图片,并且无法在其他位置找到此错误。
我做过的事情:
制作了一个可以看到图像的客户端套件
将图像绑定在java文件中
将客户端捆绑包资源导入UiBinder。
思想:
这是将图像放入UiBinders的最简单/推荐的方法
我是否必须通过CSS或Java类来完成它?
[ERROR] [ideaburger] - Errors in 'generated://D3BBFDA474FCF1195FACA7F6BC58EB44/com/IdeaBurger/client/SiteHeader_SiteHeaderUiBinderImpl.java'
[ERROR] [ideaburger] - Line 115: Type mismatch: cannot convert from ImageResource to Image
[INFO] [ideaburger] - See snapshot: /tmp/com.IdeaBurger.client.SiteHeader_SiteHeaderUiBinderImpl4360657308873324011.java
这就是我所拥有的。
SiteHeader.ui.xml
<!DOCTYPE ui:UiBinder SYSTEM "http://dl.google.com/gwt/DTD/xhtml.ent">
<ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder" xmlns:g="urn:import:com.google.gwt.user.client.ui">
<ui:with field='res' type='com.IdeaBurger.assets.Images'/>
<ui:style>
</ui:style>
<ui:Image field="logoImage" resource='{res.logo}' />
<g:HTMLPanel>
<g:HorizontalPanel>
<g:cell>
<g:Label>One</g:Label>
</g:cell>
</g:HorizontalPanel>
</g:HTMLPanel>
</ui:UiBinder>
SiteHeader.java
package com.IdeaBurger.client;
import com.IdeaBurger.assets.Images;
import com.google.gwt.core.client.GWT;
import com.google.gwt.uibinder.client.UiBinder;
import com.google.gwt.uibinder.client.UiField;
import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.Image;
import com.google.gwt.user.client.ui.Widget;
public class SiteHeader extends Composite {
private static SiteHeaderUiBinder uiBinder = GWT
.create(SiteHeaderUiBinder.class);
@UiField Images res;
@UiField Image logoImage;
interface SiteHeaderUiBinder extends UiBinder<Widget, SiteHeader> {
}
public SiteHeader() {
initWidget(uiBinder.createAndBindUi(this));
}
}
我的客户端套装,
Images.java
package com.IdeaBurger.assets;
import com.google.gwt.resources.client.ClientBundle;
import com.google.gwt.resources.client.ImageResource;
public interface Images extends ClientBundle {
@Source("logo.png")
ImageResource logo();
}
由于
答案 0 :(得分:2)
好的,我想出了至少一种方法。
我在上面的代码中有很多错误,这是我需要做的修复它。
以下是工作代码:
SiteHeader.ui.xml
<!DOCTYPE ui:UiBinder SYSTEM "http://dl.google.com/gwt/DTD/xhtml.ent">
<ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder"
xmlns:g="urn:import:com.google.gwt.user.client.ui">
<ui:with field='res' type='com.IdeaBurger.assets.Images'/>
<ui:style>
</ui:style>
<g:HTMLPanel>
<img src='{res.logo.getSafeUri}' />
<g:HorizontalPanel>
<g:cell>
<g:Label>One</g:Label>
</g:cell>
</g:HorizontalPanel>
</g:HTMLPanel>
</ui:UiBinder>
SiteHeader.java
package com.IdeaBurger.client;
import com.IdeaBurger.assets.Images;
import com.google.gwt.core.client.GWT;
import com.google.gwt.uibinder.client.UiBinder;
import com.google.gwt.uibinder.client.UiField;
import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.Widget;
public class SiteHeader extends Composite {
private static SiteHeaderUiBinder uiBinder = GWT
.create(SiteHeaderUiBinder.class);
@UiField Images res;
interface SiteHeaderUiBinder extends UiBinder<Widget, SiteHeader> {
}
public SiteHeader() {
initWidget(uiBinder.createAndBindUi(this));
}
}
干杯