2012-04-06 63 views
4

這是一個SSCCE,演示如何將Button放入TableView列。它的工作原理,但很少有不愉快的行爲。當通過鼠標使用滾動條向下滾動表格行時,新渲染的按鈕不會立即顯示。只有當鼠標被釋放然後移動時才顯示它們。我認爲還有另一種更優雅的方式來顯示錶格欄中的按鈕,並在點擊時選擇與選定行相關的東西。有什麼建議麼?將按鈕放入表格列更優雅

import javafx.application.Application; 
import javafx.collections.FXCollections; 
import javafx.collections.ObservableList; 
import javafx.event.ActionEvent; 
import javafx.event.EventHandler; 
import javafx.scene.Scene; 
import javafx.scene.control.*; 
import javafx.scene.control.cell.PropertyValueFactory; 
import javafx.scene.layout.StackPane; 
import javafx.scene.layout.StackPaneBuilder; 
import javafx.stage.Stage; 
import javafx.util.Callback; 

public class ButtonDemo extends Application { 

    private TableView<Person> personTable = new TableView<>(); 
    private TableColumn<Person, String> nameCol = new TableColumn<>("name"); 
    private TableColumn<Person, Double> salaryCol = new TableColumn<>("salary"); 
    private TableColumn<Person, String> actionCol = new TableColumn<>("action"); 

    @Override 
    public void start(Stage primaryStage) { 
     ObservableList<Person> data = FXCollections.observableArrayList(); 
     for (int i = 0; i < 40; i++) { 
      data.add(new Person("person_" + i, i * 100d)); 
     } 

     nameCol.setCellValueFactory(new PropertyValueFactory<Person, String>("name")); 
     salaryCol.setCellValueFactory(new PropertyValueFactory<Person, Double>("salary")); 
     actionCol.setCellValueFactory(new PropertyValueFactory<Person, String>("name")); // "name" here is for just to render the column 

     Callback<TableColumn<Person, String>, TableCell<Person, String>> printColumnCellFactory = // 
       new Callback<TableColumn<Person, String>, TableCell<Person, String>>() { 

      @Override 
      public TableCell call(final TableColumn param) { 
       final TableCell cell = new TableCell() { 

        @Override 
        public void updateItem(Object item, boolean empty) { 
         super.updateItem(item, empty); 
         if (empty) { 
          setText(null); 
          setGraphic(null); 
         } else { 
          final Button btnPrint = new Button("print name"); 
          btnPrint.setOnAction(new EventHandler<ActionEvent>() { 

           @Override 
           public void handle(ActionEvent event) { 
            param.getTableView().getSelectionModel().select(getIndex()); 
            Person item = personTable.getSelectionModel().getSelectedItem(); 
            if (item != null) { 
             System.out.println(item.getName()); 
            } 
           } 
          }); 
          setGraphic(btnPrint); 
          setContentDisplay(ContentDisplay.GRAPHIC_ONLY); 
         } 
        } 
       }; 
       return cell; 
      } 
     }; 
     actionCol.setCellFactory(printColumnCellFactory); 

     personTable.setItems(data); 
     personTable.getColumns().addAll(nameCol, salaryCol, actionCol); 
     StackPane root = StackPaneBuilder.create().children(personTable).build(); 
     primaryStage.setScene(new Scene(root, 300, 250)); 
     primaryStage.show(); 
    } 

    public class Person { 

     private String name; 
     private Double salary; 

     public Person(String name, Double salary) { 
      this.name = name; 
      this.salary = salary; 
     } 

     public String getName() { 
      return name; 
     } 

     public Double getSalary() { 
      return salary; 
     } 
    } 

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

哪個FX版本可以使用?無法用FX 2.1最新開發版本重現您的問題 - http://www.oracle.com/technetwork/java/javafx/downloads/devpreview-1429449.html – 2012-04-06 16:44:43

+0

目前我正在使用javaFX 2.0.1。如果使用鼠標的中間按鈕進行滾動,則立即渲染列上的按鈕。通過拖動表格的滾動條完成滾動時會發生問題。對於我發佈的示例代碼,如果滾動條同時上下拖動,所有按鈕最終都會消失。 – 2012-04-09 08:30:33

+0

看起來像一個錯誤,你的代碼是正確的。也許你想升級到2.1dev? - 通過鼠標拖動滾動在那裏工作。 – 2012-04-09 08:47:01

回答

0

升級到2.1版解決了這個問題。