您不能轻松地将 mgwt 触摸事件与 GWT CellTable 一起使用。
如果 GWT-CellTable 更开放,您可以扩展它,从 Mgwt-CellTable 获取与触摸事件相关的代码,并将扩展类的容器设置为支持触摸的小部件。但这是不可能的,因为您无法设置或更改 GWT-CellTable 的小部件。
因此,不必扩展 GWT-CellTable,您必须复制自己类中的所有代码并添加来自 Mgwt-Cell 的触摸事件内容(请参阅 UlTouchWidget 和 InternalTouchHandler 代码)。但不方便的是,您必须将单元格表的样式设置为看起来可移动,这是一项艰巨的工作。
另一种选择是扩展 Mgwt-CellTable 以使其使用数据提供程序,但由于它扩展了 Composite 而不是 AbstractHasData,因此您必须包装 AbstractHasData 并以某种方式填充其所有 API。
最简单的选择是复制 Mgwt-CellTable 的代码,使其扩展 AbstractHasData 并实现一堆方法。使用这种方式,您将拥有一个移动外观的小部件。这对我有用:
// Copy mgwt CellList and change package and classname
package com.example;
// Make it extend AbstractHasData instead of Composite
public class MyCellList<T> extends AbstractHasData<T> {
/* Copy here all mgwt CellList code */
....
// Change the constructor to call the AbstractHasData one
public MyCellList(Cell<T> cell, ListCss css) {
super(new UlTouchWidget(),25, null);
main = (UlTouchWidget) getWidget();
css.ensureInjected();
this.cell = cell;
this.css = css;
internalTouchHandler = new InternalTouchHandler();
setStylePrimaryName(css.listCss());
}
// implement AbstractHasData methods
protected boolean dependsOnSelection() {
return false;
}
private Element fakeDiv = Document.get().createDivElement();
protected Element getChildContainer() {
return fakeDiv;
}
protected Element getKeyboardSelectedElement() {
return fakeDiv;
}
protected boolean isKeyboardNavigationSuppressed() {
return true;
}
protected void renderRowValues(SafeHtmlBuilder sb, List<T> values, int start,
SelectionModel<? super T> selectionModel)
throws UnsupportedOperationException {
render(values);
}
protected boolean resetFocusOnCell() {
return false;
}
protected void setKeyboardSelected(int index, boolean selected,
boolean stealFocus) {
}
}