在 CellTable 单元格中添加双击事件 - GWT

Posted

技术标签:

【中文标题】在 CellTable 单元格中添加双击事件 - GWT【英文标题】:adding Double click event in CellTable cell - GWT 【发布时间】:2011-06-16 11:32:27 【问题描述】:

我无法弄清楚如何将双击事件添加到 CellTable 的单元格中。

GWT CellTable 是否可行?

有什么办法吗

谢谢你..

al

顺便说一句,我看到了这个帖子,但没有回复...... http://www.devcomments.com/Adding-DoubleClicks-and-OnContextMenu-to-CellTable-at1066168.htm

【问题讨论】:

【参考方案1】:

将此留在这里以备将来参考

    private Set<GenericEventHandler<T>> dblClickHandlers = new HashSet<>(4);

dblClickHandlers 只是映射我选择的接口实现

    table.addCellPreviewHandler(event -> 
        if (BrowserEvents.DBLCLICK.equalsIgnoreCase(event.getNativeEvent().getType())) 
            LOGGER.info("dblclick (native) " + event.getIndex() + "  " + event.getColumn() + "; " + event.getValue());
            dblClickHandlers.forEach(handler -> 
                handler.onEvent(event.getValue());
            );
        
    );
    table.sinkBitlessEvent(BrowserEvents.DBLCLICK);

诀窍是接收 'dblclick' 事件。

【讨论】:

【参考方案2】:

由于 CellPreview 接口本身不捕获双击事件,您需要将事件逻辑添加到 Overriden onCellPreview 方法中。首先,您会认为最好的方法是检查点击时间差异。然而,使用状态机并计算点击次数会更加高效和优雅。这更加健壮,允许您处理多种事件情况 - 例如鼠标悬停、单击和双击。代码非常简单。尽情享受吧!

public class CellHoverHandler implements Handler<T> 

    Timer singleClickTimer;
    int clickCount = 0;
    int clickDelay = 300;

    @Override
    public void onCellPreview(final CellPreviewEvent<T> event) 
        if (Event.getTypeInt(event.getNativeEvent().getType()) == Event.ONMOUSEOVER) 
            handleOnMouseOver(event);
         else if (Event.getTypeInt(event.getNativeEvent().getType()) == Event.ONCLICK) 
            clickCount++;
            if (clickCount == 1) 
                singleClickTimer = new Timer() 

                    @Override
                    public void run() 
                        clickCount = 0;
                        handleOnClick(event);
                    
                ;
                singleClickTimer.schedule(clickDelay);
             else if (clickCount == 2) 
                singleClickTimer.cancel();
                clickCount = 0;
                handleOnDblClick(event);
            
        
    

    private void handleOnMouseOver(CellPreviewEvent<T> event) 
        Element cell = event.getNativeEvent().getEventTarget().cast();
        GWT.log("mouse over event");
    

    private void handleOnClick(CellPreviewEvent<T> event) 
        Element cell = event.getNativeEvent().getEventTarget().cast();
        GWT.log("click event");
    

    private void handleOnDblClick(CellPreviewEvent<T> event) 
        Element cell = event.getNativeEvent().getEventTarget().cast();            
        GWT.log("double click event");
    

优化:随意将计数、计时器和延迟作为静态类成员或全局成员进行重用。在创建新实例之前还要检查计时器是否为空。为简单起见,我省略了这一点。与许多其他技术不同,这种方式仍然可以让您轻松直接地访问单元格事件。重载 AbstractCell 的技术也很有效,但是有时您确实没有自定义单元格,或者想要制作一个自定义单元格来处理单元格上的事件。

【讨论】:

【参考方案3】:

对于单元格列表,此代码可以正常工作:

  cellList.addDomHandler(new DoubleClickHandler() 
    @Override
    public void onDoubleClick(DoubleClickEvent event) 
      // do the stuff
    
  , DoubleClickEvent.getType());

我不确定表格单元格

【讨论】:

