以下方法对我有用。它基于 Zack Linder 的建议
Google Web Toolkit ›布局面板问题
(1) 将 HeaderLayoutPanel 附加到您的 RootLayoutPanel。headerLayoutPanel 是您创建的扩展 HeaderPanel 并实现 ProvidesResize() 的类。
import com.google.gwt.user.client.ui.HeaderPanel;
import com.google.gwt.user.client.ui.ProvidesResize;
import com.google.gwt.user.client.ui.SimpleLayoutPanel;
import com.google.gwt.user.client.ui.Widget;
public class HeaderLayoutPanel extends HeaderPanel implements ProvidesResize {
SimpleLayoutPanel contentPanel;
public HeaderLayoutPanel() {
super();
contentPanel=new SimpleLayoutPanel();
}
@Override
public void setContentWidget(Widget w) {
contentPanel.setSize("100%","100%");
contentPanel.setWidget(w);
super.setContentWidget(contentPanel);
}
public void onResize() {
int w=Window.getClientWidth();
int h=Window.getClientHeight();
super.setPixelSize(w, h);
}
}
(2)接下来,实例化一个HeaderLayoutPanel。页眉和页脚小部件被分配了一个固定的高度(例如菜单栏高度),并且它们的宽度会自动调整为面板的宽度。中心小部件应该是 ProvidesSize。我使用了一个布局面板。例如,
public class AppViewer extends Composite implements MyApp.AppDisplay {
private HeaderLayoutPanel allContentsPanel;
MenuBar menuBarTop;
MenuBar menuBarBottom;
LayoutPanel dataPanel;
public AppViewer() {
allContentsPanel = new HeaderLayoutPanel();
menuBarTop = new MenuBar(false);
menuBarBottom = new MenuBar(false);
dataPanel = new LayoutPanel();
menuBarTop.setHeight("30px");
menuBarBottom.setHeight("20px");
allContentsPanel.setHeaderWidget(menuBarTop);
allContentsPanel.setFooterWidget(menuBarBottom);
allContentsPanel.setContentWidget(dataPanel);
initWidget(allContentsPanel);
}
@Override
public void doOnResize() {
allContentsPanel.onResize();
}
}
(3) 中心小部件 (LayoutPanel) 将包含我在单独的 Composite 中定义的 DeckLayoutPanel(但您可以做任何您想做的事情)。例如,
public class MyDataView extends Composite implements MyDataPresenter.DataDisplay {
private DockLayoutPanel pnlAllContents;
private HorizontalPanel hpnlButtons;
private HorizontalPanel hpnlToolbar;
private VerticalPanel pnlContent;
public MyView() {
pnlAllContents=new DockLayoutPanel(Unit.PX);
pnlAllContents.setSize("100%", "100%");
initWidget(pnlAllContents);
hpnlToolbar = new HorizontalPanel();
hpnlToolbar.setWidth("100%");
pnlAllContents.addNorth(hpnlToolbar, 30);
hpnlButtons = new HorizontalPanel();
hpnlButtons.setWidth("100%");
pnlAllContents.addSouth(hpnlButtons,20);
pnlContent=new VerticalPanel();
//center widget - takes up the remainder of the space
pnlAllContents.add(pnlContent);
...
}
}
(4) 最后,所有内容都在 onModuleLoad() 类中绑定在一起:AppViewer 生成添加到 RootLayoutPanel 的显示,MyDataView 生成添加到容器的 display.asWidget()。例如,
public class MyApp implements EntryPoint,Presenter{
private HasWidgets container=RootLayoutPanel.get();
private static AppDisplay display;
private DataPresenter dataPresenter;
public interface AppDisplay extends Display{
@Override
Widget asWidget();
HasWidgets getContentContainer();
void doOnResize();
}
@Override
public void onModuleLoad() {
display=new AppViewer();
dataPresenter = new DataPresenter();
display.getContentContainer().add(dataPresenter.getDisplay().asWidget());
container.add(display.asWidget());
bind();
}
@Override
public void bind() {
Window.addResizeHandler(new ResizeHandler() {
@Override
public void onResize(ResizeEvent event) {
display.doOnResize();
}
});
}
@Override
public com.midasmed.client.presenter.Display getDisplay() {
return display;
}
}
希望这可以帮助!