2017-09-30 6 views
0

javafx의 테이블 뷰에서 하나의 열에 두 개의 버튼을 구현하려고합니다. 하나의 열에 하나의 버튼을 구현할 수 있지만 하나의 열에 두 개의 버튼을 추가 할 수는 없습니다. 나는 하나의 열에 두 개의 버튼을 추가하고 클릭 행 값을 얻으십시오. javafx

Add a button to a cells in a TableView (JAVAFX)

How to add two buttons in a TableColumn of TableView JavaFX

내가 위의 링크에서 아이디어를 사용하게

How to add button in JavaFX table view

이 링크에서 몇 가지 아이디어를 얻었다. 그러나 코드가 나를 위해 작동하지 않습니다.

TableColumn<Student, String> firstCol = new TableColumn<Student, String>("ID"); 
    TableColumn<Student, String> secondCol = new TableColumn<Student, String>("Name"); 
    TableColumn<Student, String> thirdCol = new TableColumn<Student, String>("Quiz Mark"); 
    TableColumn<Student, String> forthCol = new TableColumn<Student, String>("A1"); 
    TableColumn<Student, String> fifthCol = new TableColumn<Student, String>("A2"); 
    TableColumn<Student, String> sixthCol = new TableColumn<Student, String>("A3"); 
    TableColumn<Student, String> sevenCol = new TableColumn<Student, String>("Exam"); 
    TableColumn<Student, String> eightCol = new TableColumn<Student, String>("Result"); 
    TableColumn<Student, String> nineCol = new TableColumn<Student, String>("Grade"); 
    TableColumn<Student, Student> tenthCol = new TableColumn<Student, Student>("Action"); 


firstCol.setCellValueFactory(new PropertyValueFactory<>("Id")); 
    secondCol.setCellValueFactory(new PropertyValueFactory<>("Name")); 
    thirdCol.setCellValueFactory(new PropertyValueFactory<>("QuizMark")); 
    forthCol.setCellValueFactory(new PropertyValueFactory<>("Assingment1Mark")); 
    fifthCol.setCellValueFactory(new PropertyValueFactory<>("Assingment2Mark")); 
    sixthCol.setCellValueFactory(new PropertyValueFactory<>("Assingment3Mark")); 
    sevenCol.setCellValueFactory(new PropertyValueFactory<>("ExamMark")); 
    eightCol.setCellValueFactory(new PropertyValueFactory<>("Result")); 
    nineCol.setCellValueFactory(new PropertyValueFactory<>("Grade")); 
    tenthCol.setCellFactory(param -> new TableCell<Student, Student>() { 
     private final Button editButton = new Button("edit"); 
     private final Button deleteButton = new Button("delete"); 
     HBox pane = new HBox(deleteButton, editButton); 

     @Override 
     protected void updateItem(Student patient, boolean empty) { 
      super.updateItem(patient, empty); 

      if (patient == null) { 
       setGraphic(null); 
       return; 
      } 

      deleteButton.setOnAction(event -> { 
       Student getPatient = getTableView().getItems().get(getIndex()); 
       System.out.println(getPatient.getId() + " " + getPatient.getName()); 
      }); 

      editButton.setOnAction(event -> { 
       Student getPatient = getTableView().getItems().get(getIndex()); 
      }); 
      pane.getChildren().addAll(deleteButton,editButton); 
      setGraphic(pane); 
     } 
    }); 

image to describe the text

에서, 액션 칸의 버튼이 표시되지 않습니다. 나는 어디에서 실수하고 있니? 아무도 알려주지 마세요.

답변

0

tenthColumn 세포에 대한 cellValueFactory 항목을 결여 항상 null입니다. 행이 비어 있는지 확인하려면 updateItem 메서드의 두 번째 인수를 사용하십시오.

또한 이것을 나타내려면 열 유형을 TableColumn<Student, Void>으로 변경하십시오. getIndex()Button는 클릭 될 때 평가되므로

는 또 다시이 항목 onAction 핸들러 업데이트 될 때 불필요한 변경마다 HBox 자손 추가.

이에 코드를 변경할 수 있습니다 :

TableColumn<Student, Void> tenthCol = new TableColumn<>("Action"); 

... 

tenthCol.setCellFactory(param -> new TableCell<Student, Void>() { 
    private final Button editButton = new Button("edit"); 
    private final Button deleteButton = new Button("delete"); 
    private final HBox pane = new HBox(deleteButton, editButton); 

    { 
     deleteButton.setOnAction(event -> { 
      Student getPatient = getTableView().getItems().get(getIndex()); 
      System.out.println(getPatient.getId() + " " + getPatient.getName()); 
     }); 

     editButton.setOnAction(event -> { 
      Student getPatient = getTableView().getItems().get(getIndex()); 
     }); 
    } 

    @Override 
    protected void updateItem(Void item, boolean empty) { 
     super.updateItem(item, empty); 

     setGraphic(empty ? null : pane); 
    } 
});