【参考方案4】:
Integer row=0;// to hold row index
Integer column=0;// to hold column index 
_Grid.addCellPreviewHandler(new CellPreviewEvent.Handler<Model>() 
// this is to handle row id
        @Override
        public void onCellPreview(final CellPreviewEvent<Model> event) 

            if (BrowserEvents.CLICK.equalsIgnoreCase(event.getNativeEvent().getType())) 
                row = event.getIndex();
                column=event.getColumn();
            

        
    );

// because Doubleclick handler doesn't give row index or column index we will use addCellPreviewHandler to return row index or column index.
_Grid.addDomHandler(new DoubleClickHandler() 

        @Override
        public void onDoubleClick(final DoubleClickEvent event) 
            System.out.println(" You clicked row = " + row);
            System.out.println(" You clicked column = " + column);

        
    , DoubleClickEvent.getType());

【讨论】:

在我们的例子中,我们已经在跟踪选择上下文,因此以这种方式添加处理程序效果很好,而且很好且无创。它适用于网格选择模型以及 onCellPreview。【参考方案5】:
    cellTable.addDomHandler(new DoubleClickHandler() 

        @Override
        public void onDoubleClick(DoubleClickEvent event) 
            Window.alert("That's it!");
        
    , DoubleClickEvent.getType());

【讨论】:

您将无法使用这种方式访问​​单元格或单元格表数据,例如行索引或列索引。 如果用户单击 CellTable 上的任何位置,包括标题或未填充行的空白区域,此处理程序将触发。我不认为这是个好主意。【参考方案6】:

我制作了一些不同的东西来满足我的需要:

cellTable.addCellPreviewHandler(new Handler<TitoloProxy>() 

           long lastClick=-1000;

           @Override
           public void onCellPreview(CellPreviewEvent<TitoloProxy> event) 
               long clictAt = System.currentTimeMillis();
               GWT.log("clickAt: "+(clictAt));
               GWT.log("lastClick: "+(lastClick));
               if(event.getNativeEvent().getType().contains("click"))
                   GWT.log(""+(clictAt-lastClick));
                   if(clictAt-lastClick < 300)  // dblclick on 2 clicks detected within 300 ms
                       Window.alert("I am a double click crafted event!");

                   
                   lastClick = System.currentTimeMillis();
               
           
       );

【讨论】:

可以进行更优雅的事件类型检查,而不是event.getNativeEvent().getType().contains("click")。尝试Event.getTypeInt(event.getNativeEvent().getType()) == Event.ONCLICK,将Event.ONCLICK 替换为与所需事件相对应的枚举(使用 GWT 2.4 测试)。 这不支持parrellel中的单击事件=( @SuperKakes 你是对的,但如果你使用 Boris 解决方案,你将能够区分单击和双击。如果您仍然想使用我的解决方案,您可以在 .contains("click") 测试中区分单击和双击。我没有试过你。【参考方案7】:

如果您想要一个文本单元格来支持您自己选择的事件列表,您可以使用:

public class EventfulTextCell extends AbstractSafehtmlCell`<String`> 

    private static final String[] NO_CONSUMED_EVENTS = null; 

    public EventfulTextCell() 
        this(NO_CONSUMED_EVENTS);
    

    public EventfulTextCell(String... consumedEvents) 
        super(SimpleSafeHtmlRenderer.getInstance(), consumedEvents);
    

    @Override
    public void render(Context context, SafeHtml value, SafeHtmlBuilder sb) 
        if (value != null) 
            sb.append(value);
        
    

然后你实例化它:

new EventfulTextCell("click", "dblclick")

然后重写 onBrowserEvent() 方法来处理你的事件。

【讨论】:

以上是关于在 CellTable 单元格中添加双击事件 - GWT的主要内容,如果未能解决你的问题,请参考以下文章

在celltable gwt中添加url列

在 CellTable 中从输入切换到输入

Excel如何实现输入时在后面添加而不替换单元格中的内容?

在表格视图单元格中双击应该在 didSelectRowAtIndexPath 之前 [重复]

vba 判断一个单元格中是不是包含某个字符串 有则执行后面的语句

UITableView 单元格中的 UIButton,例如“删除事件”