我有一个简单的Cell类:
public class MyCell implements AbstractCell<MyDto> {
...
@Override
public void render(com.google.gwt.cell.client.Cell.Context context,
MyDto value, SafeHtmlBuilder sb) {
}
}
如何在此类单元格中收听MGWT TapEvent?
编辑:我不想使用MGWT提供的CellList,我需要使用GWT的CellList,因为这使我可以使用数据提供程序。
可以将一个触摸代表链接到Cell吗?
最佳答案
您不能在GWT CellTable中轻松使用mgwt触摸事件。
如果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) {
}
}