首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何修改TreeTableView的点击行为

如何修改TreeTableView的点击行为
EN

Stack Overflow用户
提问于 2014-03-27 10:16:24
回答 2查看 2.4K关注 0票数 6

我想修改TreeTableView的点击行为,但老实说,我不知道这样做的目的是什么,或者它是否是要以任何方式改变的。

大多数用户抱怨当前的行为不一致。有时对单元格的单击会折叠/展开树项,有时需要双击。这与削弱编辑模式可能是一种痛苦。所以我很乐意自己处理点击行为。

我能够将行为缩小到TreeTableCellBehavior类:

代码语言:javascript
复制
@Override
protected void handleClicks(MouseButton button, int clickCount, boolean isAlreadySelected) {
        // handle editing, which only occurs with the primary mouse button
        TreeItem<S> treeItem = getControl().getTreeTableRow().getTreeItem();
        if (button == MouseButton.PRIMARY) {
            if (clickCount == 1 && isAlreadySelected) {
                edit(getControl());
            } else if (clickCount == 1) {
                // cancel editing
                edit(null);
            } else if (clickCount == 2 && treeItem.isLeaf()) {
                // attempt to edit
                edit(getControl());
            } else if (clickCount % 2 == 0) {
                // try to expand/collapse branch tree item
                treeItem.setExpanded(! treeItem.isExpanded());
            }
        }
}

不幸的是,我没有看到任何可能创造一个钩子或任何东西来改变这种行为。因为行为类和皮肤是内部类,所以我看不到创建自己行为的任何可能性。因此,有没有人知道,在TreeTableView的哪个点,我应该加入修改TreeTableView的点击行为。

编辑:似乎代码改变了,因为我张贴了代码。所以我更新了这个问题。我还找到了部分公共api访问,但仍然不知道如何覆盖点击行为。有人能给我什么线索吗?

Edit2:由于brians的评论,我创建了一个小示例,并将其与用户体验文档进行了比较。它按照所描述的方式工作(=>“节点可以通过单击"turner”图标或双击节点名称来打开(注意,如果启用编辑,双击将进入编辑模式)。“),直到我将TreeTableView的TreeColumn更改为另一列,然后是第一列(这是我的项目和示例代码之间的唯一区别)。更改列会导致奇怪的行为: turner不再对单个鼠标做出反应,有时(几乎不发生)选择没有正确设置,而是节点被展开/折叠。

我添加了一个小例子来演示这个问题:

代码语言:javascript
复制
public class TreeTableViewTurnerIssueExample extends Application
{
  @Override
  public void start( final Stage primaryStage )
  {
    TreeItem<Item> root = new TreeItem<>( new Item( "Root", "Root" ) );

    TreeItem<Item> item1 = new TreeItem<>( new Item( "1", "Item1" ) );
    TreeItem<Item> item2 = new TreeItem<>( new Item( "2", "Item2" ) );
    TreeItem<Item> item3 = new TreeItem<>( new Item( "3", "Item3" ) );
    TreeItem<Item> item4 = new TreeItem<>( new Item( "4", "Item4" ) );
    TreeItem<Item> item41 = new TreeItem<>( new Item( "4.1", "Item41" ) );
    TreeItem<Item> item42 = new TreeItem<>( new Item( "4.2", "Item42" ) );
    TreeItem<Item> item43 = new TreeItem<>( new Item( "4.3", "Item43" ) );
    TreeItem<Item> item5 = new TreeItem<>( new Item( "5", "Item5" ) );
    TreeItem<Item> item52 = new TreeItem<>( new Item( "5.1", "Item51" ) );

    root.getChildren().add( item1 );
    item1.getChildren().add( item2 );
    root.getChildren().add( item3 );
    item3.getChildren().add( item4 );
    item4.getChildren().add( item41 );
    item4.getChildren().add( item42 );
    item4.getChildren().add( item43 );
    root.getChildren().add( item5 );
    item5.getChildren().add( item52 );

    TreeTableColumn<Item, String> nameColumn = new TreeTableColumn<>( "Name" );
    TreeTableColumn<Item, String> valueColumn = new TreeTableColumn<>( "Value" );

    nameColumn.setCellValueFactory( new TreeItemPropertyValueFactory<Item, String>( "name" ) );
    valueColumn.setCellValueFactory( new TreeItemPropertyValueFactory<Item, String>( "value" ) );

    final TreeTableView<Item> treeTableView = new TreeTableView<>( root );
    treeTableView.getColumns().add( nameColumn );
    treeTableView.getColumns().add( valueColumn );

    treeTableView.setTreeColumn( valueColumn );//<- changing this to the first column, the clickbehavior is fine.

    treeTableView.setShowRoot( false );
    treeTableView.setColumnResizePolicy( TreeTableView.CONSTRAINED_RESIZE_POLICY );

    BorderPane layout = new BorderPane();
    layout.setCenter( treeTableView );
    Scene scene = new Scene( layout, 400, 400 );
    scene.getStylesheets().add( getClass().getResource( "application.css" ).toExternalForm() );
    primaryStage.setScene( scene );
    primaryStage.show();
  }

  public static void main( final String[] args )
  {
    launch( args );
  }
}


public class Item
{
  private final StringProperty name  = new SimpleStringProperty();
  private final StringProperty value = new SimpleStringProperty();

  public Item( final String name, final String value )
  {
    this.name.set( name );
    this.value.set( value );
  }

  public String getName()
  {
    return name.get();
  }

  public void setName( final String name )
  {
    this.name.set( name );
  }

  public StringProperty nameProperty()
  {
    return name;
  }

  public String getValue()
  {
    return value.get();
  }

  public void setValue( final String value )
  {
    this.value.set( value );
  }

  public StringProperty valueProperty()
  {
    return value;
  }
}

我还创建了一个Jira机票,因为我认为这确实是一个bug,除非有人可以指出我在这个示例中所犯的任何错误。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-02-23 20:41:05

这似乎是在8u60中修复的一个官方错误,您可以在这里看到:Jira

如果您仍然希望修改您的TreeTableView的单击行为,您可能需要使用一个EventFilter,将事件委托给您的实现并使用这些事件。幸运的是,对于我来说,默认的行为将可以再次修复,所以我停止了进一步的研究。

票数 0
EN

Stack Overflow用户

发布于 2015-02-21 01:22:33

也许你可以尝试一个事件过滤器。由于我不详细了解您的用例,这里是一个简单的示例,没有任何错误处理,可以将MouseEvent EventHandler添加到TreeTableView中,以便通过代码展开/折叠TreeItems

代码语言:javascript
复制
treeTableView.addEventHandler( MouseEvent.MOUSE_CLICKED, new EventHandler<MouseEvent>(){
    @Override
    public void handle( MouseEvent e )
    {
        TreeTableCell<Item, String> cell = (TreeTableCell<Item, String>) e.getTarget();
        TreeItem<Item> item = cell.getTreeTableView().getTreeItem( cell.getTreeTableRow().getIndex() );
        item.setExpanded( !item.isExpanded() );
    }
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22684465

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档